文档章节

MySQL datetime数据类型设置当前时间为默认值

varchard
 varchard
发布于 2015/04/26 16:27
字数 420
阅读 209
收藏 8
点赞 0
评论 0

环境:MySQL Sever 5.1 + MySQL命令行工具

问题:MySQL datetime数据类型设置当前时间为默认值

解决:

方法一:

由于MySQL目前字段的默认值不支持函数,所以以create_time datetime default now() 的形式设置默认值是不可能的。代替的方案是使用TIMESTAMP类型代替DATETIME类型。

TIMESTAMP列类型自动地用当前的日期和时间标记INSERT或UPDATE的操作。如果有多个TIMESTAMP列,只有第一个自动更新。

自动更新第一个TIMESTAMP列在下列任何条件下发生:

1.列值没有明确地在一个INSERT或LOAD DATA INFILE语句中指定。

2.列值没有明确地在一个UPDATE语句中指定且另外一些的列改变值。(注意一个UPDATE设置一个列为它已经有的值,这将不引起TIMESTAMP列被更新,因为如果你设置一个列为它当前的值,MySQL为了效率而忽略更改。)

3.你明确地设定TIMESTAMP列为NULL.

4.除第一个以外的TIMESTAMP列也可以设置到当前的日期和时间,只要将列设为NULL,或NOW()。

所以把日期类型 选择成timestamp 允许空就可以了

  1. CREATE TABLE test (   

  2. uname varchar(50) NOT NULL,   

  3. updatetime timestamp NULL DEFAULTCURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP   

  4. ) ENGINE=InnoDB DEFAULT CHARSET=utf8;    

如果要在navicat下操作的话,将字段设置为timestamp,然后默认值写上CURRENT_TIMESTAMP即可

方法二:

在MySQL5.0以上版本中也可以使用trigger来实现此功能。

  1. create table test_time (   

  2.  idint(11),   

  3.  create_time datetime   

  4. );   

  5. delimiter |   

  6. create trigger default_datetime beforeinsert on test_time   

  7.   foreach row   

  8.     if new.create_time is null then   

  9.       set new.create_time = now();   

  10.     end if;|   

  11. delimiter ;

© 著作权归作者所有

共有 人打赏支持
varchard
粉丝 6
博文 48
码字总数 19458
作品 0
程序员
MySQL中 TIMESTAMP类型 和 DATETIME类型 的区别

1、两者的存储方式不一样 TIMESTAMP:把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。 DATETIME:不做任何改变,基本上是原...

学习也休闲 ⋅ 2016/01/20 ⋅ 0

MySQL一些常用的时间函数 current_timestamp()

mysql自带的一些函数功能也是很强大的,这里整理了一下时间方面的 获取当前时间格式串: #获取当前时间戳current_timestamp() yyyy-mm-dd hh:ii:ss now() yyyy-mm-dd hh:ii:sscurdate() yyyy...

big_cat ⋅ 2015/06/24 ⋅ 0

[mysql] timestamp自动更新和初始化

[mysql] timestamp自动更新和初始化 1.概述 在我们设计表的时候,考虑将行数据的创建时间和最后更新时间记录下来是很好的实践。尤其是可能需要做数据同步或者对数据新鲜度有要求的表。举些应...

as007012012 ⋅ 2017/01/13 ⋅ 0

mysql 中怎么设置默认值为系统日期

-- 方法一: 由于MySQL目前字段的默认值不支持函数,所以以create_time datetime default now() 的形式设置默认值是不可能的。代替的方案是使用TIMESTAMP类型代替DATETIME类型。 TIMESTAMP列...

Galy_绿 ⋅ 2016/03/18 ⋅ 0

mysql常用数据类型

mysql常用数据类型 tinyint/smallint/mediumint/int/bigint-->1B/2B/3B/4B/8B float/double-->单精度/双精度浮点型 decimal-->不会产生精度丢失的单精度/双精度浮点型 date-->日期类型 time......

chenruibing ⋅ 2015/06/15 ⋅ 0

MySQL学习笔记--1

1:SQL语言的组成 DDL-主要用于定义数据库,表,视图,索引,触发器等,如DROP,CREATE,ALTER等语句 DML-主要包括对数据库增删改,INSERT,UPDATE,DELETE DQL-主要用于数据的检索,SELECT,...

雨醉风尘 ⋅ 2015/09/14 ⋅ 0

Mysql支持的数据类型

