mysql 当时间是varchar类型时 , 进行比较

        一般情况下数据库时间类型都是以datetime、timestamp等格式进行存储的 , 但有时也会出现varchar类型 , 这个时候在sql中比较时间类型就需要用到函数STR_TO_DATE(str, format);

STR_TO_DATE(str, format)函数是DATE_FORMAT()函数的反函数 , 返回一个DATETIME值。它需要一个字符串str和一个格式字符串格式 '%Y-%m-%d %H:%i'  , %Y  四位数字表示的年份(2015,2016 ......),%M 两位数字表示月份(01,02,...,12),

%d 两位数字表示月中天数(01,02,...,31),%H 24小时制,两位数形式小时(00,01,...,23) , %i 两位数字形式的分(00,01,...,59), %S 两位数字形式的秒(00,01,...,59).

来个例子:

这是我的表数据 , 下面 加通过日期个查询的条件  , 查询 2019-06-05 的数据

查询结果显示我们使用STR_TO_DATE(str, format)函数可以将数据库中varchar类型的日期数据转换成DATETIME类型的日期数据,转换过程注意format参数必须要应对str的格式

 

然后我们在通过时间段查询一下 , 这里我就需要用到另一个切割字符串的函数了 

 left(str,length) 从左边截取length

right(str,length)从右边截取length 

我们来截取一下时间 ,查询大于10:30的时间

查询结果也是没有问题的 . 用varchar类型麻烦许多 , 建议使用时间类型(((┏(; ̄▽ ̄)┛装完逼就跑

时间加减

SELECT start_time FROM `t_healthy_lesson` WHERE STR_TO_DATE(start_time,'%Y-%m-%d %H:%i') < date_add('2019-06-03 10:30', interval 1 hour)
AND STR_TO_DATE(start_time,'%Y-%m-%d %H:%i') > date_sub('2019-06-03 10:30', interval 1 hour);

day,hour,minute,second, microsecond, week, month,quarter ,year

date_add() 加 , date_sub()减

  • 6
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在MySQL中,varchar类型比较大小是按照字符串的字典序进行的。也就是说,如果两个varchar类型的值都是纯数字,那么它们的大小比较结果就是按照数字大小进行的;如果其中一个值是字符串,那么比较结果就是按照字符串的字典序进行的。例如,"abc"比"ab"大,"123"比"45"小。 ### 回答2: MySQL中的varchar类型比较大小需要注意以下几点: 1.比较的是varchar存储的字符在编码表中对应的编码值大小,而不是字符本身的大小。例如,"A"在ASCII编码中对应的值为65,在UTF-8中对应的值为97,因此在UTF-8编码下,"A"比"a"的编码值要小。 2.在进行大小比较,如果两个varchar的长度不同,则MySQL会将短的varchar类型数据自动转换为长的varchar类型数据长度,然后再进行比较。 3.如果varchar类型数据中含有数字,那么比较会按照数字的大小进行比较,例如"10"比"9"要大。 4.如果varchar类型数据中含有日期,那么比较会按照日期的大小进行比较。 5.如果varchar类型数据中含有中文字符,那么比较会按照中文字符在编码表中对应的编码值大小进行比较。 总之,在进行varchar类型比较大小,需要注意数据类型的特点和数据本身的特点,并且在数据库设计需要根据具体情况选择合适的数据类型,以确保数据正确性和查询效率。 ### 回答3: MySQL中的VARCHAR类型是一种非常常见的字符串类型,它可以存储最大长度为65535个字符的可变长度字符串数据。 在MySQL中,VARCHAR类型比较大小是根据字符编码进行的。对于大部分字符编码来说,VARCHAR类型比较大小是逐个字符按照字符编码进行比较的。比如在UTF-8编码下,字符排序是根据unicode字符集中字符的字典顺序来进行的。 如果我们想要按照数字的大小比较VARCHAR类型的数据,我们需要使用CAST函数将VARCHAR类型的数据转换成数字类型进行比较。比如: SELECT * FROM my_table WHERE CAST(my_column AS UNSIGNED) > 10; 这个示例中,我们将my_column字段从VARCHAR类型转换成无符号整型(unsigned),来进行数字大小的比较。 需要注意的是,在使用CAST函数,如果字符串中存在非数字字符,比如字母、特殊符号等,将会抛出一个错误。因此,在进行VARCHAR类型数据比较大小,我们需要先保证数据类型的正确性。 如果我们想要根据数字的大小来对VARCHAR类型数据进行排序,可以使用ORDER BY子句,例如: SELECT * FROM my_table ORDER BY CAST(my_column AS UNSIGNED) ASC; 这个示例中,我们将my_column字段按照数字大小升序排列。 总之,MySQL中的VARCHAR类型比较大小需要根据字符编码来进行,如果我们需要根据数字大小进行比较,可以使用CAST函数将其转换成数字类型进行比较
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值