Rumah > pangkalan data > tutorial mysql > Bolehkah MySQL Menggunakan Fungsi untuk Menetapkan Nilai Lajur Lalai?

Bolehkah MySQL Menggunakan Fungsi untuk Menetapkan Nilai Lajur Lalai?

Mary-Kate Olsen
Lepaskan: 2024-12-17 05:21:26
asal
816 orang telah melayarinya

Can MySQL Use Functions to Set Default Column Values?

Menetapkan Nilai Lalai dengan Fungsi dalam MySQL

Dalam MySQL, nilai lalai untuk lajur jadual biasanya ditetapkan sebagai nilai statik, seperti pemalar atau ungkapan. Walau bagaimanapun, sesetengah pengguna mungkin menghadapi keadaan di mana mereka ingin menetapkan nilai lalai menggunakan fungsi. Soalan ini meneroka sama ada fungsi sedemikian disokong dalam MySQL.

Soalan:

Bolehkah MySQL menetapkan nilai lajur lalai menggunakan fungsi? Sebagai contoh, bolehkah pernyataan berikut berjaya dilaksanakan?

create table app_users
(
    app_user_id smallint(6) not null auto_increment primary key,
    api_key     char(36) not null default uuid()
);
Salin selepas log masuk

Jawapan:

Tidak, MySQL tidak membenarkan memberikan nilai lajur lalai menggunakan fungsi. Percubaan untuk berbuat demikian akan mengakibatkan ralat.

Penyelesaian:

Walaupun MySQL sendiri tidak menyokong nilai lalai berasaskan fungsi, penyelesaian boleh dicapai menggunakan pencetus. Berikut ialah contoh pencetus yang memberikan nilai UUID lalai kepada lajur api_key sebelum memasukkan baris baharu ke dalam jadual app_users:

CREATE TRIGGER before_insert_app_users
  BEFORE INSERT ON app_users 
  FOR EACH ROW
  SET new.api_key = uuid();
Salin selepas log masuk

Pencetus ini secara automatik akan menjana dan menetapkan UUID baharu kepada lajur api_key untuk setiap baharu baris dimasukkan ke dalam jadual app_users.

Atas ialah kandungan terperinci Bolehkah MySQL Menggunakan Fungsi untuk Menetapkan Nilai Lajur Lalai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan