MySQL数据库安全之防止撰改的方法
MySQL数据库可以通过触发器,使之无法修改某些字段的数据,同时又不会影响修改其他字段。
DROPTRIGGERIFEXISTS`members`; SET@OLD_SQL_MODE=@@SQL_MODE,SQL_MODE=''; DELIMITER// CREATETRIGGER`members`BEFOREUPDATEON`members`FOREACHROWBEGIN setnew.name=old.name; setnew.cellphone=old.cellphone; setnew.email=old.email; setnew.password=old.password; END// DELIMITER; SETSQL_MODE=@OLD_SQL_MODE;
再举一个例子:
CREATETABLE`account`( `id`INT(10)UNSIGNEDNOTNULLAUTO_INCREMENT, `user`VARCHAR(50)NOTNULLDEFAULT'0', `cash`FLOATNOTNULLDEFAULT'0', PRIMARYKEY(`id`) ) COLLATE='utf8_general_ci' ENGINE=InnoDB;
每一次数据变化新增一条数据
INSERTINTO`test`.`account`(`user`,`cash`)VALUES('neo',-10);
INSERTINTO`test`.`account`(`user`,`cash`)VALUES('neo',-5);
INSERTINTO`test`.`account`(`user`,`cash`)VALUES('neo',30);
INSERTINTO`test`.`account`(`user`,`cash`)VALUES('neo',-20);
保护用户的余额不被修改
DROPTRIGGERIFEXISTS`account`; SET@OLD_SQL_MODE=@@SQL_MODE,SQL_MODE=''; DELIMITER// CREATETRIGGER`account`BEFOREUPDATEON`account`FOREACHROWBEGIN setnew.cash=old.cash; END// DELIMITER; SETSQL_MODE=@OLD_SQL_MODE;
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语