0

0

MySql与Java的时间类型

php中文网

php中文网

发布时间:2016-06-07 15:34:34

|

1248人浏览过

|

来源于php中文网

原创

MySql与Java的时间类型 MySql的时间类型有Java中与之对应的时间类型 datejava.sql.Date Datetimejava.sql.Timestamp Timestampjava.sql.Timestamp Timejava.sql.Time Yearjava.sql.Date 对其进行分析 参考MySql的reference manual Date: A date. The support

MySql与Java的时间类型

MySql的时间类型有          Java中与之对应的时间类型
date                                           java.sql.Date

datetime                                    java.sql.timestamp

Timestamp                                  java.sql.Timestamp

Time                                          java.sql.Time

Year                                           java.sql.Date

 

立即学习Java免费学习笔记(深入)”;

 

立即学习Java免费学习笔记(深入)”;

对其进行分析
参考MySql 的reference manual

Date:
A date. The supported range is '1000-01-01' to '9999-12-31'. MySQL displays DATE values in 'YYYY-MM-DD' format, but allows you to assign values to DATE columns using either strings or numbers. 

只记录日期信息,表示范围为1000-01-01 至 9999-12-31。

MySql 按照YYYY-MM-DD 的方式进行该类字段的显示。添加该类字段数据,即可以使用字符串类型,也可以使用数字类型

 

立即学习Java免费学习笔记(深入)”;

由于Date类型的字段只记录日期信息,所以如果添加的数据中包含了时间信息,该时间信息将会自动被截断。

如果要保存时间信息,可以考虑使用DateTime类型。

经过测试,发现如下2种方式可以对Date类型字段进行填充:

按字符串:

insert into time_table(CreateDate) values(‘2007-04-09’)

按数字:
insert into time_table(CreateDate) values(20070409)

 

立即学习Java免费学习笔记(深入)”;

获取可以用java.sql.Date类型获取

代码为:

Date dtDate =rsBuffer.getDate("CreateDate");

 

立即学习Java免费学习笔记(深入)”;

测试代码如下:(其中,IDBFace 是自己基于JDBC封装的一个简单类, 接受Sql对数据库进行操作)
public void testDate()throws SQLException

{

       IDBFace DBFace =DBFactory.createMySqlFace();

       DBFace.connect();

       //清空表

       String strDelete ="delete from time_table";

       DBFace.update(strDelete);

       //添加

             

       String strInsert ="insert into time_table(CreateDate) values(20070409)";

       DBFace.update(strInsert);

             

             

       //获取

       String strSelect ="select * from time_table";

       ResultSet rsBuffer =DBFace.select(strSelect);

       while(rsBuffer.next())

       {

              Date dtDate =rsBuffer.getDate("CreateDate");

              System.out.println(dtDate.toString());

       }

       DBFace.close();

}

执行结果: 2007-04-09

 

DateTime
A date and time combination. The supported range is '1000-01-01 00:00:00' to '9999-12-31 23:59:59'. MySQL displays DATETIME values in 'YYYY-MM-DD HH:MM:SS' format, but allows you to assign values to DATETIME columns using either strings or numbers.

DateTime 与Date最主要的区别在于:DateTime 可以记录日期和时间信息。而Date只记录日期信息。表示范围为: 1000-01-01 00:00:00 至 9999-12-31 23:59:59 MySql的按照YYYY-MM-DD HH:MM:SS对数据进行格式化,允许以字符串和数字的方式提交。

 

立即学习Java免费学习笔记(深入)”;

例如以数字的方式进行提交:
insert into time_table(CreateDate) values(20070409132013)

 

立即学习Java免费学习笔记(深入)”;

获取该类型的数据可以使用:java.sql.Timestamp类型

代码如下:
public void testDateTime() throws SQLException

{

       IDBFace DBFace =DBFactory.createMySqlFace();

DBFace.connect();

       //清空表

       String strDelete ="delete from time_table";

       DBFace.update(strDelete);

       //添加

             

       String strInsert ="insert into time_table(CreateDateTime) values(20070409132013)";

       DBFace.update(strInsert);

       //获取

       String strSelect ="select * from time_table";

       ResultSet rsBuffer =DBFace.select(strSelect);

       while(rsBuffer.next())

       {

              Timestamp tsBuffer =rsBuffer.getTimestamp("CreateDateTime");

              System.out.println(tsBuffer.toString());

       }

       DBFace.close();

}

执行结果: 2007-04-09 13:20:13.0

TimeStamp
A timestamp. The range is '1970-01-01 00:00:00' to partway through the year 2037. A TIMESTAMP column is useful for recording the date and time of an INSERT or UPDATE operation. The firstTIMESTAMP column in a table is automatically set to the date and time of the most recent operation if you don't assign it a value yourself. You can also set any TIMESTAMP column to the current date and time by assigning it a NULL value.

与DateTime类型非常相似

范围为1970-01-01 –2037年,精度为1秒/

如果在Sql中未对Timestamp类型的列赋值,该列将被构造成当前时间。

提交NULL值也会使该列以当前时间录入。

动力先锋仿阿里巴巴B2B电子商务系统
动力先锋仿阿里巴巴B2B电子商务系统

前台功能介绍:1、网页首页显示有高级会员推荐,精品推荐,商业机会分类列表,最新供求信息,网站动态,推荐企业,行业动态等;2、商业机会栏目功能有:二级分类,已经带有详细分类的数据库,后台可以更改增加操作,并可以推荐公司,栏目分为分类显示信息,最新的采购、供应、合作和代理信息,搜索时同样按分类,信息,时间,交易类型等搜索;3、展厅展品栏目功能:二级分类,已经带有详细分类的数据库,后台可以更改增加操作,

