防止在MySQL字段中设置零值?

在表上使用触发器BEFORE INSERT可以防止MySQL字段中的值为零。让我们首先创建一个表-

mysql> create table DemoTable(Value int);

让我们创建一个触发器来防止MySQL字段中的值为零-

mysql> DELIMITER //
mysql> create trigger preventing_to_insert_zero_value
   before insert on DemoTable
   for each row
   begin
      if(new.Value = 0) then SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'You can not provide 0 value';
   END if;
end
//
mysql> DELIMITER ;

让我们在表中插入0值,并检查是否要插入该值。它不允许-

mysql> insert into DemoTable values(0);
ERROR 1644 (45000): You cannot provide 0 value

因此,在上表中,由于触发,您不能插入0值。但是,您可以插入其他一些值。

现在让我们使用insert命令在表中插入一些记录-

mysql> insert into DemoTable values(10);
mysql> insert into DemoTable values(-1000);

使用select语句显示表中的所有记录-

mysql> select *from DemoTable;

这将产生以下输出-

+-------+
| Value |
+-------+
| 10    |
| -1000 |
+-------+
2 rows in set (0.00 sec)