Kita tidak bisa melakukan itu. Kita perlu mengetikkan semua kolom dan fungsi NVL() masing-masing. Saya tahu itu sepertinya membutuhkan banyak usaha, tetapi pertimbangkan apa yang akan terjadi jika salah satu kolom Anda adalah DATE atau tipe data "eksotis" lainnya.
Jika Anda memiliki banyak kolom dan Anda benar-benar ingin menghemat tenaga, Anda dapat membuat klausa dari kamus data:
select 'nvl('|| column_name || ', 0)'
from user_tab_columns
where table_name = 'STUDENT'
order by column_id;
Cut'n'paste hasil yang disetel ke editor.
Setelah Anda memulai rute ini, mudah untuk menjadi lebih canggih:
select case when column_id > 1 then ',' end ||
'nvl('|| column_name || ',' ||
case when data_type = 'DATE' then 'sysdate'
when data_type = 'VARCHAR2' then '''DEF'''
else '0' end ||
')'
from user_tab_columns
where table_name = 'STUDENT'
order by column_id;