Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

Parameterisasi nama tabel dalam file input sqlplus

Masalahnya adalah SQL*Plus memperlakukan seluruh string setelah & , hingga spasi putih atau simlar berikutnya, sebagai nama variabel substitusi. Jelas bukan itu yang Anda inginkan di sini.

Untungnya mereka telah memikirkan hal ini, dan Anda dapat menandai akhir nama variabel dengan . :

FROM &3._TABLE

(Setidaknya, itu berfungsi untuk variabel bernama, dan saya hampir yakin itu akan berfungsi untuk variabel posisi... jika tidak maka Anda perlu mendefinisikan variabel baru yang disetel ke &3 sebagai solusi).

Ada di dokumentasi , tapi berkedip dan Anda akan melewatkannya:

Ada efek terkait yang mungkin ingin Anda ingat untuk masa depan. Jika karakter berikutnya setelah variabel substitusi adalah . anyway - antara skema dan tabel, atau antara tabel dan kolom, misalnya - maka itu akan ditafsirkan sebagai terminator substitusi. Katakanlah Anda melewati skema secara terpisah sebagai &4 , dengan nilai 'scott'; ini:

FROM &4.&3._TABLE

terlihat masuk akal tetapi akan diganti sebagai scottdev_TABLE , yang tidak akan dikenali. Jadi dalam hal ini Anda perlu memiliki satu tambahan:

FROM &4..&3._TABLE

yang akan diganti sebagai scott.dev_TABLE .




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Bagaimana cara memformat pencetakan SQL Query dengan cantik di SQLAlchemy?

  2. Menggunakan where in di spring-jdbc

  3. Cara Membuat Array Asosiatif Di Database Oracle

  4. Bagaimana Menerapkan Independensi Basis Data dengan Entity Framework

  5. Mendapatkan kesalahan saat memanggil fungsi apa pun dalam kueri SQL dalam sebuah paket tanpa mendeklarasikan fungsi dalam spesifikasi paket