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创建吧
解决 无用评论 打赏 举报
悬赏问题
- ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
- ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿
- ¥15 回答4f系统的像差计算
- ¥15 java如何提取出pdf里的文字?
- ¥100 求三轴之间相互配合画圆以及直线的算法