`
klts
  • 浏览: 41339 次
  • 性别: Icon_minigender_2
  • 来自: 成都
社区版块
存档分类
最新评论
  • klts: 我一直用的jdk1.6.0_13,感觉还可以
    JDK
  • wuyulunbi: 现在jdk什么版本的稳定
    JDK

mysql datetime与timestamp

阅读更多

mysql创建表时间类型的选择:创建表(datetime),更新表(timestamp)。如果你的表中有两个timestamp字段,只要你更新任何非timestamp字段的值,则第一个timestamp列会更新成当前时间,而第二个timestamp列的值不变。

 

MySQL5的日期类型有三种:DATETIME、DATE和TIMESTAMP

DATE用来表示一个不带时分秒的是日期,另外两个都带时分秒。TIMESTAMP还可以精确到毫秒。

共性:他们的格式“不严格”,很自由,一般你认为对的格式都可以正确插入到数据库中

 

一、TIMESTAMP

1、TIMESTAMP列必须有默认值,默认值可以为“0000-00-00 00:00:00”,但不能为null。
2、TIMESTAMP列不可以设置值,只能由数据库自动去修改。
3、一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。因此,一个表中有多个TIMESTAMP 列是没有意义,实际上一个表只设定一个TIMESTAMP列。
4、TIMESTAMP列的默认值是CURRENT_TIMESTAMP常量值。当纪录数据发生变化的时候,TIMESTAMP列会自动将其值设定为CURRENT_TIMESTAMP。
5、TIMESTAMP列创建后的格式是:
`a` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
这个语句含义,a字段的默认值是CURRENT_TIMESTAMP,当纪录更新时候,自动将a字段的值设置为 CURRENT_TIMESTAMP。
6、另外,下面的定义从语法角度是对的,但是没有意义,因为该字段的值不可更改,永远只能为默认值。
`b` timestamp NOT NULL DEFAULT ’0000-00-00 00:00:00′,

二、DATETIME

1、DATETIME列可以设置为多个,默认可为null,可以手动设置其值。
2、DATETIME列不可设定默认值,这是很多人煞费苦心研究的成果,呵呵!
3、DATETIME列可以变相的设定默认值,比如通过触发器、或者在插入数据时候,将DATETIME字段值设置为now(),这样可以做到了,尤其是后者,在程序开发中常常用到。

分享到:
评论

相关推荐

    MySQL中datetime和timestamp的区别及使用详解

    在MySQL数据库中,datetime和timestamp是两种常用的日期和时间数据类型,它们虽然都可以用来存储日期和时间信息,但在使用和处理上存在一些显著的区别。本文将深入探讨这两种数据类型的差异以及如何在实际应用中选择...

    Mysql中的Datetime和Timestamp比较

    MySQL数据库系统中,时间数据类型是用来存储日期和时间值的,其中包括`DATE`、`DATETIME`和`TIMESTAMP`。这些类型在某些方面相似,但在其他方面却有着明显的区别。下面将详细介绍`DATETIME`和`TIMESTAMP`的比较,并...

    spirng-boot 的时间类型(date、datetime、timestamp)的全局配置

    两者的区别在于,DATETIME的范围更广(1000-01-01到9999-12-31),而TIMESTAMP在MySQL 5.6及之后版本支持的范围与DATETIME相同,但在旧版本中范围较小(1970-01-01到2038-01-19)。此外,TIMESTAMP在某些情况下会...

    mysql时间类型对应的java类型1

    4. **TIMESTAMP**:与DATETIME类似,但存储的精度可以更高,可以精确到纳秒。在MySQL中,TIMESTAMP有时区敏感性,而DATETIME是固定的。在Java中,同样使用`java.sql.Timestamp`来表示。 5. **YEAR**:仅存储年份,...

    mysql中datetime类型设置默认值方法

    在MySQL数据库中,datetime类型常用于存储日期和时间的组合数据,如事件的发生时间或记录的创建、修改时间。在设计数据库表结构时,有时我们需要为datetime类型的字段设置默认值,以便在插入新记录时自动填充当前的...

    解决mysql时间戳datatime存储四舍五入问题.docx

    在MySQL数据库中,时间戳(Timestamp)和日期时间(DateTime)是两种常见的日期和时间数据类型,用于存储和处理时间信息。在您的项目中遇到的问题是关于DateTime类型的字段在存储时出现了四舍五入的问题,这通常是...

    MySQL的datetime设置当前时间为默认值[定义].pdf

    MySQL datetime 设置当前时间为默认值 MySQL 中的 datetime 类型字段无法使用函数作为默认值,因此无法使用 `create_time datetime default now()` 的形式设置默认值。代替的方案是使用 TIMESTAMP 类型代替 ...

    关于MySQL 时间类型 datetime、bigint、timestamp,你用哪个?

    ### MySQL时间类型详解:datetime、bigint、timestamp 在MySQL中,根据不同的应用场景和需求,可以选择多种方式来存储日期和时间信息。本篇文章将详细介绍三种常用的时间类型:`datetime`、`bigint` 和 `timestamp`...

    MySQL 5.6 中 TIMESTAMP 的变化分析

    此外,TIMESTAMP类型与时区相关,其存储的是UTC时间,但在查询时会根据服务器的时区进行转换。因此,当涉及跨时区操作时,需要特别注意时区设置和转换。 总之,MySQL 5.6中TIMESTAMP的行为变化是向更清晰的默认规则...

    java与mysql日期类型的问题

    通过java向mysql中插入datetime类型的数据: String sql = "INSERT INTO wp_posts ( post_date )VALUES(?)"; PreparedStatement pstmt = connection.prepareStatement(sql); Timestamp time = new Timestamp...

    mysql 数据类型TIMESTAMP

    在mysql中timestamp数据类型是一个比较特殊的数据类型,他可以自动在你不...因此在MySQL中要记录创建日期还得使用datetime 然后使用NOW() 函数完成! 1: 如果定义时DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TI

    mysql取得datetime类型的数据,后面会跟个.0的实现方法

    在MySQL中,datetime和timestamp是两种常见的日期时间类型。datetime能存储的范围从1000-01-01 00:00:00到9999-12-31 23:59:59,而timestamp在不同版本的MySQL中有所不同,但通常能存储从1970-01-01 00:00:00到2038-...

    debezium-datetime-converter:Debezium自定义转换器用于处理mysql datetime类型的问题

    Debezium自定义转换器用于处理mysql datetime类型的问题 MySQL的 Binlog连接器 德比兹 德比兹图式 日期(2021-01-28) 本地日期(2021-01-28) 整数(18655) 碘化氢时间日期 时间(17:29:04) 期间(PT17H29M4...

    MySQL 5.6 中 TIMESTAMP有那些变化

    MySQL 5.6 版本对 TIMESTAMP 数据类型的处理方式与之前的版本有所不同,这些变化可能会对数据库操作和应用程序的兼容性产生影响。以下是 MySQL 5.6 中 TIMESTAMP 的关键变化: 在 MySQL 5.6.6 之前,TIMESTAMP 的...

    mysql datetime查询异常问题解决

    mysql datetime查询异常 异常:Value ‘0000-00-00 00:00:00’ can not be represented as java.sql.Timestamp (2011-05-25 11:38:40) 描述:非空无默认值的Datetime类型字段,查询时程序报以下错误: Value ...

    datetime时间插入的5种方式

    在编程领域,尤其是在数据库操作中,插入datetime时间是常见的任务。MyBatis作为一个轻量级的持久层框架,为开发者提供了灵活的操作接口。本篇文章将详细介绍在MyBatis中插入datetime时间的五种方法,帮助你更好地...

    MySQL错误TIMESTAMP column with CURRENT_TIMESTAMP的解决方法

    在MySQL数据库中,`TIMESTAMP`数据类型常用于记录时间戳,它允许自动初始化或更新为当前日期和时间。然而,不同版本的MySQL对`TIMESTAMP`列的默认值和自动更新行为有不同的处理方式,这可能导致在不同环境下的兼容性...

Global site tag (gtag.js) - Google Analytics