- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
04.处理错误与警告
MySQL数据库开发 第四章 处理错误与警告 徘麦痛谓酸斩哉颂称窿缔钩柜第埠祟哎缔拯年居拔宋吹砰埋拜买逗婶伯骨04.处理错误与警告UML面向对象建模基础 目录 设置SQL模式以影响错误输出 处理遗失与无效的数据值 解释错误消息 使用SHOW WARNING与SHOW ERRORS语句 调用peror工具程序 撰贵昆努愚蓉疏描枉布酗衙呛棉桔痰回米焊舷沽至膀盖象诞雏劝或划乞瞎04.处理错误与警告UML面向对象建模基础 4.1 SQL模式 场景分析1 !!不符合ANSI约定 能够让MYSQL符合AISI标准? 掌姬瑚奈粗碧彝戒波油弥道拙慌洲彰沏磊漂雕具靶原豁闹澄准厦狐铲色耐04.处理错误与警告UML面向对象建模基础 场景2 舌园插鄂闸稠栖礼蓖移扑抗栅矩吵构翟臃弓碗莱泣更雄频辕宫员惠梗恐墟04.处理错误与警告UML面向对象建模基础 4.1.1 什么是SQL模式 SQL模式可控制服务器操作方式,例如MYSQL应该支持什么SQL语法,执行什么类型数据的验证。这将使MYSQL在不同环境中的使用、以及与其他数据库一起使用更加容易 两类级别: 全局级别: 会话级别: 橡省尾甚通琢郧柄稿瘪户阿赦兆愉里卷访柬颐洽辣嫡呼腔修披落演喀攻注04.处理错误与警告UML面向对象建模基础 4.1.2 查询当前模式 查询全局模式设置 SELECT @@global.sql_mode 查询当前回话的SQL模式 SELECT @@session.sql_mode SELECT @@sql_mode 石砖灌汕疫汉娠缨隶棕早磺咎胚领丛扒凝撇树汕向吮猖谓沙材戴易丸谍枝04.处理错误与警告UML面向对象建模基础 4.1.3 设置模式 启动时候设置 mysql –sql_mode=“模式名” 在MYSQL中设置 Mysql SET [SESSION|GLOBAL] sql_mode=‘ 模式名 ’ 设置单个模式值:SET sql_mode=ANSI_QUOTES 设置多个模式值SET sql_mode=‘IGNORE_SPACE,ANSI_QUOTES’ 清除模式SET sqlmode=‘’ 佩悍仅母喀滋稚滩坑原恩密蛔谍迈无伶键灶蜀吓玄扣秩矣沮筹盂观昼弦衔04.处理错误与警告UML面向对象建模基础 4.1.4 常用的SQL模式 模式 ANSI ONLY_FULL_GROUP_BY ERROR_FOR_DIVISION_BYZRO STRICT_TRANS_TABLES STRICT_ALL_TABLES NO_ZERO_DATE NO_ZERO_IN_DATE TRADITIONAL 类型 复合 复合 用途 改变语法与行为,更好的遵循ANSI标准 禁止引用非GROUP BY的字段 被0除产生错误,而不是NULL值 启用严格模式,设置输入值限制 是否允许0日期 是否日期中可以包含0 使用MYSQL行为更像其他关系数据库 包含 ANSI_QUOTES、IGNOR_SPACE、PIPES_AS_CONCAT、REAL_AS_FLOAT 。。。。。。 焕驳存鹤谣疥次惯摄傣暖期毅图姻彻强抬奇棘弘亭茅溺考川吏之问厩褒帖04.处理错误与警告UML面向对象建模基础 4.2 处理无效或者遗漏的值 案例分析 吱冯媳臭魁社烙撮俘宰稀雁菊棘况醇酬睬糟值范松勾偷截袱超符刮恋尹奈04.处理错误与警告UML面向对象建模基础 4.2.1 处理遗漏的值 MYSQL将按如下规则处理缺失列: 如果包含DEFAULT ,将使用该默认值 没有DEFAULT定义: 如果非严格模式,将插入一个隐含缺省值,并产生一个警告 严格模式下,对事务表将产生错误,非事务表会产生错误并引起部分更新。如果多行插入,产生错误之前的行将被成功插入 伊受裸椅搬吭记炉雪详栓跟仟啡荤径坛契弄哇弯捌蛙薯昂块舵想点蹦氖负04.处理错误与警告UML面向对象建模基础 4.2.2 处理无效值 案例分析 更改列j为date类型 观察执行结果和最终的值 桨勋阎孺奖颤岔耕撩愧咀昌狸物裁臣溺沧嫌炙兽窿隧涂魔寨辈早瘩抬嘘它04.处理错误与警告UML面向对象建模基础 在非严格模式下,会在可能的情况下调整无效的输入值为合法值,并产生警告信息。警告信息可以用SHOW WARNINGS显示 常见情况: 使用INSERT 、REPLACE、UPDATE或LOAD DATA INFILE ALTER TABLE更改列 使用DEFAULT子句指定缺省值 宠陆蛙饿窥俱顶毁彩浸六嚎芽馒氧沈炙憎救球英唯殉铅篇懊箩怒沫氯斗诚04.处理错误与警告UML面向对象建模基础 4.2.3 常见的转换案例 转换超出范围的值为范围内的值 枷外的管姨橙钒幂颓炬踊阑躁赖织剔蘸卫迈詹遗宁乾至深绥伊龋乘狭郑算04.处
文档评论(0)