Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Kunci unik dengan NULL

Properti dasar dari kunci unik adalah bahwa itu harus unik. Menjadikan bagian dari kunci Nullable akan menghancurkan properti ini.

Ada dua kemungkinan solusi untuk masalah Anda:

  • Salah satu cara, cara yang salah, adalah menggunakan tanggal ajaib untuk mewakili yang tidak diketahui. Ini hanya membuat Anda melewati "masalah" DBMS tetapi tidak menyelesaikan masalah secara logis. Harapkan masalah dengan dua entri "John Smith" yang tanggal lahirnya tidak diketahui. Apakah orang-orang ini satu dan sama atau mereka individu yang unik? Jika Anda tahu mereka berbeda maka Anda kembali ke masalah lama yang sama -Kunci Unik Anda tidak unik. Jangan pernah berpikir untuk menetapkan rentang tanggal ajaib untuk mewakili "tidak diketahui" - ini benar-benar jalan menuju neraka.

  • Cara yang lebih baik adalah membuat atribut EmployeeId sebagai kunci pengganti. Ini hanyalah pengidentifikasi arbitrer yang Anda tetapkan ke individu yang kenal unik. Pengenal ini sering kali hanya berupa nilai integer. Kemudian buat tabel Karyawan untuk menghubungkan EmployeeId (unik, non-nullablekey) dengan apa yang Anda yakini sebagai atributer dependen, dalam hal iniNama dan Tanggal Lahir (semuanya dapat dibatalkan). Gunakan kunci pengganti EmployeeId di mana pun Anda sebelumnya menggunakan Nama/Tanggal Lahir. Ini menambahkan tabel baru ke sistem Anda tetapi memecahkan masalah nilai yang tidak diketahui dengan cara yang kuat.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Fungsi MySQL SELECT untuk menjumlahkan data saat ini

  2. Kolom kardinalitas yang lebih tinggi pertama dalam indeks ketika melibatkan rentang?

  3. php mysql_connect Peringatan nonaktifkan

  4. Kesalahan migrasi di Django 2; AttributeError:objek 'str' tidak memiliki atribut 'decode'

  5. Konversi MySQL ke SQLite