数据库的日期类型字段该如何选择

数据库的日期类型字段该如何选择,第1张

Mysql中经常用来存储日期的数据类型有三种:Date、Datetime、Timestamp。

Date数据类型:用来存储没有时间的日期。Mysql获取和显示这个类型的格式为“YYYY-MM-DD”。支持的时间范围为“1000-00-00”到“9999-12-31”。

Datetime类型:存储既有日期又有时间的数据。存储和显示的格式为 “YYYY-MM-DD HH:MM:SS”。支持的时间范围是“1000-00-00 00:00:00”到“9999-12-31 23:59:59”。

Timestamp类型:也是存储既有日期又有时间的数据。存储和显示的格式跟Datetime一样。支持的时间范围是“1970-01-01 00:00:01”到“2038-01-19 03:14:07”。

所有不符合上面所述格式的数据都会被转换为相应类型的0值。(0000-00-00或者0000-00-00 00:00:00)

可以使用curdate()函数,current_date()函数等

例如:

insert into t1(oid,order_date) values('0010',curdate());

1. 数据类型

MS SQL Server 2005 有 datetime 和 smalldatetime 两种格式的日期时间数据类型。注意:没有单独的日期或时间类型。

2数据库内部用两个 4 字节的整数存储 datetime 数据类型的值。第一个 4 字节存储基础日期(即 1900-1-1, base date )之前或之后的日期。日期范围为 1753-1-1 至 9999-12-31 。当日期为 1900-1-1 时值为 0 ;之前的日期是负数;之后日期是正数。另外一个 4 字节存储以午夜后三又三分之一( 10/3 )毫秒数所代表的每天的时间。精确度为百分之三秒(等于 333 毫秒或 000333 秒)。如下表所示,把值调整到 000 、 003 、或 007 秒的增量。

3SQL 如下:

查询中,我们常常需要搜索指定日期范围内的数据,比如返回 1998-01-01 当天内的数据,你可能会这样写:

Date >= '1998-01-01 00:00:00000' and date <= '1998-01-01 23:59:59999'

根据上面的调整规则,其实这句语句的实际搜索范围为:

date >= '1998-01-01 00:00:00000' and date <= '1998-01-02 00:00:00000' 你会看到这包括了 1998-01-02 的数据,所以最好的正确的搜索语句为:

date >= '1998-01-01 00:00:00000' and date < '1998-01-02 00:00:00000'

4 smalldatetime 数据类型存储日期和每天的时间,但精确度低于 datetime 。 SQL Server 将 smalldatetime 的值存储为两个 2 字节的整数。第一个 2 字节存储 1900-1-1 后的天数。另外一个 2 字节存储午夜后的分钟数。日期范围从 1900-1-1 到 2079-6-6 ,时间精确到分钟。 29998 秒或更低的 smalldatetime 值向下舍入为最接近的分钟, 29999 秒或更高的 smalldatetime 值向上舍入为最接近的分钟。

--returns time as 12:35

SELECT CAST ( '2000-05-08 12:35:29998' AS smalldatetime )

GO

--returns time as 12:36

SELECT CAST ( '2000-05-08 12:35:29999' AS smalldatetime )

GO4

工具/材料:Management Studio。

1、首先在桌面上,点击“Management Studio”图标。

2、之后在该界面中,点击左上角“新建查询”选项。

3、接着在该界面中,输入的sql语句“

create table test3 (id INT NOT NULL,name NVARCHAR(50),datetype DATE, PRIMARY KEY (id));”。

4、然后在该界面中,点击左上方“执行”按钮。

5、最后在该界面中,显示成功创建date类型的数据。

在数据库取出来的时候就转换好

select getdate()

2006-05-12 11:06:08177

我整理了一下SQL Server里面可能经常会用到的日期格式转换方法:

举例如下:

select Convert(varchar(10),getdate(),120)

2006-05-12

select CONVERT(varchar, getdate(), 120 )

2006-05-12 11:06:08

select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','')

20060512110608

select CONVERT(varchar(12) , getdate(), 111 )

2006/05/12

select CONVERT(varchar(12) , getdate(), 112 )

20060512

select CONVERT(varchar(12) , getdate(), 102 )

20060512

其它几种不常用的日期格式转换方法:

select CONVERT(varchar(12) , getdate(), 101 )

0612/2005 select CONVERT(varchar(12) , getdate(), 103 )

12/09/2004

select CONVERT(varchar(12) , getdate(), 104 )

12052006

select CONVERT(varchar(12) , getdate(), 105 )

12-05-2006

select CONVERT(varchar(12) , getdate(), 106 )

12 05 2006

select CONVERT(varchar(12) , getdate(), 107 )

05 12, 2006

select CONVERT(varchar(12) , getdate(), 108 )

11:06:08

select CONVERT(varchar(12) , getdate(), 109 )

0512 2006 1

select CONVERT(varchar(12) , getdate(), 110 )

09-12-2004

select CONVERT(varchar(12) , getdate(), 113 )

12 052006

select CONVERT(varchar(12) , getdate(), 114 )

11:06:08177

解决方案一:

日期前面的符号换为逗号

日期可以用mysql的方法todate

解决方案二:

MySQL 插入数据 date 格式

mysql插入date类型的值

mysql插入date类型的值

解决方案三:

nsert into table (date) values ('to_date('2009-06-08 23:53:17','YYYY-DD-MM HH:MI:SS'),'

解决方案四:

数据库中日期字段设置datetime类型 然后就可以插入对应字符串

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

以上就是关于数据库的日期类型字段该如何选择全部的内容,包括:数据库的日期类型字段该如何选择、mysql数据库怎么存当前时间类型为date的数据、数据库的日期类型等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9762787.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存