创建用户表以及使用触发器

创建用户表,用户额外的表以及触发器:

CREATE TABLE user( 
uid int   primary key AUTO_INCREMENT,
birthday varchar(50),
email varchar(50) not null unique default '0',
school varchar(30),
register_day varchar(50) not null default '0',
gender varchar(1) default '0' check(gender in('1','0')),
password  varchar(20) not null default '0'
);
create  table user_a(
uid int not null,
user_name varchar(50)  ,
signature  varchar(255),
head_url varchar(255),
job  varchar(255),
hobby varchar(255),
introduction varchar(255)
)



DELIMITER |
 
CREATE TRIGGER  conn AFTER INSERT ON user
  FOR EACH ROW BEGIN
       insert into user_a set uid = NEW.uid;
	   update user_a set user_name= CONCAT(NEW.uid) where uid=NEW.uid;
	   END
|

有以下的几点注意:

触发器不能修改触发器所依赖的表。比如用户注册后如果没有修改昵称,那么称就是uid号.一开始是将user_name放在user表中间的,也就是要把uid赋给同一行的user_name.这一部分使用的是这样的触发器:

DELIMITER |
 
CREATE TRIGGER  conn AFTER INSERT ON user
  FOR EACH ROW BEGIN
	   update user set user_name= CONCAT(NEW.uid) where uid=NEW.uid;
	   END
|

这样做的话user表连插入都不能用。说明不能这样做。

此外:

mysql不支持 for each statement

也不支持标准sql语句。(比如 insert into user_a (uid) values (new.uid) 这种标准的sql语句)不能有返回值(比如要使用select)。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值