热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

用你想不到的MySQL运算符获得更多数据比较功能_MySQL

如果你在最近进行过SELECT或UPDATE查询,那么你很可能用到过一个或者多个MySQL的比较运算符来限制查询的输出结果。比较是大多数SELECT查询不可分割的一部分,而MySQL为这一功能提供了很多函数;根据最近一次统计,它有超过20个这样的运算符和函数,从著名的和LIKE到更
如果你在最近进行过SELECT或UPDATE查询,那么你很可能用到过一个或者多个MySQL的比较运算符来限制查询的输出结果。比较是大多数SELECT查询不可分割的一部分,而MySQL为这一功能提供了很多函数;根据最近一次统计,它有超过20个这样的运算符和函数,从著名的=和LIKE到更加难懂的NOT IN和STRCMP()。 1VY4K4|}S
gM= sL
本文把重点放在一些不太常见的MySQL数据比较函数和运算符上,讨论它们可以被如何运用在应用程序里比较表格字段里的字符串、数字和日期/时间或者用户提供的值。 2X {r{C
Jlt0N)5
BETWEEN ?e6|E.S2
cZ1%MK(c:
BETWEEN运算符是测试在某个范围内是否存在一个数值或者日期值的有用方式。这个运算符接受两个参数——最大值和最小值,并测试所提供的值是否在这两个值的范围之内。如果在这个范围之内,运算符就返回一个布尔值——真;否则,它就返回一个伪值。下面就是一个例子: LO{e%I&{;
vnv4|^ZNnQ
mysql> SELECT 2350 BETWEEN 100 AND 10000; :k4RPM7oS
+----------------------------+ L%T6ai1~
| 2350 BETWEEN 100 AND 10000 | 1H-~cV1c
+----------------------------+ QvmGwFO
| 1 | M#FhJvE4QJ
+----------------------------+ m5HY$9d
1 row in set (0.18 sec) !vBxXnY;
1z2%TZ='
下面两个例子用到了日期值: YXV 9Mi
5 ""&3
mysql> SELECT 20060405 BETWEEN 20060101 AND 20070101; fUue'U|5
+----------------------------------------+ :bSK WoQ{
| 20060405 BETWEEN 20060101 AND 20070101 | MVW]|Lv
+----------------------------------------+ 9`ia<~X4N
| 1 | i|W/(Q@9
+----------------------------------------+ >nr?U% " c
1 row in set (0.00 sec) xqTpW.1
^n[lQh
mysql> SELECT 20060405 BETWEEN 20060101 AND 20060401; "7mG+Ak
+----------------------------------------+ p$@ch4i
| 20060405 BETWEEN 20060101 AND 20060401 | -c-[K6a_
+----------------------------------------+ 8hM?i_}IQ
| 0 | |_O7sBx&
+----------------------------------------+ [)51f+oC8
1 row in set (0.00 sec) ?N1LMD1qp$
7l E&D
GREATEST和LEAST *p@1}e}&A
$(J >m:j
GREATEST和LEAST运算符为判断一组数字或者时间值中最大和最小值提供了一个便捷的途径。你一看名字就知道这两个运算符的作用——下面是一个对一组日期使用GREATEST运算符的例子: +q+cyX
9zw7;jz^ +
mysql> SELECT GREATEST(20000601, 20000529, 20000604); GC)XtG5b
+----------------------------------------+ =[|IEZYq
| GREATEST(20000601, 20000529, 20000604) | :Op\PrM1f
+----------------------------------------+ |vLQb*Q
| 20000604 | BE^"n}75
+----------------------------------------+ 5|GFPd\Pg
1 row in set (0.00 sec) Xcq4XGwnj
@M2o A.7
而下面是一个对一组数值使用LEAST运算符的例子: ]Hm^_f+
oewSeplb
mysql> SELECT LEAST(100, 200, 50, -6, -73, 1000); =PF:Xj!
+------------------------------------+ Y/"C aKm
| LEAST(100, 200, 50, -6, -73, 1000) | 0Ad=,0z
+------------------------------------+ QVV?[c8K
| -73 | ZKivc xF3L
+------------------------------------+ "d KO`1
1 row in set (0.03 sec)

如果你在最近进行过SELECT或UPDATE查询,那么你很可能用到过一个或者多个MySQL的比较运算符来限制查询的输出结果。比较是大多数SELECT查询不可分割的一部分,而MySQL为这一功能提供了很多函数;根据最近一次统计,它有超过20个这样的运算符和函数,从著名的=和LIKE到更加难懂的NOT IN和STRCMP()。 w
`[9ieXPB-_
本文把重点放在一些不太常见的MySQL数据比较函数和运算符上,讨论它们可以被如何运用在应用程序里比较表格字段里的字符串、数字和日期/时间或者用户提供的值。 cH5u;zK4`
xi2 "w r9
BETWEEN `'IUKa
 }MmNDq
BETWEEN运算符是测试在某个范围内是否存在一个数值或者日期值的有用方式。这个运算符接受两个参数——最大值和最小值,并测试所提供的值是否在这两个值的范围之内。如果在这个范围之内,运算符就返回一个布尔值——真;否则,它就返回一个伪值。下面就是一个例子: TC^`&"
Nlw6 G_bLF
mysql> SELECT 2350 BETWEEN 100 AND 10000; ):zC9;:
+----------------------------+  LxyZm
| 2350 BETWEEN 100 AND 10000 | v"6*y2a N
+----------------------------+ \91$M@
| 1 | V5+]n
+----------------------------+ LSt<S*[
1 row in set (0.18 sec) ;R>|*y
z|US~Tl
下面两个例子用到了日期值: *75TVy?D
]rrpq%z
mysql> SELECT 20060405 BETWEEN 20060101 AND 20070101; NC>E(z
+----------------------------------------+ 5+BUJB4_pM
| 20060405 BETWEEN 20060101 AND 20070101 | d1^1 cr
+----------------------------------------+ iD]|sX%^0
| 1 | 3+=E{_0C
+----------------------------------------+ }TDp('^
1 row in set (0.00 sec) F{ewZsjd=
NVXTQ&|Xx
mysql> SELECT 20060405 BETWEEN 20060101 AND 20060401; {.'+W
+----------------------------------------+ ]}O0 nriE
| 20060405 BETWEEN 20060101 AND 20060401 | EXRP\Fh
+----------------------------------------+ pznE<
| 0 | .6&l`O/#
+----------------------------------------+ Iv.i5Y5
1 row in set (0.00 sec) Q%2WeRU//
3_HF8
GREATEST和LEAST e!}S7*RyN-
($.zdoUr&v
GREATEST和LEAST运算符为判断一组数字或者时间值中最大和最小值提供了一个便捷的途径。你一看名字就知道这两个运算符的作用——下面是一个对一组日期使用GREATEST运算符的例子: >oh!wq[+
`G~ofP8
mysql> SELECT GREATEST(20000601, 20000529, 20000604); F6$ l {bm
+----------------------------------------+ H* 1o5vg
| GREATEST(20000601, 20000529, 20000604) | }YXH:8I
+----------------------------------------+ .62Dx{
| 20000604 | t!%i/:J'[
+----------------------------------------+ u)12rx
1 row in set (0.00 sec) h ,NJ.mK
MFVN%.E r
而下面是一个对一组数值使用LEAST运算符的例子: Q,rcyIM
o1S4#?Sy
mysql> SELECT LEAST(100, 200, 50, -6, -73, 1000); S 9)TvQ
+------------------------------------+ 5Nhr|@b0
| LEAST(100, 200, 50, -6, -73, 1000) | SNi9WIjP`
+------------------------------------+ rIo qO# 3
| -73 | #:z &&)Y&C
+------------------------------------+ ))%8e1rB
1 row in set (0.03 sec)

推荐阅读
  • PHP组合工具以及开发所需的工具
    本文介绍了PHP开发中常用的组合工具和开发所需的工具。对于数据分析软件,包括Excel、hihidata、SPSS、SAS、MARLAB、Eview以及各种BI与报表工具等。同时还介绍了PHP开发所需的PHP MySQL Apache集成环境,包括推荐的AppServ等版本。 ... [详细]
  • Java实战之电影在线观看系统的实现
    本文介绍了Java实战之电影在线观看系统的实现过程。首先对项目进行了简述,然后展示了系统的效果图。接着介绍了系统的核心代码,包括后台用户管理控制器、电影管理控制器和前台电影控制器。最后对项目的环境配置和使用的技术进行了说明,包括JSP、Spring、SpringMVC、MyBatis、html、css、JavaScript、JQuery、Ajax、layui和maven等。 ... [详细]
  • 现在学vb6还靠得住么?语言只是工具,关键是思想。程序=算法+数据结构。除了汇编,其他语言都靠不住。随着时代的进步,很多语言跟不上开发的要求。从面向过程到面向对象,与其说是思想的进步,不如说是为了适应高速开发。除了底层汇编语言,还有那些能适应高速开发的语言。每种语言都是很有趣的。 ... [详细]
  • 本文详细介绍了如何创建和使用VUE uni-app开发环境,包括通过HBuilderX可视化界面和通过vue-cli命令执行的方法。文章内容简单清晰,易于学习与理解。通过学习本文,读者可以深入了解VUE uni-app开发环境,并通过实践验证掌握具体的使用情况。编程笔记将为读者推送更多相关知识点的文章,欢迎关注! ... [详细]
  • 本文介绍了一个从入门到高手的VB.NET源代码,通过学习这些源代码,可以在21天内成为VB.NET高手。文章提供了下载地址,并提醒读者加入作者的QQ群和收藏作者的博客。 ... [详细]
  • 全面介绍Windows内存管理机制及C++内存分配实例(四):内存映射文件
    本文旨在全面介绍Windows内存管理机制及C++内存分配实例中的内存映射文件。通过对内存映射文件的使用场合和与虚拟内存的区别进行解析,帮助读者更好地理解操作系统的内存管理机制。同时,本文还提供了相关章节的链接,方便读者深入学习Windows内存管理及C++内存分配实例的其他内容。 ... [详细]
  • Linux环境变量$PATH的作用及使用方法
    本文介绍了Linux环境变量$PATH的作用及使用方法。$PATH是一个由多个目录组成的变量,用冒号分隔。当执行一个指令时,系统会按照$PATH定义的目录顺序搜索同名的可执行文件,如果有多个同名指令,则先找到的会被执行。通过设置$PATH变量,可以在任何地方执行指令,无需输入绝对路径。 ... [详细]
  • Windows7企业版怎样存储安全新功能详解
    本文介绍了电脑公司发布的GHOST WIN7 SP1 X64 通用特别版 V2019.12,软件大小为5.71 GB,支持简体中文,属于国产软件,免费使用。文章还提到了用户评分和软件分类为Win7系统,运行环境为Windows。同时,文章还介绍了平台检测结果,无插件,通过了360、腾讯、金山和瑞星的检测。此外,文章还提到了本地下载文件大小为5.71 GB,需要先下载高速下载器才能进行高速下载。最后,文章详细解释了Windows7企业版的存储安全新功能。 ... [详细]
  • GTX1070Ti显卡怎么样?GTX1070Ti显卡首发图赏+参数解读与拆解图
    先来简单回顾一下今年的显卡市场,nvidia自从发布了帕斯卡架构新品之后,可以说是一直都主宰着高端游戏显卡市场,虽说amd也憋了一个hbm2的vega64出来,然而即使是最高贵的水 ... [详细]
  • 本文介绍了禅道作为一款国产开源免费的测试管理工具的特点和功能,并提供了禅道的搭建和调试方法。禅道是一款B/S结构的项目管理工具,可以实现组织管理、后台管理、产品管理、项目管理和测试管理等功能。同时,本文还介绍了其他软件测试相关工具,如功能自动化工具和性能自动化工具,以及白盒测试工具的使用。通过本文的阅读,读者可以了解禅道的基本使用方法和优势,从而更好地进行测试管理工作。 ... [详细]
  • 本文介绍了某点评网的搜索策略,包括名称和地址的匹配策略,模糊匹配的方法以及不同口音和拼音的近似发音。同时提供了一些例子来说明这些策略的应用。 ... [详细]
  • loader资源模块加载器webpack资源模块加载webpack内部(内部loader)默认只会处理javascript文件,也就是说它会把打包过程中所有遇到的 ... [详细]
  • asp中如何嵌入python的简单介绍
    本文目录一览:1、如何在IIS中执行Python脚本 ... [详细]
  • CS231n简介详见CS231n课程笔记1:Introduction。本文都是作者自己的思考,正确性未经过验证,欢迎指教。作业笔记本部分实现的是Momentum,RMSProb, ... [详细]
  • vb.net不用多线程如何同时运行两个过程?不用多线程?即使用多线程,也不会是“同时”执行,题主只要略懂一些计算机编译原理就能明白了。不用多线程更不可能让两个过程同步执行了。不过可 ... [详细]
author-avatar
江南西道longge
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有