数据库日期字段采用String或Date等原生类型的优劣势对比

数据库中常用的日期类型:

日期类型存储空间日期格式日期范围
date3 bytesYYYY-MM-DD1000-01-01 ~ 9999-12-31
datetime8 bytesYYYY-MM-DD HH:MM:SS1000-01-01 00:00:00 ~ 9999-12-31 23:59:59
timestamp4 bytes YYYY-MM-DD HH:MM:SS1970-01-01 00:00:01 ~ 2037-12-31 23:59:59
time3 bytesHH:MM:SS-838:59:59 ~ 838:59:59
varchar14+ bytesYYYYMMDDHHMMSS 






    字符串不是一个很高效的数据类型,占用存储空间大,数值之间compare是逐个字符比对,比较慢,唯一的优势是展示比较直接。

    timestamp和其他数据库原生支持的日期类型,它们在实际存储和查询的时候其实都是整数,所以非常高效。相对于varchar占用的的内存也更少。

小结:数据库存储日期,建议采用原生的日期类型,效率和功能上肯定都有很高的保证;如果不支持日期类型的话,就用长整型Long或者大整数BIGINT。采用varchar存储是一种比较偷懒的做法,但是考虑到代码可能要移植到不同的数据库上,在兼容性上有更高的保证。

    

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在后端将前端传递的Date类型字段转换为String类型并存入数据库时,具体的方法取决于你使用的编程语言和数据库。以下是一个通用的示例来解释这个过程的步骤: 1. 接收前端传递的Date类型字段。具体的方式取决于你使用的后端框架和编程语言。例如,在Java,你可以使用HttpServletRequest对象来获取前端传递的参数。 2. 将接收到的Date类型字段转换为String类型。根据你使用的编程语言,可以使用日期格式化函数或方法来进行转换。例如,在Java,你可以使用SimpleDateFormat类来将Date类型转换为String类型。 ```java import java.text.SimpleDateFormat; import java.util.Date; // 假设前端传递的字段名为"dateParam" Date dateParam = request.getParameter("dateParam"); SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); String dateString = dateFormat.format(dateParam); ``` 3. 将转换后的String类型字段存入数据库。具体的方法取决于你使用的数据库和后端框架。一般来说,你需要执行一个更新(Update)操作或插入(Insert)操作来将数据存入数据库。 ```java // 假设使用JDBC连接MySQL数据库进行更新操作 String sql = "UPDATE your_table SET date_column = ? WHERE ..."; PreparedStatement statement = connection.prepareStatement(sql); statement.setString(1, dateString); statement.executeUpdate(); ``` 上述示例,"your_table" 是你的表名,"date_column" 是存储日期的列名,"?" 是占位符,通过setString方法将转换后的日期字符串设置到占位符。 请根据你使用的编程语言、框架和数据库进行相应的调整和实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值