当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL运算符获得更多数据比较功能

MYSQL
MySQL 实用命令
Mysql 默认字符集设置方法(免安装版)
MySQL 数据库对服务器端光标的限制
MySQL UPDATE更新语句精解
Table ‘xxx’ is marked as crashed and should be repaired 错误解决方法参考
mysql 读写分离(基础篇)
mysql 读写分离(实战篇)
processlist命令 查看mysql 线程
MySQL 数据类型 大全
MySQL 密码设置
MYSQL代码 定期备份Mysql数据库
汇总整理MYSQL相关操作命令
MySQL 数据库两台主机同步实战(linux)
MSSQL 添加字段说明
MySQL 查询某个字段不重复的所有记录
mysql 设置默认的时间值
mysqlreport显示Com_中change_db占用比例高的问题的解决方法
解决mysql不能插入中文Incorrect string value
mysql从执行.sql文件时处理\n换行的问题
mysql 主从服务器的简单配置

MYSQL 中的 MySQL运算符获得更多数据比较功能


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 95 ::
收藏到网摘: n/a

如果你在最近进行过SELECT或UPDATE查询,那么你很可能用到过一个或者多个MySQL的比较运算符来限制查询的输出结果。比较是大多数SELECT查询不可分割的一部分,而MySQL为这一功能提供了很多函数;根据最近一次统计,它有超过20个这样的运算符和函数,从著名的=和LIKE到更加难懂的NOT IN和STRCMP()。

本文把重点放在一些不太常见的MySQL数据比较函数和运算符上,讨论它们可以被如何运用在应用程序里比较表格字段里的字符串、数字和日期/时间或者用户提供的值。

  BETWEEN

BETWEEN运算符是测试在某个范围内是否存在一个数值或者日期值的有用方式。这个运算符接受两个参数——最大值和最小值,并测试所提供的值是否在这两个值的范围之内。如果在这个范围之内,运算符就返回一个布尔值——真;否则,它就返回一个伪值。下面就是一个例子:

下面两个例子用到了日期值:

以下为引用的内容:

  mysql> SELECT 20060405 BETWEEN 20060101 AND 20070101;

  +----------------------------------------+

  | 20060405 BETWEEN 20060101 AND 20070101 |

  +----------------------------------------+

  | 1 |

  +----------------------------------------+

  1 row in set (0.00 sec)

  mysql> SELECT 20060405 BETWEEN 20060101 AND 20060401;

  +----------------------------------------+

  | 20060405 BETWEEN 20060101 AND 20060401 |

  +----------------------------------------+

  | 0 |

  +----------------------------------------+

  1 row in set (0.00 sec)

  GREATEST和LEAST

GREATEST和LEAST运算符为判断一组数字或者时间值中最大和最小值提供了一个便捷的途径。你一看名字就知道这两个运算符的作用——下面是一个对一组日期使用GREATEST运算符的例子:

以下为引用的内容:

  mysql> SELECT GREATEST(20000601, 20000529, 20000604);

  +----------------------------------------+

  | GREATEST(20000601, 20000529, 20000604) |

  +----------------------------------------+

  | 20000604 |

  +----------------------------------------+

  1 row in set (0.00 sec)

而下面是一个对一组数值使用LEAST运算符的例子:

以下为引用的内容:

  mysql> SELECT LEAST(100, 200, 50, -6, -73, 1000);

  +------------------------------------+

  | LEAST(100, 200, 50, -6, -73, 1000) |

  +------------------------------------+

  | -73 |

  +------------------------------------+

  1 row in set (0.03 sec)