首页 数据库 mysql教程 MySql与Java的时间类型

MySql与Java的时间类型

Jun 07, 2016 pm 03:34 PM
java mysql 时间 类型

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

 

 

对其进行分析
参考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 的方式进行该类字段的显示。添加该类字段数据,即可以使用字符串类型,也可以使用数字类型

 

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

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

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

按字符串:

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

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

 

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

代码为:

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

 

测试代码如下:(其中,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对数据进行格式化,允许以字符串和数字的方式提交。

 

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

 

获取该类型的数据可以使用: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值也会使该列以当前时间录入。

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

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

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

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

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

A time. The range is <span>'-838:59:59'</span> to <span>'838:59:59'</span>. MySQL displays <span>TIME</span> values in <span>'HH:MM:SS'</span> format, but allows you to assign values to <span>TIME</span> 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 <span>1901</span> to <span>2155</span>, and <span>0000</span>. In two-digit format, the allowable values are <span>70</span> to <span>69</span>, representing years from 1970 to 2069. MySQL displays <span>YEAR</span> values in <span>YYYY</span> format, but allows you to assign values to <span>YEAR</span> columns using either strings or numbers. The <span>YEAR</span> type is unavailable prior to MySQL 3.22.

 

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

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

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

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

 

代码:
       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.

该方法已经被废弃。

 

另外。

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

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

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

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

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

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

 

 

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

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

记录DateTime.trick().

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

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

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

无法以 root 身份登录 mysql 无法以 root 身份登录 mysql Apr 08, 2025 pm 04:54 PM

无法以 root 身份登录 MySQL 的原因主要在于权限问题、配置文件错误、密码不符、socket 文件问题或防火墙拦截。解决方法包括:检查配置文件中 bind-address 参数是否正确配置。查看 root 用户权限是否被修改或删除,并进行重置。验证密码是否准确无误,包括大小写和特殊字符。检查 socket 文件权限设置和路径。检查防火墙是否阻止了 MySQL 服务器的连接。

RDS MySQL 与 Redshift 零 ETL 集成 RDS MySQL 与 Redshift 零 ETL 集成 Apr 08, 2025 pm 07:06 PM

数据集成简化:AmazonRDSMySQL与Redshift的零ETL集成高效的数据集成是数据驱动型组织的核心。传统的ETL(提取、转换、加载)流程复杂且耗时,尤其是在将数据库(例如AmazonRDSMySQL)与数据仓库(例如Redshift)集成时。然而,AWS提供的零ETL集成方案彻底改变了这一现状,为从RDSMySQL到Redshift的数据迁移提供了简化、近乎实时的解决方案。本文将深入探讨RDSMySQL零ETL与Redshift集成,阐述其工作原理以及为数据工程师和开发者带来的优势。

mysql 是否要付费 mysql 是否要付费 Apr 08, 2025 pm 05:36 PM

MySQL 有免费的社区版和收费的企业版。社区版可免费使用和修改,但支持有限,适合稳定性要求不高、技术能力强的应用。企业版提供全面商业支持,适合需要稳定可靠、高性能数据库且愿意为支持买单的应用。选择版本时考虑的因素包括应用关键性、预算和技术技能。没有完美的选项,只有最合适的方案,需根据具体情况谨慎选择。

MySQL 中的查询优化对于提高数据库性能至关重要,尤其是在处理大型数据集时 MySQL 中的查询优化对于提高数据库性能至关重要,尤其是在处理大型数据集时 Apr 08, 2025 pm 07:12 PM

1.使用正确的索引索引通过减少扫描的数据量来加速数据检索select*fromemployeeswherelast_name='smith';如果多次查询表的某一列,则为该列创建索引如果您或您的应用根据条件需要来自多个列的数据,则创建复合索引2.避免选择*仅选择那些需要的列,如果您选择所有不需要的列,这只会消耗更多的服务器内存并导致服务器在高负载或频率时间下变慢例如,您的表包含诸如created_at和updated_at以及时间戳之类的列,然后避免选择*,因为它们在正常情况下不需要低效查询se

mysql用户和数据库的关系 mysql用户和数据库的关系 Apr 08, 2025 pm 07:15 PM

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

mysql 是否更改表锁定表 mysql 是否更改表锁定表 Apr 08, 2025 pm 05:06 PM

MySQL修改表结构时,通常使用元数据锁,可能导致锁表。为了减少锁的影响,可采取以下措施:1. 使用在线DDL保持表可用;2. 分批执行复杂修改;3. 在小表或非高峰期操作;4. 使用PT-OSC工具实现更精细的控制。

mysql 可以在 android 上运行吗 mysql 可以在 android 上运行吗 Apr 08, 2025 pm 05:03 PM

MySQL无法直接在Android上运行,但可以通过以下方法间接实现:使用轻量级数据库SQLite,由Android系统自带,无需单独服务器,资源占用小,非常适合移动设备应用。远程连接MySQL服务器,通过网络连接到远程服务器上的MySQL数据库进行数据读写,但存在网络依赖性强、安全性问题和服务器成本等缺点。

如何针对高负载应用程序优化 MySQL 性能? 如何针对高负载应用程序优化 MySQL 性能? Apr 08, 2025 pm 06:03 PM

MySQL数据库性能优化指南在资源密集型应用中,MySQL数据库扮演着至关重要的角色,负责管理海量事务。然而,随着应用规模的扩大,数据库性能瓶颈往往成为制约因素。本文将探讨一系列行之有效的MySQL性能优化策略,确保您的应用在高负载下依然保持高效响应。我们将结合实际案例,深入讲解索引、查询优化、数据库设计以及缓存等关键技术。1.数据库架构设计优化合理的数据库架构是MySQL性能优化的基石。以下是一些核心原则:选择合适的数据类型选择最小的、符合需求的数据类型,既能节省存储空间,又能提升数据处理速度

See all articles