mysql数据库数字取整,截取部分字段,日期
2017-02-15 08:48
1191 查看
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为小数的一个数字。如果
D为
0,结果将没有小数点或小数部分。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';
完毕;
注:以上问题的解决方法部分摘自度娘,侵删。
相关文章推荐
- 截取Mysql的日期字段部分
- SQL语句中如何截取字段中的数字部分然后进行精确查找
- SQL Server中截取日期型字段的日期部分和时间部分
- SQL Server中截取日期型字段的日期部分和时间部分
- SQL Server 中截取日期的日期部分与时间部分
- SQlserver 创建函数实现只取某个字段的数字部分
- 截取字段数值特定的部分
- struts2中格式化输出数字和日期、截取小数点后两位数的方法
- 如何批量更新oracle库中时间型字段的日期部分
- MySql用DATE_FORMAT截取DateTime字段的日期值
- 无废话ExtJs 入门教程九[数字字段:NumberField、隐藏字段Hidden、日期字段:DataFiedl]
- 截取部分字段(数据库)
- 截取字符串中数字部分函数
- SQL中只截取日期的日期部分和日期的时间部分
- 往数据表中插入 "字段名 字符串" , 对于非字符字段,采用 "递增整形数字" 代替(日期字段会自动转变为对应日期)
- 在mysql数据库中关于日期时间字段的处理
- SQL截取一个字段中不确定字母和数字并按照数字顺序排序
- 如何实现截取无规则字符串中的数字部分
- [知识点]datatable排序、取部分数据、截取某字段的长度
- sql如何截取日期字段中的年和月