mysql update more than one row_一直报[Err] 1172 - Result consisted of more than one row错误

2023-10-18 22:59

本文主要是介绍mysql update more than one row_一直报[Err] 1172 - Result consisted of more than one row错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

create table BorrowState

(

bcardno varchar(8) not null,

bno varchar(15) primary key,

bdate date ,

rdate date

);

14d7cbbb69881c23282bc3227417eda4.png

这是之前插入的,想要插入新的就报下面的错误了。

5121aba1e8a3419fdbc2442ad602ed2c.png

还有3段触发器的编码,全创建成功了,我觉得应该没错,但就是无法测试成功。

6)为读者信息表创建一个删除触发器,当一个读者调出本单位时,将此读者的资料从读者信息表中删除。注意实施业务规则:有借阅书的读者不得从读者信息表中删除。

create trigger reader_del before delete on reader

for each row

begin

declare a varchar(8);

if not exists(select * from borrowstate WHERE bcardno=a and rdate is NULL) THEN

delete from reader where bcardno=a;

end IF;

end;

7)借阅处理:为借阅表设计INSERT触发器,在读者借阅时更改ISBN类别信息表,且可借数量减1,图书信息表是否可借列的值变为“不可借”,读者信息表中该读者已借阅数加1。

create trigger borrow_insert after insert on BorrowState

for each row

begin

declare b varchar(15);

select bno into b from BorrowState;

update ISBNbook,bookstate set brest=brest-1 where BookState.bno=b and ISBNbook.isbnno=BookState.isbnno;

update BookState set bstate="不可借" where bno=b;

update Reader,borrowstate set ramount=ramount-1,bamount=bamount+1 where BorrowState.bno=b and Reader.bcardno=BorrowState.bcardno;

end;

8)还书处理:为借阅信息表设计UPDATE触发器,在读者借阅时更改ISBN类别信息表,且可借数量加1,图书信息表是否可借列的值变为“可借”,读者信息表中该读者已借阅数减1。

create trigger borrow_update after update on BorrowState

for each row

begin

declare b varchar(15);

select bno INTO b from BorrowState where rdate is not NULL;

update ISBNbook,bookstate

set brest=brest+1 where BookState.bno=b and ISBNbook.isbnno=BookState.isbnno;

update BookState

set bstate="可借" where bno=b;

update Reader,borrowstate

set ramount=ramount+1,bamount=bamount-1 where BorrowState.bno=b and Reader.bcardno=BorrowState.bcardno;

end;

下面是建好的其他3个表

create table ISBNbook

(

isbnno varchar(10) primary key,

kind varchar(10),

bname varchar(20),

writer varchar(20),

press varchar(20),

pressdate varchar (8),

price double,

store int(5) not null,

brest int(5) not null,

introduction varchar(200)

)

create table BookState

(

isbnno varchar(10) not null,

bno varchar(15) primary key,

bstate varchar(10) not null

)

create table Reader

(

bcardno varchar(8) primary key,

rname varchar(20),

sex varchar(2),

birth varchar (8),

id varchar(20),

career varchar(20),

ramount int(5) not null,

bamount int(5) not null,

department varchar(20),

address varchar(50),

telephone varchar(20)

)

请各位大神帮忙,万分感谢!

这篇关于mysql update more than one row_一直报[Err] 1172 - Result consisted of more than one row错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/235662

相关文章

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

MySQL 筛选条件放 ON后 vs 放 WHERE 后的区别解析

《MySQL筛选条件放ON后vs放WHERE后的区别解析》文章解释了在MySQL中,将筛选条件放在ON和WHERE中的区别,文章通过几个场景说明了ON和WHERE的区别,并总结了ON用于关... 今天我们来讲讲数据库筛选条件放 ON 后和放 WHERE 后的区别。ON 决定如何 "连接" 表,WHERE

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

MySQL日志UndoLog的作用

《MySQL日志UndoLog的作用》UndoLog是InnoDB用于事务回滚和MVCC的重要机制,本文主要介绍了MySQL日志UndoLog的作用,文中介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、Undo Log 的作用二、Undo Log 的分类三、Undo Log 的存储四、Undo

MySQL游标和触发器的操作流程

《MySQL游标和触发器的操作流程》本文介绍了MySQL中的游标和触发器的使用方法,游标可以对查询结果集进行逐行处理,而触发器则可以在数据表发生更改时自动执行预定义的操作,感兴趣的朋友跟随小编一起看看... 目录游标游标的操作流程1. 定义游标2.打开游标3.利用游标检索数据4.关闭游标例题触发器触发器的基

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.