MySQL笔记 —SQL运算符


Posted in MySQL onJanuary 18, 2022

1.算术运算符

+ - * /或DIV %或MOD

  /或DIV

select 100/5,100 DIV 5 from dual;

结果:

100/5 100 DIV 5
20.0000 20

注意:/结果是浮点型有结果20.0000,但是DIV结果是20

取模运算%MOD

select 10 % 2,10 % 3,12 MOD -4 from dual;

结果:

10 % 2 10 % 3 12 MOD -4
0 1 0

2.比较运算符

< > = <=> <>或!= <= >=
小于 大于 等于 安全等于 不等于 小于等于 大于等于

<=>第一次学到比较特殊

select null <=> null,null = null,null != null from dual;

结果:

null<=>null null=null null!=null
1 null null

因此可以得出<=>就是为NULL而生,其余只要运算中有null结果为null

具体关键字

MySQL笔记 —SQL运算符

IS NULL 等于<=>NULL 运算及结果一样

ISNULL IS NULL也一样,但用法有点不一样

select salary from empty where salary is null;
select salary from empty where isnull(salary);
select salary from empty where salary <=> null;

大家在运用过程中最好最好用is null is not null

LEAST()min(),CREATEST()max() 一样,还是建议用min与max

BETWEEN  条件1 AND 条件2  (查询条件1到条件2范围数据,包含边界。条件1是下限,条件2是上限)

select * from emp
where salary between 3000 and 5000;

在emp表查询工资在3000到5000的员工信息

innot in

course表查询选修了(name)数据库,线性代数,概率论的同学信息

select * 
from course
where name in('数据库','线性代数','概率论');
#where name='数据库' or name='线性代数' or name='概率论';

很明显in对多个数据选择更加方便了,如果查不在里面的用not in()即可

like模糊查询 

stu表查询了(name)性刘的同学信息

select *
from stu
where name like'刘%';

在stu表查询了(name)名字包含为刘的同学信息

select *
from stu
where name like'%刘%';

stu表查询了(name)名字包含刘也包含壮的同学信息

select *
from stu
where name like'%刘%' and name like'%壮%';

在stu表查询了(name)名字第二个字为刘的同学信息

select *
from stu
where name like'_刘%';

u表查询了(name)名字第二个为_且第三个字为刘的同学信息(需要使用转移字符\)

select *
from stu
where name like'_\_刘%';

不使用转移字符需要表中用escape(&不是必须的可以用任意字符)

select *
from stu
where name like'_&_刘%' escape '&';

正则表达式:(了解)

REGEXP运算符用来匹配字符串,语法格式为:expr REGEXP 匹配条件。如果expr满足匹配条件,返回1;如果不满足,则返回0。若expr或匹配条件任意一个为NULL,则结果为NULL。

REGEXP运算符在进行匹配时,常用的有下面几种通配符:

  • (1)‘^’匹配以该字符后面的字符开头的字符串。
  • (2)‘$’匹配以该字符前面的字符结尾的字符串。
  • (3)‘.’匹配任何一个单字符。
  • (4)“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”或“b”或“c”。为了命名字符的范围,使用一个‘-’。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。(3.4自我理解跟like差不多)
  • (5)‘*’匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的‘x’字符,“[0-9]*”匹配任何数量的数字,而“*”匹配任何数量的任何字符。

3.逻辑运算符

NOT或! AND或&& OR或|| XOR
逻辑非 逻辑与 逻辑或 逻辑异或

注意:

OR可以和AND一起使用,但是在使用时要注意两者的优先级,由于AND的优先级高于OR,因此先对AND两边的操作数进行操作,再与OR中的操作数结合。

主要XOR有点陌生,有且只能取一方。

4.位运算符

& | ^ ~ >> <<
换位与(位AND) 换位或(位OR) 换位异或(位XOR) 按位取反 按位右移 按位左移

了解即可。

