mysqldata字段和datatime字段
date类型
可用于需要一个日期值而不需要时间部分时。MySQL 以 ‘YYYY-MM-DD’ 格式检索与显示date值。支持的范围是 ‘1000-01-01’ 到’9999-12-31’。数据库会自动去掉时分秒
注意:不可勾选更新
datetime类型
可用于需要同时包含日期和时间信息的值。MySQL 以 ‘YYYY-MM-DD HH:mm:ss’格式检索与显示 DATETIME 类型。支持的范围是’1000-01-0100:00:00’ 到 ‘9999-12-3123:59:59’。(“支持”的含义是,尽管更早的值可能工作,但不能保证他们均可以。)数据库会自动补全时分秒
注意:可以勾选更新
@DateTimeFormat与@JsonFormat详解
前端时间控件,一般情况下直接会传一个yyyy-MM-dd的日期字符串到后台。这个时候如果我们直接用java.util.Date类型就无法正确接收到。或者我们从数据库里查到DateTime类型并且用java的Date类型接收并返回给前台的时候,前台也无法用yyyy-MM-dd的形式进行呈现。
这个时候,前面两种情况分别对应了@DateTimeFormat和@JsonFormat注解的使用。
@DateTimeFormat
该注解主要解决前端时间控件传值到后台接收准确的Date类属性的问题,我们可以在需要接收的类中对应的时间类型属性上加上@DateTimeFormat注解,并在注解中加上pattern属性,例如
public class Person{
// 名字
private String name;
// 出生年月日
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
}
随后在前端对应birthday传入的yyyy-MM-dd日期类型就能够按照该种格式进行转义赋值给Person类中的birthday的Date类型。
若想按照yyyy/MM/dd的日期格式,则直接修改@DateTimeFormat的pattern属性为对应的日期格式即可,即@DateTimeFormat(pattern = “yyyy/MM/dd”)。或者还想要接收到对应的HH-mm-ss时分秒,同样在pattern中加上即可,如@DateTimeFormat(pattern = “yyyy-MM-dd HH-mm-ss”)
@JsonFormat
该注解主要解决后台从数据库中取出时间类型赋予java对象的Date属性值无法在前端以一定的日期格式来呈现,默认返回的是一个带时区的格式串,不符合我们日常要呈现的yyyy-MM-dd格式的日期。
同样,我们在对应的接收对象时间类型上加上@JsonFormat注解,并在注解中加上pattern属性以及timezone属性,例如:
public class Person{
// 名字
private String name;
// 出生年月日
@JsonFormat(locale="zh", timezone="GMT+8", pattern="yyyy-MM-dd HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
}
表示我们从后台数据库查询结果赋予对应的Date java类型为yyyy-MM-dd格式,且注意后面的timezone属性,最好加上GMT+8表示我们以东八区时区为准,若读者想用其他时区就可以通过更改timezone属性来改变,从而解决时区不同造成的时间差问题。
扩展
以上使用方法需要在各个类的属性上加对应注解,适合日期格式个性化的操作。如果在项目中是统一的日期格式,例如yyyy-MM-dd HH:mm:ss,那么我们可以在配置文件中进行配置项目全局生效:
spring
jackson:
date-format: yyyy-MM-dd HH:mm:ss
REPLACE(receipt_address,',',' ')函数进行字符串替换操作
格式: REPLACE(str,from_str,to_str)
将字符串to_str替代字符串str中的字符串from_str,返回替换后的字符串str
REPLACE(receipt_address,',',' ')把逗号替换成空格
xml写法
注意:不能用别名点,会报错
REPLACE(receipt_address,',',' ')函数进行字符串替换操作
CAST( s.id AS CHAR)函数
id为Long类型,
order_id为字符串,所以联表查会出问题