数据库日期类型
❶ 数据库中日期型数据如何查询
我的习惯是先转化为实数,如许就没有次序、分隔符等问题。ADO+Access2K中可行,其它引擎未知。
❷ 数据库datetime是什么类型
datetime类型:可用于需要同时包含日期和时间信息的值。
datetime:Mysql 以 'YYYY-MM-DD HH:mm:ss'格式检索与显示 DATETIME 类型。
DateTime日期和时间部分,可以表示1753年1月1日00:00:00.000到9999年12月31日23:59:59.997之间的日期范围,精确到3.33ms,它需要8字节的存储空间,其中前4字节用于存储1900年1月1日之前或之后的天数。该值分为正数和负数,正数表示此日期之后的天数,负数表示此日期之前的天数;最后4个字节用于存储从零开始指定的时间之后的毫秒数。
(2)数据库日期类型扩展阅读
在MySQL中创建表时,
通过类型介绍,可以方便地选择正确的数据类型。然而,选择datetime或timestamp戳可能有点困难。这两种日期时间类型各有优点:datetime的日期范围比较大;timestamp的存储空间比较小,只有日期时间的一半。
此外,timestamp类型的列还有一个特性:默认情况下,在插入和更新数据时,timestamp列将自动填充/更新为当前的(CURRENT_TIMESTAMP)的意思是如果你不在乎,MySQL会帮你处理的。
❸ 数据库的日期类型
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 )毫秒数所代表的每天的时间。精确度为百分之三秒(等于 3.33 毫秒或 0.00333 秒)。如下表所示,把值调整到 .000 、 .003 、或 .007 秒的增量。
3.SQL 如下:
查询中,我们常常需要搜索指定日期范围内的数据,比如返回 1998-01-01 当天内的数据,你可能会这样写:
Date >= '1998-01-01 00:00:00.000' and date <= '1998-01-01 23:59:59.999'
根据上面的调整规则,其实这句语句的实际搜索范围为:
date >= '1998-01-01 00:00:00.000' and date <= '1998-01-02 00:00:00.000' 你会看到这包括了 1998-01-02 的数据,所以最好的正确的搜索语句为:
date >= '1998-01-01 00:00:00.000' and date < '1998-01-02 00:00:00.000'
4. smalldatetime 数据类型存储日期和每天的时间,但精确度低于 datetime 。 SQL Server 将 smalldatetime 的值存储为两个 2 字节的整数。第一个 2 字节存储 1900-1-1 后的天数。另外一个 2 字节存储午夜后的分钟数。日期范围从 1900-1-1 到 2079-6-6 ,时间精确到分钟。 29.998 秒或更低的 smalldatetime 值向下舍入为最接近的分钟, 29.999 秒或更高的 smalldatetime 值向上舍入为最接近的分钟。
--returns time as 12:35
SELECT CAST ( '2000-05-08 12:35:29.998' AS smalldatetime )
GO
--returns time as 12:36
SELECT CAST ( '2000-05-08 12:35:29.999' AS smalldatetime )
GO4.
❹ 数据库的日期型数据应该用什么类型接受
1、如果数据库中存储时间的数据类型为datetime,那就避免在后台代码(*.aspx.cs)中转化时间格式,将格式转化的任务放到界面代码(*.aspx)上。
无论获取的时间是什么格式的,在后台不要对这个时间的值进行任何操作(比如赋值等,否则系统会将时间隐式转换),而是直接在界面代码(*.aspx)用DataBinder、Eval等方法来直接进行格式化:
后台关键代码:
<span style="white-space:pre"> </span>DataTable dt = new NewsManager().SelectById(newsid); //这里得到的dt为从直接数据库中查询到的数据
<span style="white-space:pre"> </span> repNews.DataSource =dt;
repNews.DataBind();
前台关键代码:
<span style="white-space:pre"> </span><asp:Repeater ID="repNews" runat="server">
<ItemTemplate>
<p class="con_time">
发布时间:
<%# DataBinder.Eval(Container.DataItem,"createTime","{0:yyyy-MM-dd HH:mm:ss}") %> <%--此处createTime为上面dt中的字段名--%>
</p>
</ItemTemplate>
</asp:Repeater>
❺ 在SQL-Server中关于日期的数据类型有哪些
有datetime和smalldatetime两种格式的日期时间数据类型,如下:
1、datetime
数据库内部用两个4字节的整数存储datetime数据类型的值。
第一个4字节存储基础日期(即1900-1-1, base date)之前或之后的日期。
日期范围为1753-1-1至9999-12-31。当日期为1900-1-1时值为0,之前的日期是负数;之后日期是正数,另外一个4字节存储以午夜后三又三分之一(10/3)毫秒数所代表的每天的时间。
2、smalldatetime
smalldatetime数据类型存储日期和每天的时间,但精确度低于datetime。
SQL Server将smalldatetime的值存储为两个2字节的整数。
第一个2字节存储1900-1-1后的天数,另外一个2字节存储午夜后的分钟数。
日期范围从1900-1-1到2079-6-6,时间精确到分钟,29.998秒或更低的smalldatetime值向下舍入为最接近的分钟,29.999秒或更高的smalldatetime值向上舍入为最接近的分钟。
--returns time as 12:35
SELECT CAST('2000-05-08 12:35:29.998' AS smalldatetime)
GO
--returns time as 12:36
SELECT CAST('2000-05-08 12:35:29.999' AS smalldatetime)
GO
注意:没有单独的日期或时间类型。
❻ 数据库查询日期格式
实体映射类的上传时间属性的getter方法上
添加一个@JsonFormat(pattern="yyyy-MM-dd",timezone="GMT+08")注解
类似下面这样:
java">{
@DateTimeFormat(pattern="yyyy-MM-dd")
privateDateuploadTime;
@JsonFormat(pattern="yyyy-MM-dd",timezone="GMT+08")
publicDategetUploadTime(){
returnuploadTime;
}
publicvoidsetUploadTime(DateuploadTime){
this.uploadTime=uploadTime;
}
}
❼ 数据库日期 用日期类型还是VARCHAR
建议用定长的类型,日期类型肯定比varchar类型的查找等操作的性能要高,要不可以用int类型保存日间戳,这样更好,谦容性也好
❽ sql数据库中的时间类型
满意答案。9级2010-11-29使用nvarchar对于前期的实现比较容易,但性能及后期使用及后期需求开发比较困难
如按时间排序,数据库类型校验,根据时间段查询,根据时间的分组统计等等方面造成的影响比较大
追问:
如果用datetime
我的MyEclipse用Hibernate转换时是timestamp类型的
在用模糊查询查时间时有点纠结啊
老是报不能转换的错误
回答:
用hibernate啊
那你在配置文件注入类型不用时间戳
改成这个试试java.util.Date
补充:
hibernate项目好几年没做过了
原来在数据库时间建模和操纵时习惯用java.sql.Timestamp与数据库中DateTime对应,但业务流通层,模型里还是用java.util.Date
因为这些时间直接的转换都是一样的方便,而且这样做逻辑理解上比较直观
记忆中是没有出现过错误,Timestamp在现在使用数据源时经常使用
追问:
知道用date类型的哇
但是hibernate自动生成的就是timestamp类型
不改配置文件
就用timestamp怎么做啊?总不能每次生成就改一次配置文件吧.....
追问:
还有我做的是模糊查询
在form里面时间又是string类型的
转换有点麻烦
回答:
你在createSQLQuery方法后面在使用
addScalar方法传入你datetime的实体对应名和hibernate类型试一下吧
补充:
这个的确比较麻烦,你可以写个公共转换方法进行转换
就是字符串根据你的时间格式进行取出时间long
然后转换就可以了
大概这样子
SimpleDateFormat
simpleDateFormat
=
new
SimpleDateFormat();
❾ 数据库中有哪几种date类型的格式
日期格式有还几种,有比较精确一点的时间,也初象一点的,一般有,拿2006年5月12号为例来说吧,它可以为
2006-05-12 11:06:08
2006-05-12
20060512110608
20060512
2006/05/12
05-12-2006