Mybatis中如何避免MySQL存储Date类型数据时遇到的问题?

2026-04-30 06:592阅读0评论SEO资讯
  • 内容介绍
  • 相关推荐

本文共计917个文字,预计阅读时间需要4分钟。

Mybatis中如何避免MySQL存储Date类型数据时遇到的问题?

场景:将一个时间字符串转换成Date,并存入MySQL。时间字符串会比实际时间早1天,也可能少了13-14小时。MySQL的时区设置为CST(使用语句:show VARIABLES LIKE '%time_zone%'; 查询)。

操作步骤:

1.将时间字符串格式化为Date类型。

2.将转换后的Date存入MySQL数据库。

3.考虑时区差异,确保时间正确。

具体代码示例(以Python和MySQL为例):

pythonimport mysql.connectorfrom datetime import datetime, timedelta

假设time_string为需要转换的时间字符串time_string=2023-04-01 23:59:59

将时间字符串转换为Dateconverted_date=datetime.strptime(time_string, %Y-%m-%d %H:%M:%S)

考虑时区差异if datetime.now() - converted_date > timedelta(days=1): converted_date -=timedelta(days=1)elif datetime.now() - converted_date

连接MySQL数据库db_connection=mysql.connector.connect( host=your_host, user=your_user, password=your_password, database=your_database)cursor=db_connection.cursor()

创建表(如果不存在)cursor.execute( CREATE TABLE IF NOT EXISTS your_table ( id INT AUTO_INCREMENT PRIMARY KEY, date_field DATE ))

插入数据cursor.execute(INSERT INTO your_table (date_field) VALUES (%s), (converted_date.date(),))

提交事务db_connection.commit()

关闭连接cursor.close()db_connection.close()

场景:

把一个时间字符串转成Date,存进Mysql。时间天数会比实际时间少1天,也可能是小时少了13-14小时

Mysql的时区是CST(使用语句:show VARIABLES LIKE '%time_zone%'; 查)

先放总结:

修改方法:

1. 修改数据库时区

2. 在jdbc.url里加后缀 &serverTimezone=GMT%2B8

Mybatis中如何避免MySQL存储Date类型数据时遇到的问题?

3. 代码里设置时区,给SimpleDateFormat.setTimeZone(...)

例外:new Date() 可以直接存为正确时间,其他的不行。比如我试过,把new Date用sdf转个2次,然后就错误了

贴一下测试的一下渣码

// 1.new Date()直接存数据库则是正确的日期 结果:√ 190626,数据库存储正常 // Date now = new Date(); // 2,new Date()用simpleDateFormat转化为字符串再转为Date。结果: × 少1天 190625 // Date now1 = new Date(); // String tempStr = yyMMddFormatter.format(now1); // String tempStrDate = tempStr.split(" ")[0];// 会加上00:00:00 // Date date = yyMMddFormatter.parse(tempStrDate); // 3.配置文件加上&serverTimezone=GMT%2B8,√ 正确 // 4. 设置中国标准时区 UTC+8 结果:√ // SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd"); // 设置时区: 中国标准时 China Standard Time UTC+08:00 使用GMT+8东8区,结果:?使用默认时区setTimeZone(TimeZone.getDefault); // sdf.setTimeZone(TimeZone.getTimeZone("UTC+8")); // System.out.println(sdf.getTimeZone().toString()); // Date date = sdf.parse(liftMaxDt); // System.out.println(sdf.getTimeZone().toString()); // System.out.println(date); // // Date targetDate = new Date(date.getTime()); // System.out.println("------------------"); // System.out.println(targetDate); // 5. 测试毫秒数 new Date(ms);但是要先使用sdf转入参 结果:× 问题就在于SimpleDateFormat会混乱时区 // SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd"); // Date date = sdf.parse(liftMaxDt); // Date targetDate = new Date(date.getTime()); // System.out.println("使用sdf转换date,在new Date(date.getTime())-----------"); // System.out.println(targetDate); // 使用LocalDate.结果: × 还是少一天 DateTimeFormatter df = DateTimeFormatter.ofPattern("yyMMdd"); LocalDate ldt = LocalDate.parse(liftMaxDt, df); System.out.println("String类型的时间转成LocalDateTime:"+ldt); // LocalDate转LocalDateTime LocalDateTime lll = LocalDateTime.of(ldt, LocalTime.of(0,0,0)); ZoneId zone = ZoneId.systemDefault(); Instant instant = lll.atZone(zone).toInstant(); Date targetDate = Date.from(instant); // 将对象里时间属性设置为String,数据库里仍然用Date,用数据库的时间函数转化

最后,还是采用的数据库为timestamp类型,用mysql的时间函数进行转换,保证时间为数据库时间

补充知识:mybatis解决java中的date类型存入oracle数据库之后不显示时分秒

实体类中类型为java.util.Date

private Date update_date;

数据库中对应字段的类型为Date

不显示 时分秒 的情况:

Mapping文件中对应字段的jdbcType为DATE类型

如果显示时分秒的话,只需要将Mapping文件中对应字段的类型改为TIMESTAMP即可.