一、数值类型 注: 1. int类型里面默认的数据宽度是11,即int(11) 关于zerofill,在数字位数不够的空间用字符0填充 例如: 2.整数类型有AUTO_INCREMENT的属性 AUTOINCREMENT的值一般从1开始,...

Geekwolf ⋅ 2014/04/08 ⋅ 0

MySQL datetime && timestamp

MySQL datetime && timestamp 转自:http://www.tech-recipes.com/rx/22599/mysql-datetime-vs-timestamp-data-type/ The temporal data types in MySQL can be confusing. Hopefully, thi......

秋风醉了 ⋅ 2014/12/24 ⋅ 0

Mysql基础(一)

#################################################################################### 什么是数据库: DB,DataBase --》数据库 :依照某种数据模型进行组织并存放到存储器的数据集合。 ...

段超超 ⋅ 2017/12/21 ⋅ 0

跟王老师学MySQL:MySQL数据类型常见问题及解答

跟王老师学MySQL:MySQL数据类型常见问题及解答 主讲教师:王少华 QQ群号:483773664 学习内容 整数类型和浮点类型的异同 浮点数类型和定点数类型的异同 char和varchar类型的异同 时间和日期...

imentors ⋅ 2016/07/04 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

CENTOS7防火墙命令记录

安装Firewall命令: yum install firewalld firewalld-config Firewall开启常见端口命令: firewall-cmd --zone=public --add-port=80/tcp --permanent firewall-cmd --zone=public --add-po......

cavion ⋅ 59分钟前 ⋅ 0

【C++】【STL】利用chromo来测量程序运行时间与日志时间打印精确到微秒

直接上代码吧,没啥好说的。头疼。 #include <iostream>#include <string>#include <ctime>#include <sstream>#include <iomanip>#include <thread>#include <chrono>using ......

muqiusangyang ⋅ 今天 ⋅ 0

Mac环境下svn的使用

在Windows环境中,我们一般使用TortoiseSVN来搭建svn环境。在Mac环境下,由于Mac自带了svn的服务器端和客户端功能,所以我们可以在不装任何第三方软件的前提下使用svn功能,不过还需做一下简...

故久呵呵 ⋅ 今天 ⋅ 0

破解公司回应苹果“USB限制模式”:已攻破

本周四,苹果发表声明称 iOS 中加入了一项名为“USB 限制模式”的功能,可以防止 iPhone 在连接其他设备的时候被破解,并且强调这一功能并不是针对 FBI 等执法部门,为的是保护用户数据安全。...

六库科技 ⋅ 今天 ⋅ 0

MyBtais整合Spring Boot整合,TypeHandler对枚举类(enum)处理

概要 问题描述 我想用枚举类来表示用户当前状态,枚举类由 code 和 msg 组成,但我只想把 code 保存到数据库,查询处理,能知道用户当前状态,这应该怎么做呢?在 Spring 整合MyBatis 的时候...

Wenyi_Feng ⋅ 今天 ⋅ 0

synchronized与Lock的区别

# <center>王梦龙的读书笔记第一篇</center> ## <center>-synchronized与Lock的区别</centre> ###一、从使用场景来说 + synchronized 是能够注释代码块、类、方法但是它的加锁是和解锁使用一......

我不想加班 ⋅ 今天 ⋅ 0

VConsole的使用

手机端控制台打印输出,方便bug的排查。 首先需要引入vconsole.min.js 文件,然后在文件中创造实例。就能直接使用了。 var vConsole = new VConsole(); vConsole的文件地址...

大美琴 ⋅ 今天 ⋅ 0

Java NIO之字符集

1 字符集和编解码的概念 首先,解释一下什么是字符集。顾名思义,就是字符的集合。它的初衷是把现实世界的符号映射为计算机可以理解的字节。比如我创造一个字符集,叫做sex字符集,就包含两个...

士别三日 ⋅ 今天 ⋅ 0

Spring Bean基础

1、Bean之间引用 <!--如果Bean配置在同一个XML文件中,使用local引用--><ref bean="someBean"/><!--如果Bean配置在不同的XML文件中,使用ref引用--><ref local="someBean"/> 其实两种......

霍淇滨 ⋅ 今天 ⋅ 0

05、基于Consul+Upsync+Nginx实现动态负载均衡

1、Consul环境搭建 下载consul_0.7.5_linux_amd64.zip到/usr/local/src目录 cd /usr/local/srcwget https://releases.hashicorp.com/consul/0.7.5/consul_0.7.5_linux_amd64.zip 解压consu......

北岩 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部