Sqlserver
 sql >> Teknologi Basis Data >  >> RDS >> Sqlserver

Apa praktik terbaik untuk kunci utama dalam tabel?

Saya mengikuti beberapa aturan:

  1. Kunci utama harus sekecil mungkin. Lebih suka tipe numerik karena tipe numerik disimpan dalam format yang jauh lebih ringkas daripada format karakter. Ini karena sebagian besar kunci utama akan menjadi kunci asing di tabel lain serta digunakan dalam beberapa indeks. Semakin kecil kunci Anda, semakin kecil indeksnya, semakin sedikit halaman dalam cache yang akan Anda gunakan.
  2. Kunci utama tidak boleh berubah. Memperbarui kunci utama harus selalu keluar dari pertanyaan. Ini karena kemungkinan besar akan digunakan dalam beberapa indeks dan digunakan sebagai kunci asing. Memperbarui satu kunci utama dapat menyebabkan efek riak perubahan.
  3. JANGAN gunakan "kunci utama masalah Anda" sebagai kunci utama model logika Anda. Misalnya nomor paspor, nomor jaminan sosial, atau nomor kontrak karyawan karena "kunci alami" ini dapat berubah dalam situasi dunia nyata. Pastikan untuk menambahkan batasan UNIK untuk ini jika perlu untuk menegakkan konsistensi.

Pada surrogate vs natural key, saya mengacu pada aturan di atas. Jika kunci alami kecil dan tidak akan pernah berubah dapat digunakan sebagai kunci utama. Jika kunci alami besar atau cenderung berubah, saya menggunakan kunci pengganti. Jika tidak ada kunci utama, saya masih membuat kunci pengganti karena pengalaman menunjukkan Anda akan selalu menambahkan tabel ke skema Anda dan berharap Anda akan meletakkan kunci utama di tempatnya.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Pernyataan SQL CASE:Apa itu dan apa cara terbaik untuk menggunakannya?

  2. Panggil prosedur tersimpan dengan parameter di c #

  3. Cara menggunakan Pernyataan Kasus untuk Pemformatan Bersyarat di Kueri Pilih - Tutorial SQL Server / TSQL Bagian 116

  4. SQL Server PIVOT mungkin?

  5. Replikasi Basis Data SQL Server