** 举例 1:** 定义 “Field_Not_Be_NULL” 错误名与 MySQL 中违反非空约束的错误类型是 “ERROR 1048 (23000)” 对应。...CONDITION FOR SQLSTATE '23000'; ** 举例 2:** 定义 "ERROR 1148 (42000)" 错误,名称为 command_not_allowed。...在存储过程中,定义处理程序,捕获 sqlstate_value 值,当遇到 sqlstate_value 值为 23000 时,执行 EXIT 操作,并且将 @proc_value 的值设置为 - 1。...游标 # 4.1 什么是游标(或光标) 虽然我们也可以通过筛选条件 WHERE 和 HAVING,或者是限定返回记录的关键字 LIMIT 返回一条记录,但是,却无法在结果集中像指针一样,向前定位一条记录...函数的功能可以实现累加薪资最高的几个员工的薪资值,直到薪资总和达到 limit_total_salary 参数的值,返回累加的人数给 total_count。
在提交注册信息的时候报错:SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry 'admin' for key 'username...' 原因:主键冲突 违反完整性约束 字段唯一索引 从上图可以看出,用户名和邮箱必须唯一,如果填入重复的用户名或者邮箱就会出错 解决方法:在控制器里面进行判断 data=input(′post.′);data
在提交注册信息的时候报错:SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry ‘admin’ for key ‘username...’ 原因:主键冲突 违反完整性约束 字段唯一索引 从上图可以看出,用户名和邮箱必须唯一,如果填入重复的用户名或者邮箱就会出错 解决方法:在控制器里面进行判断 $data = input('post.
为了避免冲突,首先用"DELIMITER &&"将MySQL的结束符设置为&&。最后再用"DELIMITER ;"来将结束符恢复成分号。这与创建触发器时是一样的。... [characteristic ...] routine_body 其中,sp_name参数是存储函数的名称;func_parameter表示存储函数的参数列表;RETURNS type指定返回值的类型... ); END 上述代码中,存储函数的名称为name_from_employee;该函数的参数为emp_id;返回值是VARCHAR类型。...SELECT语句从employee表查询num值等于emp_id的记录,并将该记录的name字段的值返回。...SQLWARNING表示所有以01开头的sqlstate_value值。NOT FOUND表示所有以02开头的sqlstate_value值。
为了避免冲突,首先用"DELIMITER &&"将MySQL的结束符设置为&&。最后再用"DELIMITER ;"来将结束符恢复成分号。这与创建触发器时是一样的。...type [characteristic ...] routine_body 其中,sp_name参数是存储函数的名称;func_parameter表示存储函数的参数列表;RETURNS type指定返回值的类型...); END 上述代码中,存储函数的名称为name_from_employee;该函数的参数为emp_id;返回值是VARCHAR类型。...SELECT语句从employee表查询num值等于emp_id的记录,并将该记录的name字段的值返回。...SQLWARNING表示所有以01开头的sqlstate_value值。NOT FOUND表示所有以02开头的sqlstate_value值。
· 错误:1216 SQLSTATE: 23000 (ER_NO_REFERENCED_ROW) 消息:无法添加或更新子行,外键约束失败。...· 错误:1217 SQLSTATE: 23000 (ER_ROW_IS_REFERENCED) 消息:无法删除或更新父行,外键约束失败。...· 错误:1223 SQLSTATE: HY000 (ER_CANT_UPDATE_WITH_READLOCK) 消息:由于存在冲突的读锁定,无法执行查询。...· 错误:1451 SQLSTATE: 23000 (ER_ROW_IS_REFERENCED_2) 消息:不能删除或更新父行,外键约束失败(%s)。...· 错误:1452 SQLSTATE: 23000 (ER_NO_REFERENCED_ROW_2) 消息:不能添加或更新子行,外键约束失败(%s)。
错误:1242 SQLSTATE: 21000 (ER_SUBQUERY_NO_1_ROW) 消息:子查询返回1行以上。...冲突声明:’%s%s’和’%s%s’ 错误:1303 SQLSTATE: 2F003 (ER_SP_NO_RECURSIVE_CREATE) 消息:不能从另一个存储子程序中创建%s。...错误:1415 SQLSTATE: 0A000 (ER_SP_NO_RETSET) 消息:不允许从%s返回结果集。...错误:1451 SQLSTATE: 23000 (ER_ROW_IS_REFERENCED_2) 消息:不能删除或更新父行,外键约束失败(%s)。...错误:1452 SQLSTATE: 23000 (ER_NO_REFERENCED_ROW_2) 消息:不能添加或更新子行,外键约束失败(%s)。
类代码 23 约束违例 表 18. 类代码 23:约束违例 SQLSTATE 值 含义23001 RESTRICT 更新或删除规则防止父键被更新或删除。...类代码 38:外部函数异常 SQLSTATE 值 含义38XXX 外部例程或触发器返回有效错误 SQLSTATE。38001 不允许外部例程执行 SQL 语句。...类代码 39:外部函数调用异常 SQLSTATE 值 含义39001 用户定义的函数已返回无效 SQLSTATE。39004 不允许 IN 或 INOUT 参数为空值。...类代码 40:事务回滚 SQLSTATE 值 含义40001 发生了伴随自动回滚的超时或死锁。40003 语句完整性未知。40504 由于系统错误导致工作单元被回滚。...类代码 40:事务回滚 SQLSTATE 值 含义 40001 发生了伴随自动回滚的超时或死锁。 40003 语句完整性未知。 40504 由于系统错误导致工作单元被回滚。
首先与存储过程一样,只能返回一条结果记录。另外就是存储函数只能指明一列数据作为结果,而存储过程能够指明多列数据作为结果。...因为id属性有主键约束,所以不能插入相同的id。...'23000'; -- 主键约束的错误值 DECLARE CONTINUE HANDLER FOR primary_key_limit SET @info = -1; -- 设计如果出现错误...'23000'; -- 主键约束的错误值 DECLARE EXIT HANDLER FOR primary_key_limit SET @info = -1; -- 使用EXIT策略,遇到SQL...'23000'; -- 主键约束的错误值 DECLARE EXIT HANDLER FOR primary_key_limit SET @info = -1; -- 设计如果出现错误,@info
表中一定要有各种约束,通过约束,让我们未来插入数据库表中的数据是符合预期的。约束的本质是通过技术收到逼迫程序员插入正确的数据,反过来,站在mysql的视角,凡是插入进来的数据,都是符合数据约束的。...约束的最终目标:保证数据的完整性和可预期性所以需要更多的约束。...> insert into t14 (name,age) values ('张三',20); Query OK, 1 row affected (0.00 sec) default和NOT NULL不冲突...Query OK, 0 rows affected (0.07 sec) Records: 0 Duplicates: 0 Warnings: 0 对b列添加了zerofill属性,再进行查找,返回如下结果...我们选择某一列作为主键,但是并不排除其他属性不需要维护,可能需要用到唯一键来限定,选择其他列作为唯一键,与主键配合起来,能够保证一些数据冲突。
约束 (constraint) 概述 # 1.1 为什么需要约束 数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。...为了保证数据的完整性,SQL 规范以约束的方式对表数据进行额外的条件限制。...如果删除主键约束了,主键约束对应的索引就自动删除了。 需要注意的一点是,不要修改主键字段的值。因为主键是数据记录的唯一标识,如果修改了主键的值,就有可能会破坏数据的完整性。...FOREIGN KEY 约束 # 6.1 作用 限定某个表的某个字段的引用完整性。 比如:员工表的员工所在部门的选择,必须在部门表能找到对应的部分。...碰到运算符,通常返回 null。 (2)效率不高。影响提高索引效果。
SQLite 约束:约束是在表的数据列上强制执行的规则 约束可以是列级或表级。...列级约束仅适用于列,表级约束被应用到整个表 (1)以下是在 SQLite 中常用的约束 NOT NULL 约束:确保某列不能有 NULL 值。...:(不知道这样算不算正确,我也不是理解的太深刻) 交叉连接后结果非常多,慎用 左外连接会填充NULL,内连接不会 4, SQLite Unions子句:用于合并两个或多个 SELECT 语句的结果,不返回任何重复的行...基本语法如下: CREATE INDEX index_name ON table_name (column_name); 唯一索引:使用唯一索引不仅是为了性能,同时也为了数据的完整性。...索引自动创建为主键约束和唯一约束。
函数可以从语句外调用,能返回标量值。...存储过程 3、执行Proc() 存储过程 ❝注意:“DELIMITER //”语句的作用是将MySQL的结束符设置为//,因为MySQL默认的语句结束符为分号;,为了避免与存储过程」 中SQL语句结束符相冲突...例如,如果一个函数返回一个SET或ENUM值,但是RETURN语句返回一个整数,对于SET成员集的相应ENUM成员,从函数返回的值 是字符串。...如果DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' SET @X2=1;,这一行不存在 第二个INSERT因PRIMARY KEY约束而失败之后,MySQL可能已经采取...然后,将结果返回给输出值。
关系数据库还定义了三种约束完整性:实体完整性、参照完整性以及用户定义完整性。大多数主流数据库都属于关系数据库,例如 Oracle、MySQL、SQL Server 以及 PostgreSQL 等。...关系型数据库有哪些约束? 答案: 关系数据库定义了以下约束: 非空约束(NOT NULL),用于限制字段不会出现空值。比如员工姓名不能为空。唯一约束(UNIQUE),用于确保字段中的值不会重复。...,修改约束,删除约束等。...另外,数据库还必须保证满足完整性约束,比如账户扣款之后不能出现余额为负数(可以在余额字段上添加检查约 束)。Isolation,隔离性。...另外,InnoDB 还支持外键约束,能够维护数据的完整性。MyISAM 存储引擎数据文件占用的空间更小。MyISAM 采用表级锁,限制了同时读写的性能,通常用于只读或者以读为主的应 用。
存储过程 3、执行Proc() 存储过程 注意:“DELIMITER //”语句的作用是将MYSQL的结束符设置为//,因为MYSQL默认的语句结束符为分号;,为了避免与存储过程 中SQL语句结束符相冲突...如果在存储函数中的RETURN语句返回一个类型不同于函数的RETURNS子句中指定类型的值,返回值将被强制转换为恰当的类型。...例如,如果一个函数返回一个SET或ENUM值,但是RETURN语句返回一个整数,对于SET成员集的相应ENUM成员,从函数返回的值 是字符串。...如果DECLARE CONTINUE HANDLER FOR SQLSTATE '23000' SET @X2=1;,这一行不存在 第二个INSERT因PRIMARY KEY约束而失败之后,MYSQL可能已经采取...然后,将结果返回给输出值。
数据表操作 基础操作 -- 1.创建表(类似于一个excel表) create table tab_name( field1 type[完整性约束条件],...tab_name 查看当前数据库表建表语句 -- 3.修改表结构 -- (1)增加列(字段) alter table tab_name add [column] 列名 类型[完整性约束条件...add birth varchar(20) after name; -- (2)修改一列类型 alter table tab_name modify 列名 类型 [完整性约束条件...INT, click_num INT, is_top TINYINT(1), content TEXT ); 完整性约束条件之主键约束...在使用EXISTS关键字时,内层查询语句不返回查询的记录。 -- 而是返回一个真假值。
,MySQL会自动生成一个类似:{table_name}_check_{seq_num}的约束名称,约束名称是大小写敏感的,且最长可以到64个字符 expr设定了一个返回值为boolean类型的约束条件...模式下,可能返回不同的结果 另外,在INFORMATION_SCHEMA的CHECK_CONSTRAINTS表中存放着所有表中定义的CHECK约束的信息。...EACH ROW BEGIN IF (NEW.pid 0 AND NEW.pid NOT IN (select id from department)) THEN signal sqlstate...department FOR EACH ROW BEGIN IF (OLD.id < 0 OR OLD.id IN (select pid from department)) THEN signal sqlstate...to be chosen from id'; END IF; END 如果属于业务逻辑,建议放在应用层处理,方便开发者:理解和维护,但是:也需要通过强化业务管理,避免特权用户偶发操作引起对数据完整性的破坏
第一种,Basic INSERT,即是最普通的 INSERT 语句,语法 INSERT INTO VALUES (),语义为插入一条语句,若发生唯一约束冲突(主键冲突、唯一索引冲突),则返回执行失败。...第三种,语法 INSERT INTO VALUES () ON DUPLICATE KEY UPDATE,是当冲突后,更新冲突行后插入数据。如果更新后的行跟表中另一行冲突,则返回错误。...在 batchChecker 中,首先,拿待插入的数据,将其中可能冲突的唯一约束在 getKeysNeedCheck 中构造成 Key(TiDB 是通过构造唯一的 Key 来实现唯一约束的,详见 《三篇文章了解...在这次 UPDATE 中,可能还是会遇到唯一约束冲突的问题,如果遇到了,此时即报错返回,如果该语句是 INSERT IGNORE ON DUPLICATE KEY UPDATE 则会忽略这个错误,继续下一行...简要说明一下就是,一般的 INSERT 语句如果需要 INSERT 某一行,那将会当遭遇了唯一约束冲突的时候,出现以下几种处理方式: 放弃插入,报错返回:Basic INSERT 放弃插入,不报错:INSERT
常见的数据库对象 表 : 存储数据的逻辑单元 数据字典 : 就是系统表, 存放数据库相关的信息 约束 : 执行数据校验的规则,用于保证数据完整性的规则 视图 :一个或者多个数据表里的数据的逻辑显示,试图并不存储数据...) 仅仅带有IN类型(有参无返回) 仅仅带有OUT类型(无参有返回) 即带有IN 又带有OUT (有参有返回) CREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 参数类型)...RETURNS 返回值类型 BEGIN 函数体 #函数体一定要有返回值 END 特征 对比两者 : 数据库完整性 实体完整性 实体完整性就是说 : 创建表的时候用PRIMARY KEY 来定义单属性...触发器通常用于实现数据完整性约束和业务逻辑,以及在数据发生变化时执行一些自定义的操作。...insert之前操作 表employees FOR EACH ROW -- 对每一行都要执行 BEGIN -- 开始执行 IF NEW.salary < 0 THEN -- 判断条件 SIGNAL SQLSTATE
十七、约束 约束概述 为什么需要约束? 为了保证数据的完整性。 数据完整性(Data Integrity)是指数据的精确性(Accuracy)和可靠性(Reliability)。...为了保证数据的完整性,SQL规范以约束的方式对表数据进行额外的条件限制。...为了避免与存储过程中SQL语句结束符相冲突,需要使用 DELIMITER改变存储过程的结束符。...在存储过程中,定义处理程序,捕获sqlstate_value值,当遇到sqlstate_value值为23000时,执行EXIT操 作,并且将@proc_value的值设置为-1。...'23000' ; # 捕获sqlstate_value值,当遇到sqlstate_value值为23000时,执行EXIT操作,并且将@proc_value的值设置为-1 DECLARE EXIT
领取专属 10元无门槛券
手把手带您无忧上云