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为小数的一个数字。如果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)相关术语:navicat for mysql mysql workbench mysql数据库 mysql 存储过程 mysql安装图解 mysql教程 mysql 管理工具

主题: MySQLSQL数据数据库RIM
分页:12
转载请注明
本文标题:mysql数据库数字取整,截取部分字段,日期 mysql mysql数据库 mysql函数 MySQL数据库学 ...
本站链接:http://www.codesec.net/view/533782.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 数据库(mysql) | 评论(0) | 阅读(73)