mysql运算符总结笔记

用了那么久MySql的数据库,总节了一下数据库的常用运算符,自己复习一下,以备以后参考。

1. 算术运算符(5种)
序号运算符作用
1+加法运算
2-减法运算
3*乘法运算
4/除法运算,返回商。除数为 0,返回 NULL
5%,MOD取余运算中。除数为 0,返回 NULL
2. 比较运算符(15种)

SELECT 语句中的条件语句经常要使用比较运算符。比较结果为真,则返回 1,为假返回 0,比较结果不确定会返回 NULL。

运算符作用说明
=等于用来比较两边的内容是否相等,相等的话返回 1,不相等的话返回 0
<=>安全的等于严格比较两个NULL值是否相,两个码均为NULL时,其所得值为1;而当一个码为NULL时,其所得值为0。
<> 或者 !=不等于<> 和 != 用于判断数字、字符串、表达式是否不相等
<=小于等于用来判断左边的数是否小于或者等于右边的数;小于或者等于,返回 1,否则返回 0;比较数含有 NULL,返回NULL。
>=大于等于用来判断左边的数是否大于或者等于右边的数;如果大于或者等于,返回 1,否则返回0;比较数含有NULL,返回NULL。
>大于用来判断左边的数是否大于右边的数;如果大于,返回 1,否则返回值0;比较数含有NULL,返回NULL。
<小于用来判断左边数字是否小于右边的数,如果小于,返回1,否则返回0,比较数含有NULL,返回NULL。
IS NULL 或者 ISNULL判断值是否为空检测一个值是否为 NULL,如果为 NULL,返回 1,否则返回值0。
IS NOT NULL判断值是否不为空用来检测一个值是否为非 NULL,如果是非 NULL,返回 1,否则返回 0。
BETWEEN AND在两个值之间用来判断表达式的值是否位于两个数之间,或者说是否位于某个范围内
NOT BETWEEN AND不在两个值之间用来判断表达式的值是否不位于两个数之间,或者说是否不位于某个范围内
IN在集合中判断某个数字或字符是否存下与集合中,如果存在返回1,不存在返回0
NOT IN不在集合中判断某个数字或字符是否不存在集合中,如果不存在返回1,存在返回0
LIKE模糊匹配搜索匹配字段中的指定内容。常用的通配符:%,_、escape
REGEXP 或 RLIKE正则匹配用于确定字符串是否匹配正则表达式。常用通配符:. 、* 、{n}、$、^、[]

注意:比较运算符比较字符串的时候,不区分字符串的大小写。

3. 逻辑运算符(4种)

逻辑运算符:判断表达式的真假,返回值为布尔型,真:值(1 或 true)和假:值(0 或 false)。

运算符作用说明
NOT 或者 !逻辑非返回和数相反的结果 :当数为 0(假)时,返回 1;当数为非零值时,返回 0;当数为 NULL 时,返回 NULL。
AND 或者 &&逻辑与当所有数都为非零值并且不为 NULL 时,返回 1;当一个或多个数为 0 时,返回 0;数中有任何一个为 NULL 时,返回NULL。
OR 和 ||逻辑或当两个数都为非 NULL 值时,如果有任意一个数为非零值,则返回值1,否则结果为 0;当有一个数为 NULL 时,如果另一个数为非零值,则返回1,否则结果为NULL;假如两个数均为 NULL 时,则返回NULL。
XOR逻辑异或当任意一个数为 NULL 时,返回 NULL;对于非 NULL 的数,如果两个数都非 0 值或者都是为0 值,则返回 0;如果一个为0值,另一个为非 0 值,返回 1。
4. 位运算符(6种)

位运算符是在二进制数上进行计算的运算符。位运算会先将数变成二进制数,进行位运算。然后再将计算结果从二进制数变回十进制数。

