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
Mary-Kate Olsenasal
2024-12-17 05:21:26835semak imbas

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()
);

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();

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!

Kenyataan:
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