以上这篇浅谈Mybatis+mysql 存储Date类型的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。

本文共计917个文字,预计阅读时间需要4分钟。

Mybatis中如何避免MySQL存储Date类型数据时遇到的问题?

场景:将一个时间字符串转换成Date,并存入MySQL。时间字符串会比实际时间早1天,也可能少了13-14小时。MySQL的时区设置为CST(使用语句:show VARIABLES LIKE '%time_zone%'; 查询)。

操作步骤:

1.将时间字符串格式化为Date类型。

2.将转换后的Date存入MySQL数据库。

3.考虑时区差异,确保时间正确。

具体代码示例(以Python和MySQL为例):

pythonimport mysql.connectorfrom datetime import datetime, timedelta

假设time_string为需要转换的时间字符串time_string=2023-04-01 23:59:59

将时间字符串转换为Dateconverted_date=datetime.strptime(time_string, %Y-%m-%d %H:%M:%S)

考虑时区差异if datetime.now() - converted_date > timedelta(days=1): converted_date -=timedelta(days=1)elif datetime.now() - converted_date

连接MySQL数据库db_connection=mysql.connector.connect( host=your_host, user=your_user, password=your_password, database=your_database)cursor=db_connection.cursor()

创建表(如果不存在)cursor.execute( CREATE TABLE IF NOT EXISTS your_table ( id INT AUTO_INCREMENT PRIMARY KEY, date_field DATE ))

插入数据cursor.execute(INSERT INTO your_table (date_field) VALUES (%s), (converted_date.date(),))

提交事务db_connection.commit()

关闭连接cursor.close()db_connection.close()

场景:

把一个时间字符串转成Date,存进Mysql。时间天数会比实际时间少1天,也可能是小时少了13-14小时

Mysql的时区是CST(使用语句:show VARIABLES LIKE '%time_zone%'; 查)

先放总结:

修改方法:

1. 修改数据库时区

2. 在jdbc.url里加后缀 &serverTimezone=GMT%2B8

Mybatis中如何避免MySQL存储Date类型数据时遇到的问题?

3. 代码里设置时区,给SimpleDateFormat.setTimeZone(...)

例外:new Date() 可以直接存为正确时间,其他的不行。比如我试过,把new Date用sdf转个2次,然后就错误了

贴一下测试的一下渣码

// 1.new Date()直接存数据库则是正确的日期 结果:√ 190626,数据库存储正常 // Date now = new Date(); // 2,new Date()用simpleDateFormat转化为字符串再转为Date。结果: × 少1天 190625 // Date now1 = new Date(); // String tempStr = yyMMddFormatter.format(now1); // String tempStrDate = tempStr.split(" ")[0];// 会加上00:00:00 // Date date = yyMMddFormatter.parse(tempStrDate); // 3.配置文件加上&serverTimezone=GMT%2B8,√ 正确 // 4. 设置中国标准时区 UTC+8 结果:√ // SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd"); // 设置时区: 中国标准时 China Standard Time UTC+08:00 使用GMT+8东8区,结果:?使用默认时区setTimeZone(TimeZone.getDefault); // sdf.setTimeZone(TimeZone.getTimeZone("UTC+8")); // System.out.println(sdf.getTimeZone().toString()); // Date date = sdf.parse(liftMaxDt); // System.out.println(sdf.getTimeZone().toString()); // System.out.println(date); // // Date targetDate = new Date(date.getTime()); // System.out.println("------------------"); // System.out.println(targetDate); // 5. 测试毫秒数 new Date(ms);但是要先使用sdf转入参 结果:× 问题就在于SimpleDateFormat会混乱时区 // SimpleDateFormat sdf = new SimpleDateFormat("yyMMdd"); // Date date = sdf.parse(liftMaxDt); // Date targetDate = new Date(date.getTime()); // System.out.println("使用sdf转换date,在new Date(date.getTime())-----------"); // System.out.println(targetDate); // 使用LocalDate.结果: × 还是少一天 DateTimeFormatter df = DateTimeFormatter.ofPattern("yyMMdd"); LocalDate ldt = LocalDate.parse(liftMaxDt, df); System.out.println("String类型的时间转成LocalDateTime:"+ldt); // LocalDate转LocalDateTime LocalDateTime lll = LocalDateTime.of(ldt, LocalTime.of(0,0,0)); ZoneId zone = ZoneId.systemDefault(); Instant instant = lll.atZone(zone).toInstant(); Date targetDate = Date.from(instant); // 将对象里时间属性设置为String,数据库里仍然用Date,用数据库的时间函数转化

最后,还是采用的数据库为timestamp类型,用mysql的时间函数进行转换,保证时间为数据库时间

补充知识:mybatis解决java中的date类型存入oracle数据库之后不显示时分秒

实体类中类型为java.util.Date

private Date update_date;

数据库中对应字段的类型为Date

不显示 时分秒 的情况:

Mapping文件中对应字段的jdbcType为DATE类型

如果显示时分秒的话,只需要将Mapping文件中对应字段的类型改为TIMESTAMP即可.

以上这篇浅谈Mybatis+mysql 存储Date类型的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。