mysql数据库数字取整,截取部分字段,日期

1、数字取整问题
FLOOR(X)
返回不大于X的最大整数值。 mysql> select FLOOR(1.23); -> 1mysql> select FLOOR(-1.23); -> -2 注意返回值被变换为一个BIGINT
CEILING(X)
返回不小于X的最小整数值。 mysql> select CEILING(1.23); -> 2mysql> select CEILING(-1.23); -> -1

注意返回值被变换为一个BIGINT

ROUND(X)
返回参数X的四舍五入的一个整数。 mysql> select ROUND(-1.23); -> -1mysql> select ROUND(-1.58); -> -2mysql> select ROUND(1.58); -> 2

注意返回值被变换为一个BIGINT!

ROUND(X,D)
返回参数X的四舍五入的有D为小数的一个数字。如果D0,结果将没有小数点或小数部分。 mysql> select ROUND(1.298, 1); -> 1.3mysql> select ROUND(1.298, 0); -> 1  注意返回值被变换为一个 BIGINT !  
2、对某个字段截取部分字符串问题
 本来想用正则表达式中
regexp_substr,结果发现Mysql坑爹的只支持 regexp,然后想到了用  TRIM(REPLACE(str,from_str,to_str)),
不过,这个只适合有一定规律的文字,学神勿喷。
如:建表class,字段名为class,值为 '123班';
处理前:
图片
执行:
select  TRIM(REPLACE(class,'班','')) as class from class;
处理后:
图片
成功!

3、关于取某段日期的问题 
我的表某个字段是Datetime型 以" YYYY-MM-DD 00:00:00" 存放 
如 
A 2009-01-22 21:22:22 
B 2009-01-22 19:21:11 
C 2009-01-22 23:10:22 
现在用 select * from TABLE where date between '2009-1-22' And '2009-1-22' 想查日期为2009-1-22的记录 结果查不到 
有什么办法吗

解决:

   1: create table tb(id varchar(1),riqi datetime)
   2: insert into tb values('A' , '2009-01-22 21:22:22') 
   3: insert into tb values('B' , '2009-01-22 19:21:11') 
   4: insert into tb values('C' , '2009-01-22 23:10:22')
   5: go
   6: --1
   7: select * from tb where convert(varchar(10),riqi,120) = '2009-01-22'  
   8: /*
   9: id   riqi                                                   
  10: ---- ------------------------------------------------------ 
  11: A    2009-01-22 21:22:22.000
  12: B    2009-01-22 19:21:11.000
  13: C    2009-01-22 23:10:22.000
  14: 
  15: (所影响的行数为 3 行)
  16: */
  17:  
  18: --2
  19: select * from tb where riqi between '2009-01-22 00:00:00' and '2009-01-22 23:59:59'  
  20: /*
  21: id   riqi                                                   
  22: ---- ------------------------------------------------------ 
  23: A    2009-01-22 21:22:22.000
  24: B    2009-01-22 19:21:11.000
  25: C    2009-01-22 23:10:22.000
  26: 
  27: (所影响的行数为 3 行)
  28: */
  29:  
  30: drop table tb 

总结:

短日期类型默认Time为00:00:00,所以当使用between作限制条件时,就相当于between '2009-1-22 00:00:00'  and '2009-1-22 00:00:00',因此就查不出数据。要想实现功能,那就使用连接字串的形式,在短日期后面把时间补全,那样就能实现功能了。

我的代码:
   1: date1 between '" + dateTimePicker1.Value.ToShortDateString() + " 00:00:00' and '" + dateTimePicker2.Value.ToShortDateString() + " 23:59:59'  

补充:有的日期的字段类型直接为非日期型的,可以直接用“<”,“>”或者"=","!=",不一定非得用between and 来解决;
如:select date from table where date <='2016-09-18'AND saledate >= '2012-09-18';  
完毕;
注:以上问题的解决方法部分摘自度娘,侵删。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值