- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL Mode简介
在Mysql中,sql mode可以用来解决以下问题
(1).通过设置不同的sql mode,可以在不同的严格程度对数据进行校验.有效地保证了数据准确性.
(2).通过设置sql mode为ANSI模式,来保证大多数SQL符合标准SQL的语法,这样在不同数据库之间迁移时,不需要对业务 修改太多.
查询默认的sql mode(sql mode参数)有:real_as_float,pipes_as_concat,ansi_quotes,gnore_space和ANSI。在这些模式下可以插入超过字段定义长度的数据,或是在字段中没有定义的元素数据(如,enum)。不过在插入后会有一个warning(可以用 show warnings来查看)。
可以通过设置sql mode为STRICT_TRANS_TABLES(严格模式)来实现数据的严格校检,使错误数据不能插入,从而保证数据准确性。
TRADITIONAL模式也属于严格模式,同样可以实现严格校检,使错误数据不能插入,从而保证数据准确性。
SQL中的枚举
ENUM简介
ENUM是一个字符串对象,其值来自表创建时在列规定中显式枚举的一列值。
在某些情况下,ENUM值也可以为空字符串()或NULL:
如果你将一个非法值插入ENUM(也就是说,允许的值列之外的字符串),将插入空字符串以作为特殊错误值。该字符串与“普通”空字符串不同,该字符串有数值值0。
每个枚举值有一个索引:
来自列规定的允许的值列中的值从1开始编号。
例如: browsertype enum(ie,firefox,360browser),
该枚举类型定义中枚举值ie,firefox,360browser都是有索引的,’ie’ = 1, firefox = 2,
360browser=3所以当给该列中插入’ie’枚举值时,可以通过如下语句进行查询;
select * from test where browsertype=1;
空字符串错误值的索引值是0。这说明你可以使用下面的SELECT语句来找出分配了非法ENUM值的行:
select * from test where browsertype=0;
严格模式
查看MySQL的默认的模式:
select @@sql_mode;
mysql select @@sql_mode;
+----------------------------------------------------------------+
| @@sql_mode |
+----------------------------------------------------------------+
| STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+----------------------------------------------------------------+
解释:
NO_AUTO_CREATE_USER: 不允许在该模式下自动创建用户
在严格模式下验证严格模式的语法要求:(以枚举类型举例)
建表语句
mysql create table test(
- id int not null auto_increment primary key,
- browsertype enum(ie,firefox,360browser),
- version int
- );
插入数据
insert into test(browsertype) values(ie);
查询数据
select * from test;
+----+-------------+---------+
| id | browsertype | version |
+----+-------------+---------+
| 1 | ie | NULL |
+----+-------------+---------+
给第二列插入非枚举值
insert into test(browsertype) values(maxthon);
在严格模式下抛出如下异常:
ERROR 1265 (01000): Data truncated for column browsertype at row 1
给第二列插入错误的数据类型值
正确的数据类型:
insert into test(browsertype,version) values(firefox,2);
非法的
您可能关注的文档
- 日成RCCN端子系列要点.pdf
- 201504哈锅CFB锅炉节能降耗和超低排放一体化技术.pptx
- 团 康 游 戏(完整版).doc
- [冷知识]吃货智慧!!!!!!!!.doc
- 注射用雷贝拉唑钠质量研究.doc
- 电影讲义汇总概论.doc
- 皮防所工作计划教案.doc
- 初二下学期语文复习资料基础篇.docx
- 水工设计施工详图阶段经验介绍_副本.doc
- 第四章 军队政治工作的内容与原则.doc
- 养老评估师中级行为面试题库及案例分析.docx
- 面试培训督导时考察其课程理解能力的题目.docx
- 税务专员面试中关于增值税政策的常见问题解答.docx
- 2025宁波市医疗保障局局属事业单位宁波市医疗保障基金管理中心招聘事业编制工作人员1人备考试题附答案.docx
- 2025咸宁市汉口银行咸宁嘉鱼支行招聘笔试历年题库附答案解析.docx
- 2025北京人才发展战略研究院招录笔试备考题库附答案.docx
- 2025四川成都市龙泉驿区青台山中学校秋季教师招聘22人笔试试题附答案解析.docx
- 2025台州市银龄讲学计划教师招募13人笔试参考试题附答案解析.docx
- 2025中国铁建公开招聘42人笔试题库附答案.docx
- 2025中智咨询研究院社会招聘笔试参考题库附答案.docx
原创力文档


文档评论(0)