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

Bagaimana cara memperluas Liquibase untuk menghasilkan log perubahan dengan prosedur, fungsi, dan pemicu tersimpan?

Anda benar bahwa strategi umumnya adalah membuat kelas baru yang mengimplementasikan SnapshotGenerator, tetapi ada beberapa langkah lain yang perlu Anda lakukan juga. Proses snapshot umumnya adalah:

  1. Liquibase mencari implementasi SnapshotGenerator dan memanggil addTo() untuk setiap objek yang ditemukannya di database. Untuk tipe Anda, Anda mungkin menginginkan "jika lulus objek instanceof Schema" cepat karena mereka adalah tipe yang merupakan bagian dari skema.
  2. Anda perlu membuat objek Package, StoredProcedure, dll baru yang mengimplementasikan DatabaseObject. Mereka akan seperti kelas liquibase.structure.core.Table dan menangkap status objek. Mereka dibuat dalam metode SnapshotGenerator.addsTo() Anda hingga dapat diidentifikasi (nama, skema, kumpulan dll)
  3. Semua objek yang ditambahkan oleh metode addTo() kemudian dijalankan melalui metode SnapshotGenerator.snapshotObject() Anda yang akan menarik metadata tambahan yang awalnya tidak Anda dapatkan, seperti teks prosedur tersimpan, dll.
  4. Setelah liquibase memiliki snapshot yang berisi objek Anda, liquibase akan membandingkan snapshot tersebut dengan snapshot lain (dalam kasus generateChangeLog, snapshot kosong) untuk menentukan objek apa yang hilang, tidak terduga, dan berubah di snapshot kedua. Kemudian mencari implementasi MissingObjectChangeGenerator, UnexpectedObjectChangeGenerator, dan ChangedObjectChangeGenerator. Untuk generateChangeLog hanya akan ada objek yang "hilang" sehingga Anda dapat mengimplementasikan MissingTriggerChangeGenerator, MissingPackagedChangeGenerator, dll. Tugas mereka adalah membuat instance Change untuk membuat objek yang hilang
  5. Kelas Msising*ChangeGenerator dapat mengembalikan instance RawSqlChange atau Anda dapat membuat implementasi Perubahan baru seperti CreateTriggerChange.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. ORA-12705:Tidak dapat mengakses file data NLS atau lingkungan yang tidak valid

  2. Contoh Skema di GitHub

  3. Bisakah saya menghubungkan tautan basis data di Oracle?

  4. ORACLE - Pilih Hitung pada Subquery

  5. JUnit/HSQLDB:Cara mengatasi kesalahan dengan sintaks Oracle saat menguji menggunakan HSQLDB (tanpa hak istimewa dan/atau tanpa objek DUAL)