下载

如果时间提交错误,该列将被填入0.

Timestamp比DateTime 类型所需的存储空间更小,只需要4个字节,而DateTime需要8个字节。

但是有一点需要特别注意。Timestamp只能表示时间范围为1970 -2037.

使用Timestamp一定要确保提交的时间数据一定不会超过这个范围。

代码与DateTime类是,而且我不喜欢用,所以略掉了。
Time:

A time. The range is '-838:59:59' to '838:59:59'. MySQL displays TIME values in 'HH:MM:SS' format, but allows you to assign values to TIME columns using either strings or numbers.

 

Time只记录时间信息,不包含日期信息。

范围为-838:59:59 到 838:59:59, MySql 以HH:MM:SS格式化该数据,允许输入为字符串或者数字。

代码:
public void testTime() throws SQLException

       {

              IDBFace DBFace =DBFactory.createMySqlFace();

              DBFace.connect();

              //清空表

              String strDelete ="delete from time_table";

              DBFace.update(strDelete);

              //添加

             

              String strInsert ="insert into time_table(CreateTime) values(131211)";

              DBFace.update(strInsert);

              //获取

              String strSelect ="select * from time_table";

              ResultSet rsBuffer =DBFace.select(strSelect);

              while(rsBuffer.next())

              {

                     Time tmBuffer =rsBuffer.getTime("CreateTime");

                     System.out.println(tmBuffer.toString());

              }

              DBFace.close();

       }

执行结果: 13:12:11

Year

A year in two-digit or four-digit format. The default is four-digit format. In four-digit format, the allowable values are 1901 to 2155, and 0000. In two-digit format, the allowable values are 70 to 69, representing years from 1970 to 2069. MySQL displays YEAR values in YYYY format, but allows you to assign values to YEAR columns using either strings or numbers. The YEAR type is unavailable prior to MySQL 3.22.

 

立即学习Java免费学习笔记(深入)”;

Year可以有2种表示方式,4位的和2位的。

默认情况是4位。其范围为1901-2155

2位的表述法只记录后2位 。其范围为1970-2069

允许以字符串或者数字的方式插入。

 

立即学习Java免费学习笔记(深入)”;

代码:
       public void testYear() throws SQLException

       {

              IDBFace DBFace =DBFactory.createMySqlFace();

              DBFace.connect();

              //清空表

              String strDelete ="delete from time_table";

              DBFace.update(strDelete);

              //添加

             

              String strInsert ="insert into time_table(CreateYear) values(2007)";

              DBFace.update(strInsert);

              //获取

              String strSelect ="select * from time_table";

              ResultSet rsBuffer =DBFace.select(strSelect);

              while(rsBuffer.next())

              {

                     Date dtBuffer =rsBuffer.getDate("CreateYear");

                     System.out.println(dtBuffer.getYear()+1900);

              }

              DBFace.close();

       }

执行结果:2007

需要说明的是:

Date.getYear()方法返回至1900年起经过了多少年。所以为了显示正确的时间,必须加上1900.

该方法已经被废弃。

 

立即学习Java免费学习笔记(深入)”;

另外。

有一种方法是:不使用上述任何一种类型来记录时间。

而是以char(或vchar)的方式来记录时间。

这样做在插入数据和显示记录的时候固然不用进行任何转换而比较方便。

但是要承担2个重要的缺陷。

(1)    要单独开发方法验证时间数据的合法性。例如ajidjieoa字符串不是一个时间信息,但仍然可以正常插入。

(2)    如果系统需将时间范围做为条件进行记录检索。这也会是一个*烦。用字符串记录时间将无法使用MySql为时间提供的API.对时间范围检索的代码可能与数据库剥离。这样对性能必然造成影响。例如,要从100万条数据中查询时间范围为1992-3-12 –1992-3-13日的区区100条数据,你可能不得不将100万条数据都查出来,再开发新的方法进行过滤。

 

立即学习Java免费学习笔记(深入)”;

 

立即学习Java免费学习笔记(深入)”;

另外,MySql到4.1时间精度貌若只到秒。

要记录更细的时间粒度。可以考虑构造DateTime.

记录DateTime.trick().

这只是一个想法,有没有额外的问题尚未证明。/

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

7

2026.02.05

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

8

2026.02.05

控制反转和依赖注入区别
控制反转和依赖注入区别

本专题整合了控制反转和依赖注入区别、解释、实现方法相关内容。阅读专题下面的文章了解更多详细教程。

11

2026.02.05

钉钉脑图插图教程合集
钉钉脑图插图教程合集

本专题整合了钉钉脑图怎么插入图片、钉钉脑图怎么用相关教程,阅读专题下面的文章了解更多详细内容。

24

2026.02.05

python截取字符串方法汇总
python截取字符串方法汇总

本专题整合了python截取字符串方法相关合集,阅读专题下面的文章了解更多详细内容。

2

2026.02.05

Java截取字符串方法合集
Java截取字符串方法合集

本专题整合了Java截取字符串方法汇总,阅读专题下面的文章了解更多详细操作教程。

1

2026.02.05

java 抽象方法
java 抽象方法

本专题整合了java抽象方法定义、作用教程等内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.05

Eclipse创建jsp文件教程合集
Eclipse创建jsp文件教程合集

本专题整合了Eclipse创建jsp文件、创建jsp项目等等内容,阅读专题下面的文章了解更多详细教程。

26

2026.02.05

java 字符串转数字
java 字符串转数字

本专题整合了java如何字符串转数字相关内容,阅读专题下面的文章了解更多详细教程。

4

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.1万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 823人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号