位置: 编程技术 - 正文

MySQL 5.6 中 TIMESTAMP有那些变化

编辑:rootadmin

推荐整理分享MySQL 5.6 中 TIMESTAMP有那些变化,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

在MySQL 5.6.6之前,TIMESTAMP的默认行为:

TIMESTAMP列如果没有明确声明NULL属性,默认为NOT NULL。(而其他数据类型,如果没有显示声明为NOT NULL,则允许NULL值。)设置TIMESTAMP的列值为NULL,会自动存储为当前timestamp。

表中的第一个TIMESTAMP列,如果没有声明NULL属性、DEFAULT或者 ON UPDATE,会自动分配 DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP 属性。

表中第二个TIMESTAMP列,如果没有声明为NULL或者DEFAULT子句,默认自动分配'-- ::′。插入行时没有指明改列的值,该列默认分配'-- ::′,且没有警告。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_dcbcf.png" alt="查看图片" />

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_de.png" alt="查看图片" />

2列TIMESTAMP未声明为NULL的默认行为

从MySQL5.6.6开始这种默认设置的方法被废弃了。在MySQL启动时会出现以下警告:

关闭警告,在my.cnf中加入

重启MySQL后错误消失,这时TIMESTAMP的行为如下:

TIMESTAMP如果没有显示声明NOT NULL,是允许NULL值的,可以直接设置改列为NULL,而没有默认填充行为。

TIMESTAMP不会默认分配DEFAULT CURRENT_TIMESTAMP 和 ON UPDATE CURRENT_TIMESTAMP属性。

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_df1c6e.png" alt="查看图片" />

MySQL5.6-INNODB-timestampTIMESTAMP 不设置是否为NULL

声明为NOT NULL且没有默认子句的TIMESTAMP列是没有默认值的。往数据表中插入列,又没有给TIMESTAMP列赋值时,如果是严格SQL模式,会抛出一个错误,如果严格SQL模式没有启用,该列会赋值为'-- ::′,同时出现一个警告。(这和MySQL处理其他时间类型数据一样,如DATETIME)

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_dc.png" alt="查看图片" />

TIMESTAMP 默认设置为NOT NULL

MySQL 5.6 中 TIMESTAMP有那些变化

Note:

以上内容和存储引擎选择无关。

MySQL从5.5升级到5.6,TIMESTAMP的变化

前言

前段时间,系统MySQL从5.5升级到了5.6,系统出现了大量的异常。大部分异常引起原因是由于TIMESTAMP的行为发生了变化。

TIMESTAMP在MySQL5.5中的行为

第一个未设置默认值的TIMESTAMP NOT NULL字段隐式默认值:

CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP 后面未设置默认值的TIMESTAMP NOT NULL字段隐式默认值:

-- :: TIMESTAMP NOT NULL字段插入NULL时,会使用隐式默认值:

CURRENT_TIMESTAMP 不支持多个CURRENT_TIMESTAMP 默认值

TIMESTAMP在MySQL5.6中的行为

支持多个CURRENT_TIMESTAMP 默认值 可以兼容5.5的行为,支持隐性默认值

explicit_defaults_for_timestamp=0 我测试安装的MySQL5.6默认使用这个参数,启动时,服务器会给出一个警告。

[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use ?explicit_defaults_for_timestamp server option (see documentation for more details).

可以去掉隐性默认值

explicit_defaults_for_timestamp=1

总结

MySQL5.5中TIMESTAMP行为是比较诡异的,会造成一些隐含的问题,比如程序中传入了NULL值 MySQL5.6中可以将TIMESTAMP的行为变得正常,但会存在兼容问题 explicit_defaults_for_timestamp参数未来会消失 我们不要过度依赖数据库的特性,这些特性会给应用程序造成掣肘

MySQL 5.6 中的 TIMESTAMP 和 explicit_defaults_for_timestamp 参数 安装MySQL时,有warning:[root@localhostmysql]#scripts/mysql_install_db--user=mysqlInstallingMySQLsystemtables...--::[Warning]TIMESTAMPwithimplicitDEFAULTvalueisdeprecated.Pleaseuse-

Mysql学习心得之插入、更新、删除记录 下面通过图文并茂的方式给大家详解Mysql学习心得之插入、更新、删除记录。插入记录Insert[]into]tb1_name[(col_name,…..)]自动编号的字段,可以用valuesdefaultDe

