SQL_MODE为严格模式下的数据安全专题报告
admin
2023-05-27 15:01:51
0
专题描述详细描述SQL_MODE为严格模式下可能出现的数据错误风险。
问题提出1日期默认'0000-00-00 00:00:00'的,查询时会直接报错。
Caused by: java.sql.SQLException: Value '0000-00-00 00:00:00' can not be represented as java.sql.Timestamp
URL需添加如下参数:zeroDateTimeBehavior=convertToNull。
2OMS数据库因UAT环境和性能测试环境的参数配置不同,导致性能测试环境下应用SQL执行报错,相关参数为STRICT_TRANS_TABLES与explicit_defaults_for_timestamp。
数据风险1整型类型数据值截断风险

重点关注 TINYINT类型

,其他整数类型上线初期溢出概率低。

以“`payment_display_mode` tinyint(4) 

DEFAULT NULL COMMENT '付款到期日显示方式: 

11-最晚汇款日 12-到期日',” 为例。

示例:在非严格模式下,应用程序为 

字段 payment_display_mode 设置一个值 

小于-128 或大于127 ,

则超过部分会被截断(超过-128,则存储为-128,例如 -200 会默认变成 -128;超过127,则存储为127),例如 300 会默认变成127。

2浮点类型截断

以“`longitude` DECIMAL(19,5) NULL

 DEFAULT '0.00000' COMMENT '经度坐标'” 

为例。


示例:在非严格模式下,应用程序为 

字段 longitude 设置一个值 

超过 5位小数或者整数超过14位,

则超过部分会被截断。

3字符串类型风险

以“`MODIFIER_USER` VARCHAR(30) NUL

L DEFAULT NULL COMMENT '更新者用户账号',”

 为例。


示例:在非严格模式下,

应用程序为 字段 MODIFIER_USER 

设置一个值 超过 30个字符,则超过部分会被截断。

4时间类型风险由于JAVA代码认为0000-00-00 00:00:00时间是非法的时间,JDBC中提供参数控制对它的处理, 故可通过添加zeroDateTimeBehavior=convertToNull使其转化为null。 

连接字符串示例: 
jdbc:mysql://10.202.198.201:3319/oms6?useUnicode=true&characterEncoding=UTF8&zeroDateTimeBehavior=convertToNull 
5NOT NULL类型风险

非严格模式下,不给字段定义约束

NOT NULL字段赋值 或 给其一个NULL值,

在无定义约束无默认值的情况下:数据值类型的

字段值默认为0,字符串类型的字段值默认为空字符串''。从SQL语句和存储过程处理分析,多数情况下都兼容处理了,但依然请研发团队谨慎评估。

问题原因数据库SQL_MODE设置为严格模式。
解决方案1建议DBA团队设置SQL_MODE为严格模式,运行系统进行测试,将根据报错定位存在的数据隐患,修改程序。
2设置服务器SQL_MODE为严格模式。
知识点1

数据库SQL_MODE设置为严格模式将出现问题分为以下几类

:1、日期默认'0000-00-00 00:00:00'的;查询时会直接报错,

2、字段类型设置为NOT NULL时,插入NULL值将报错;

3、当插入超出数值字段类型范围的值时,直接报错;

2STRICT_TRANS_TABLES释义:

官方文档链接:

http://dev.mysql.com/doc/refman/5.6/en/sql-mode.html#sql-mode-strict

官方文档解释:For transactional tables, an error occurs for invalid or missing values in a data-change statement when either STRICT_ALL_TABLES or STRICT_TRANS_TABLES is enabled. The statement is aborted and rolled back.
使用该参数的主要目的还是使得数据库面对错误的数据和操作时倾向于报错,而不是给出警告。便于提早发现问题,与规范对数据库的操作。
3

数据库SQL_MODE设置为非严格模式时,系统上述情况倾向于警告

。插入超过数值类型范围字段值时系统取最大值插入,

插入字符类型字段值超过长度范围时会截断。


相关内容

热门资讯

湖南石门强降雨搜救持续:村民守... 澎湃新闻记者 廖艳 实习生 林霄自5月17日7时起,湖南常德石门县遭遇极端强降雨天气,瞬时雨量大、致...
美新远程空空导弹初露真容,能缓... 澎湃新闻特约撰稿 王若鸿近日,美国一位航空摄影师拍摄到几架从佛罗里达州埃格林空军基地起飞的美国海军测...
官方通报福建漳州“泡药杨梅”事... 【大河财立方消息】 5月20日晚,福建漳州市食品安全委员会办公室通报:5月15日,媒体报道反映漳州市...
山河湖海,算算生态环境的“三本... 【大河财立方 记者 程帅星 北京报道】 5月20日下午,国务院新闻办公室举行2026年“新征程上的奋...
官方通报“儿童乳膏涉嫌非法添加... 【大河财立方消息】针对今年3月媒体反映广西十安生物科技有限公司生产的“消字号”产品涉嫌非法添加问题,...
山西通报“明长城被露天煤矿长期... 5月20日,山西宁武县委宣传部发布情况通报:近日,有媒体报道神达朝凯煤业相关问题。宁武县委、县政府高...
国务院被掏空,美国外交陷入“空... ◆在美国国务卿鲁比奥的主导下,国务院正全面围绕特朗普的核心议程进行改革。(图源:美联社)文/方晨宇编...
美军“尼米兹”号航母进入加勒比... 新华社华盛顿5月20日电(记者黄强 徐剑梅)美军南方司令部20日在社交媒体发布消息说,美军“尼米兹”...
28个暴雨红色预警信号生效中,... 20日晚,粤西到珠三角南部一带强降水仍在持续,暖湿气流源源不断补充,导致新生成的强降雨云团不断在同一...
中构建筑取得钢结构厂房用可伸缩... 国家知识产权局信息显示,中构建筑有限公司取得一项名为“一种钢结构厂房用可伸缩式抗风支撑杆”的专利,授...