- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 MYSQL 中完成一项作业。表中有一列跟踪作者的佣金百分比。元组中的佣金值加起来应始终为 100
R is the relation R ={authorid,isbn,commission} (authorid,isbn) --> primary key
因此,元组可以包含一个 ISBN 的多个作者,每个作者具有不同的佣金值。我们应该确保 isbn 的佣金加起来应始终为 100,不少于或不少于 100。我该如何实现?我被告知要使用触发器来实现相同的目的,但是,我没有想法了。
我只能想到像下面这样的触发器(高级逻辑)
SELECT isbn,sum(commission) FROM R GROUP BY isbn
我获取总佣金并检查该值是否为 100,然后据此拒绝插入/更新
但这意味着我会拒绝用户想要依次插入 3 个元组的情况,其中佣金分别为 20,30,50。这是一个有效的案例。插入内容如下所示
INSERT INTO R(authorid,isbn,commission) VALUES (1,2,20)
INSERT INTO R(authorid,isbn,commission) VALUES (2,2,30)
INSERT INTO R(authorid,isbn,commission) VALUES (3,2,50)
您能指导我吗?如果我不清楚,请告诉我。我觉得在数据库端进行这种验证是不寻常的,但是,这是一项任务,所以应该想出一些解决方案
我在网上查看过类似的问题是否已经解决。查看了 MYSQL 文档,但没有运气。
最佳答案
您可以用于插入
此触发器
DELIMITER $$
CREATE TRIGGER commisiontest
BEFORE INSERT ON R
FOR EACH ROW
BEGIN
SELECT sum(commission) into @commision FROM R WHERE isbn = NEw.isbn GROUP BY isbn;
IF (NEW.commission + @commision) > 100
THEN
SIGNAL SQLSTATE '02000' SET MESSAGE_TEXT = 'Warning: commission reaches 100 or above';
END IF;
END$$
DELIMITER ;
这样就可以了
INSERT INTO R(authorid,isbn,commission) VALUES (3,2,50)
Error Code: 1643. Warning: commission reaches 100 or above 0.000 sec
类似的事情也适用于更新
因此这将防止佣金高于 100%
关于mysql - 检查表中的列值加起来是否等于 100(百分比),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58671714/
我正在尝试执行 vagrant up 但一直遇到此错误: ==> default: IOError: [Errno 13] Permission denied: '/usr/local/lib/pyt
我在容器 div 中有一系列动态创建的不同高度的 div。 Varying text... Varying text... Varying text... Varying text.
通过 cygwin 运行 vagrant up 时遇到以下错误。 stderr: /bin/bash: /home/vagrant/.ansible/tmp/ansible-tmp-14872260
今天要向小伙伴们介绍的是一个能够快速地把数据制作成可视化、交互页面的 Python 框架:Streamlit,分分钟让你的数据动起来! 犹记得我在做机器学习和数据分析方面的毕设时,
我是 vagrant 的新手,正在尝试将第二个磁盘添加到我正在用 vagrant 制作的虚拟机中。 我想出了如何在第一次启动虚拟机时连接磁盘,但是当我关闭机器时 然后再次备份(使用 'vagrant
我是一名优秀的程序员,十分优秀!