详解MySQL中的存取权限 看到很多网友提出关于MySQL登录不上服务器的问题,包括有的是在PHP中调用MySQL时发生的不能登录MySQL数据库服务器的问题,以为是PHP出了问题。其实是My

标签: MySQL 5.6 中 TIMESTAMP有那些变化

本文链接地址:https://www.jiuchutong.com/biancheng/347965.html 转载请保留说明!

上一篇:MYSQL 创建函数出错的解决方案(mysql中函数创建与调用示例)

下一篇:Mysql学习心得之插入、更新、删除记录(mysql的心得体会)

  • 固定资产报废收入
  • 要交多少增值税
  • 税法有哪些构成要素及各要素之间有何关系
  • 股东个人为公司付的钱
  • 作废的现金支票怎么处理
  • 设备租赁公司购进设备怎么做账
  • 金蝶软件如何设置单价小数点
  • 公司收到股东的钱现金流量表怎么填
  • 股票收入要交所得税吗
  • 实收资本里的钱怎么做账
  • 车辆保险车船税每年交多少
  • 闲置资金的利息收益要冲减财务费用
  • 变动成本主要包括
  • 医疗机构免征增值税如何申报
  • 建筑企业预缴企业所得税会计分录
  • 在win10系统中,如何限制孩子玩原神游戏
  • 配件进出库账目怎么做
  • 待抵扣进项税期末要结转吗
  • 事业单位研究开题报告
  • 物业公司成本结转方案
  • 股权转让定金怎么退回
  • win11怎么桌面快捷方式
  • 坏账损失税务处理
  • antd-vue-pro
  • 潜水时看到的鱼
  • 来料加工 增值税
  • php修改图片尺寸
  • 企业生产车间发生的直接材料费用属于生产费用
  • 保姆分为哪些级别
  • uniapp h5路由模式
  • 工程款清账的句子发朋友圈
  • 利润表中其他收益是什么
  • 企业提取盈余公积属于什么会计科目
  • 研发失败的费用允许加计扣除吗
  • 土地补偿款有哪些款项
  • 长期待摊费用借方负数什么意思
  • 分组 sql
  • 房地产企业增值税预征率
  • 可供出售金融资产名词解释
  • 个人所得税累计收入怎么算
  • 股东垫付的钱可以作为实收资本吗
  • 公司没有车油费可以报销吗
  • 来料加工的账务处理新收入准则
  • 坏账损失的定义
  • 小企业汇算清缴补税会计分录
  • 负数发票要交税吗
  • 自产产品用于职工食堂,确认收入吗
  • 其他债权投资发生减值会影响所有者权益总额吗
  • 利润总额和未分成比例
  • 事业单位收入是再分配吗
  • 投资收益怎么做帐
  • 工业企业营业税率
  • 案例如何分析
  • mysql 5.7.33安装
  • windows更新9%
  • linux怎么用命令
  • ubuntu20.10
  • linux用户管理包括哪几个文件
  • 字符集 linux
  • linux安装视频教程
  • Win10 Mobile build 14393.189安装与上手体验视频
  • WINDOWS系统还原主要作用
  • windows如何禁用程序
  • netddeclnt.exe - netddeclnt是什么进程 有什么用
  • win7旗舰版磁盘清理
  • 电脑因故障出现问题而启动
  • win7屏幕调节不见了
  • perl 字符串处理
  • 可以查杀病毒的软件
  • 批量创建用户
  • html页面头部
  • jquery 使用
  • shell脚本ne
  • 严苛认证
  • javascript教程完整版
  • 出口退税申报时间是每月15号吗
  • 土地增值税可否免税
  • 2024年深圳房价
  • 企业所得税的计算,收入是含税还是不含税
  • 广东广州税务局电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设