运算符作用说明
|位或参与运算的两个二进制位有一个为 1 时,结果就为 1,两个都为 0 时结果才为 0。例如1|1结果为 1,0|0结果为0,1|0结果为1。** 任何数和 -1 进行位或运算时,最终结果都是 -1 的十进制数。
&位与参与运算的两个二进制位都为 1 时,结果就为 1,否则为 0。例如1|1结果为 1,0|0结果为 0,1|0结果为 0。** 任何数和 -1 进行位与运算时,最终结果都为任何数本身的十进制数。
^位异或参与运算的两个二进制位不同时,结果为 1,相同时,结果为 0。
~位取反运算符位取反是将参与运算的数据按对应的补码进行反转,即 1 取反后变 0,0 取反后变为 1。
<<位左移位左移是按指定值的补码形式进行左移,左移指定位数之后,左边高位的数值被移出并丢弃,右边低位空出的位置用 0 补齐。语法:expr << n
>>位右移运算符位右移是按指定值的补码形式进行右移,右移指定位数之后,右边低位的数值被移出并丢弃,左边高位空出的位置用 0 补齐。语法:expr >> n

常用运算符的优先级

最高优先级为: !、BINARY、 COLLATE。最低优先级为: :=。

优先级由低到高顺序运算符
1= (赋值运算符)、:=
2|| 、OR、XOR
3&&,AND
4NOT
5BETWEEN,CASE,WHEN,THEN,ELSE
6=(比较运算符)、<=>、>= 、> 、<= 、< 、<> 、!= 、IS 、LIKE、 REGEXP、IN
7|
8&
9<<、>>
10-(减号)、+
11*、(DIV)/、%(MOD)
12^
13-(负号/一元减号)、~(位反转/一元比特反转)
14
### React 创建项目时遇到的错误及其解决方案 #### 使用 `createRoot` 替代 `ReactDOM.render` 在 React 18 中,官方不再支持使用 `ReactDOM.render` 来渲染应用。取而代之的是引入了新的并发模式API——`createRoot`。当开发者继续使用旧版API时,浏览器控制台会出现警告信息: ```javascript react-dom.development.js:86 Warning: ReactDOM.render is no longer supported in React 18. Use createRoot instead. Until you switch to the new API, your app will behave as if it’s running React 17. Learn more: https://reactjs.org/link/switch-to-createroot [^2] ``` 为了消除该提示并利用最新特性,应当按照如下方式修改入口文件中的代码片段: ```jsx // 原有写法 (已废弃) import { render } from 'react-dom'; render(<App />, document.getElementById('root')); // 新增写法 (推荐做法) import { createRoot } from 'react-dom/client'; // 导入新模块 const container = document.getElementById('root'); const root = createRoot(container); // 创建根节点实例 root.render(<App />); // 渲染应用程序 ``` #### 处理 TypeScript 类型定义缺失问题 对于采用TypeScript构建的应用程序而言,在尝试导入某些特定版本下的`@types/react-dom`包时可能会遭遇类似下面这样的编译期报错: ``` Module '".../@types/react-dom/client"' has no default export.[^3] ``` 这通常是因为所依赖的类型声明库与当前使用的React核心库不匹配造成的。此时可以考虑执行以下操作来解决问题: * 升级或降级对应的`@types/react-*`系列npm包至兼容版本; * 或者直接移除不必要的显式指定默认导出语句。 例如原先是这样写的: ```typescript import ReactDOM from "react-dom/client"; ``` 改为按命名空间形式引入即可规避此问题: ```typescript import * as ReactDOMClient from 'react-dom/client'; const client = ReactDOMClient.createRoot(document.getElementById('root')); client.render(<App />); ``` #### 安装调试工具辅助排查 除了上述技术层面调整外,实际开发过程中难免还会碰到各种棘手状况。这时借助专业的浏览器扩展可以帮助更高效定位故障原因。特别是像[React DevTools](https://chrome.google.com/webstore/detail/react-developer-tools/fmkadmapgofadopljbjfkapdkoienihi?hl=zh-CN)这类专门为前端框架定制化的插件就显得尤为重要[^4]。 安装完成后重启页面刷新缓存再试一次往往能带来意想不到的效果;另外也可以通过它直观查看虚拟DOM结构变化情况从而进一步优化性能表现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序螺丝钉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值