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!