到此这篇关于MySQL笔记 —SQL运算符的文章就介绍到这了,更多相关 SQL运算符内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
浅析InnoDB索引结构
Apr 05 MySQL
mysql字符串截取函数小结
Apr 05 MySQL
Windows10下安装MySQL8
Apr 06 MySQL
mysql 8.0.24版本安装配置方法图文教程
May 12 MySQL
52条SQL语句教你性能优化
May 25 MySQL
MySQL 使用索引扫描进行排序
Jun 20 MySQL
MySQL系列之二 多实例配置
Jul 02 MySQL
mysql 直接拷贝data 目录下文件还原数据的实现
Jul 25 MySQL
SQL之各种join小结详细讲解
Aug 04 MySQL
MySQL令人大跌眼镜的隐式转换
Aug 23 MySQL
MySQL磁盘碎片整理实例演示
Apr 03 MySQL
MySQL 外连接语法之 OUTER JOIN
Apr 09 MySQL
Mysql中一千万条数据怎么快速查询
Dec 06 #MySQL
Mysql中有关Datetime和Timestamp的使用总结
Dec 06 #MySQL
详解MySQL中timestamp和datetime时区问题导致做DTS遇到的坑
Dec 06 #MySQL
mysql中整数数据类型tinyint详解
Dec 06 #MySQL
SQL注入详解及防范方法
Dec 06 #MySQL
防止web项目中的SQL注入
Dec 06 #MySQL
mysql创建存储过程及函数详解
Dec 04 #MySQL
You might like
PHP中通过HTTP_USER_AGENT判断是否为手机移动终端的函数代码
2013/02/14 PHP
php缓冲 output_buffering和ob_start使用介绍
2014/01/30 PHP
php判断是否为ajax请求的方法
2016/11/29 PHP
php利用fsockopen GET/POST提交表单及上传文件
2017/05/22 PHP
解决laravel(5.5)访问public报错的问题
2019/10/12 PHP
JS解析json数据并将json字符串转化为数组的实现方法
2012/12/25 Javascript
jQuery中removeData()方法用法实例
2014/12/27 Javascript
AngularJS实现Input格式化的方法
2016/11/07 Javascript
nodejs发送http请求时遇到404长时间未响应的解决方法
2017/12/10 NodeJs
微信小程序实现流程进度的图样式功能
2018/01/16 Javascript
详解Vue Elememt-UI构建管理后台
2018/02/27 Javascript
JS非行间样式获取函数的实例代码
2018/06/05 Javascript
vue-router启用history模式下的开发及非根目录部署方法
2018/12/23 Javascript
原生js实现Flappy Bird小游戏
2018/12/24 Javascript
详释JavaScript执行环境与执行栈
2019/04/02 Javascript
vue实现一拉到底的滑动验证
2019/07/25 Javascript
详解vue beforeRouteEnter 异步获取数据给实例问题
2019/08/09 Javascript
修改NPM全局模式的默认安装路径的方法
2020/12/15 Javascript
python模拟鼠标拖动操作的方法
2015/03/11 Python
Python实现根据IP地址和子网掩码算出网段的方法
2015/07/30 Python
Python基于scapy实现修改IP发送请求的方法示例
2017/07/08 Python
python进阶_浅谈面向对象进阶
2017/08/17 Python
Python爬虫PyQuery库基本用法入门教程
2018/08/04 Python
Python 基于wxpy库实现微信添加好友功能(简洁)
2019/11/29 Python
Pycharm 2020年最新激活码(亲测有效)
2020/09/18 Python
记录模型训练时loss值的变化情况
2020/06/16 Python
Tensorflow之MNIST CNN实现并保存、加载模型
2020/06/17 Python
浅析python字符串前加r、f、u、l 的区别
2021/01/24 Python
Nordgreen美国官网:在线购买极简主义斯堪的纳维亚手表
2019/07/24 全球购物
"引用"与指针的区别是什么
2016/09/07 面试题
父亲追悼会答谢词
2014/01/17 职场文书
医院学雷锋活动策划方案
2014/02/15 职场文书
英语课外活动总结
2014/08/27 职场文书
司机岗位职责
2015/02/04 职场文书
电影复兴之路观后感
2015/06/02 职场文书
MySQL中dd::columns表结构转table过程及应用详解
2022/09/23 MySQL