create table users(userId varchar(10) not null, /*用户账号,主键*/userName varchar(10) not null, /*用户名*/userPassword varchar(10) not null, /*密码*/idNo varchar(20) not null, /*身份证号码,唯一*/userMoney numeric(10,2) default 0, /*总金额,不能小于零*/userStatus varchar(4) check (userStatus='使用' or userStatus='冻结') default '使用', /*用户状态(使用,冻结),默认是使用中*/userAddress varchar(30) not null, /*用户地址*/startTime DateTime, /*开户时间,应该是开户时的系统时间,不应该人为输入*/primary key(userId), /*设置主键*/)--用户的状态一旦变成冻结状态,那么卡也应该不能使用create trigger userstatus_updateon usersafter updateasif update(userStatus)begin if (select userStatus from inserted) = '冻结'update card set cardStatus = '冻结' where userId = (select userId from deleted)if (select userStatus from inserted) = '使用'update card set cardStatus = '使用' where userId = (select userId from deleted) end
1条回答 默认 最新
- kun_hello 2016-11-22 01:46关注
CREATE TABLE users (
userId VARCHAR (10) NOT NULL,
userName VARCHAR (10) NOT NULL,
userPassword VARCHAR (10) NOT NULL,
idNo VARCHAR (20) NOT NULL,
userMoney NUMERIC (10, 2) DEFAULT 0,
userStatus VARCHAR (4) ,
userAddress VARCHAR (30) NOT NULL,
startTime DATETIME,
PRIMARY KEY (userId)
);CREATE TRIGGER userstatus_updateon usersafter updateasif
UPDATE
(userStatus)
BEGIN
IF
(SELECT
userStatus
FROM
inserted) = '冻结'
UPDATE
card
SET
cardStatus = '冻结'
WHERE userId =
(SELECT
userId
FROM
deleted) IF
(SELECT
userStatus
FROM
inserted) = '使用'
UPDATE
card
SET
cardStatus = '使用'
WHERE userId =
(SELECT
userId
FROM
deleted)
END约束另外写sql创建吧
解决 无用评论 打赏 举报
悬赏问题
- ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
- ¥30 深度学习,前后端连接
- ¥15 孟德尔随机化结果不一致
- ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
- ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
- ¥15 谁有desed数据集呀
- ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
- ¥15 关于#hadoop#的问题
- ¥15 (标签-Python|关键词-socket)
- ¥15 keil里为什么main.c定义的函数在it.c调用不了