42 mysql “+“ 操作符的实现

前言

问题来自于 chinaunix, mysql select 子句的小白问题 

mysql 的一些基础的 算术运算符 的计算的实现

这里 整理如下 case, 执行之前 设置如下变量

set @a = 2;
set @b = 3;select @a + @b;
select 'a' + 'b';
select 1 + 3;
select '1' + '3';
select 'a + b';
select a + b;

 

 

select @a + @b;

解析 sql 的时候, 会将 表达式 解析为一个 Item_func_plus, 左右操作数为 Item_func_get_user_var 变量名分别为 a, b

2f4558e20f6c4237b21983234fff6e5b.png

 

查询的时候 选择列即为 上面解析表达式的时候 resolve 的 Item_func_plus

然后由 Item_func_plus 来计算结果, 以及响应数据 

d5393378c27447878f0c925a4a76a738.png

 

取变量的方式为, 从 user_var_entry 中获取存储的数据值, 这个值是上面 “set @a = 2;” 设置进去的 

bf4e473a662b4116b597880352fbf561.png

 

具体的 计算业务是由这里的 val0 + val1, 以及 之后的符号相关处理 来完成的

得到结果 2 + 3 = 5

2212f124cf4a4aeb89e2be8591985897.png

 

 

select 'a' + 'b';

解析表达式的的时候, 合成一个 Item_func_plus, 左右操作数为 字面量 ”a”, ”b”

7faba5e80214409195e1201fa866f066.png

 

计算的时候, 尝试将 “a” 转换为 int 的时候 “a” 不符合 数字的相关规范, my_strntod 计算为 0

de580d2742744f7290e82bc59f5c10cb.png 

因此 计算结果为 0 + 0 = 0

01090431702646d7a963b9ad08ec784a.png 

 

select 1 + 3; 

解析表达式的的时候, 合成一个 Item_func_plus, 左右操作数为 数字 1, 3

ad97886c8e0f4f61ab11eca25f6c03c6.png

 

计算的时候, 获取数字 1 的值, 为 1

cf12efeb4c1240838cff7270f7ab0b3b.png 

计算结果为 1 + 3 = 4

eef3034d15c742e98ae03b7e41325ca2.png 

 

select '1' + '3';

解析表达式的的时候, 合成一个 Item_func_plus, 左右操作数为 字面量 ”1”, ”3”  

57a5e04b4d9d48068a0ad9faea10f499.png

 

将字面量转换为数字的时候, “1” 转换为 1, “3” 转换为 3

50eb178249e34d15904d6ddad0347aa4.png 

计算结果为 1 + 3 = 4

2f5f07f31f80491eb4afb6dabb95a64c.png 

 

select 'a + b';

解析表达式的时候, 解析为一个 常量字面量 “a + b”

262111575af04d1c8d41248fb1268472.png

 

然后 响应的时候, 直接 响应给定的字面量的字符串

410b1ed6c0324091b13c62b87b06a3e3.png 

 

select a + b;

解析表达式的的时候, 合成一个 Item_func_plus, 左右操作数为 Identifier 标记分别为 “a”, “b”

5d4b1afefe7d4a53b476a6c119acbad9.png

 

如果这里是 表中的两个字段, 这里也是类似的效果 

select field1 + field2 from tz_test;

cc3d844c3a0746ed8f7ba7fd9e7aee0a.png

 

然后后面 setup_fields 的时候, 从数据表中获取 a, b 对应的字段, 不存在 该字段

然后 抛出了 ER_BAD_FIELD_ERROR 其错误码为 1054

4c88b520fe6b45f79d2948da5157c7ae.png

 

 

@a, @b 这些变量取自哪里? 

执行 sql 如下 “set @a = 10;”

可以看到 是通过 “a” 从当前 session 的 user_vars 的一个 Map 中存取的变量 

1f6077209cd04d5aa5a7d663b6e10e71.png

 

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28557.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Quartus 13.0】NIOS II 部署UART 和 PWM

打算在 EP1C3T144I7 芯片上部署 nios ii 做 uart & pwm控制 这个芯片或许不够做 QT 部署 这个芯片好老啊,但是做控制足够了,我只是想装13写 leader给的接口代码是用VHDL写的,我不会 当然verilog我也不太会 就这样,随便写吧 co…

element-plus表单组件之自动补全组件el-autocomplete和级联选择器组件el-cascader

el-autocomplete 自动补全组件 自补全组件的功能和可以根据输入过滤的el-select组件有些类似。 fetch-suggestions 根据输入框的输入获取建议的内容,其接受值是一个函数,有2个参数,querystring:输入的内容,callback内置函数&…

数据结构C语言版:顺序表基本操作的实现

参考教材:数据结构C语言版(严蔚敏,吴伟民编著) 目录 线性表的基本操作: 1:线性表L的初始化(参数用引用) 2:销毁线性表L 3:清空线性表L 4:求线性表L的长度 5&#xf…

比亚迪智驾技术震撼登场!L3级自动驾驶领跑全国,无图导航、夜间挑战轻松应对!

作为新能源汽车领域的翘楚,比亚迪在电池技术与智能驾驶方面都有着卓越的表现。近日,比亚迪凭借其领先的智驾技术,成功入选全国首批L3级自动驾驶上路及行驶试点名单,这无疑将推动智驾技术的普及速度。 你知道吗?比亚迪智…

Java高手的30k之路|面试宝典|熟悉常用开源集合库Guava和ApacheCommonsCollections

Apache Commons Collections Apache Commons Collections 是一个扩展 Java Collections Framework 的开源库,提供了许多实用的集合类和相关工具。 常用的集合类: 1. Bag 接口及其实现 Bag 是一个特殊的集合,允许重复元素,并能…

写作工具:用latex代码插入公式(GPT prompt)

其中所有的公式都直接显示latex代码,不要进行编译,注意公式必须前后有$$,单独的字母或单词不需要用latex,比如i这个字母;如: $ $\Gamma(z) \int_0^\infty t^{z-1}e^{-t}dt\,. $ $ (复制粘贴该p…

单目标应用:基于三角拓扑聚合优化算法TTAO的微电网优化(MATLAB代码)

一、微电网模型介绍 微电网多目标优化调度模型简介_vmgpqv-CSDN博客 参考文献: [1]李兴莘,张靖,何宇,等.基于改进粒子群算法的微电网多目标优化调度[J].电力科学与工程, 2021, 37(3):7 二、三角拓扑聚合优化算法求解微电网 2.1算法简介 三角拓扑聚合优化算法&…

如何连接达梦数据库?

连接达梦数据库(DM Database)可以通过多种方式进行,包括使用 JDBC(Java Database Connectivity)驱动程序,这是最常见的方式之一。以下是使用 Java 通过 JDBC 连接达梦数据库的详细步骤: 1. 准备…

梦想编织者Luna:COZE从童话绘本到乐章的奇妙转化

前言 Coze是什么? Coze扣子是字节跳动发布的一款AI聊天机器人构建平台,能够快速创建、调试和优化AI聊天机器人的应用程序。只要你有想法,无需有编程经验,都可以用扣子快速、低门槛搭建专属于你的 Chatbot,并一键发布…

002、浅谈MongoDB数据库的优势

1. 灵活的数据模型 MongoDB 的文档存储方式允许你随时更改文档的结构而不需要中断应用程序,特别适合需求变化快的场景。 实例: 电商平台: 在一个电商平台中,不同类别的商品可能有不同的属性。例如,电子产品有保修期&…

gbase8s数据库的逻辑日志、物理日志和两种特殊情形的学习

(一) 日志的介绍 1. 日志的类别 数据库日志主要是分为记录日志、逻辑日志和物理日志。 记录日志:记录日志包括了数据库的报错日志、连接日志、sql执行等信息,这些日志不存储在dbspace上,而是保存在操作系统的文件内逻辑日志和物理日志&…

linux下C语言如何操作文件(二)

上篇文章中,我们简单介绍了file_util.h中定义的各函数,今天我们来讲解如何实现头文件中定义的各函数。首先,在file_util.c中,我们需要引入相应的头文件: #include <stdio.h> #include <stdlib.h> #include <stdbool.h> #include <unistd.h> #inc…

Kali之metasploit学习

目标&#xff1a;尝试使用metasploit制作一个windows 后门&#xff08;exe文件&#xff09; 一&#xff1a;使用metasploit生成一个exe安装包。 二、将对应的可执行文件放入到目标机 python3 -m http.server 端口号&#xff1a; 模块化启动一个端口。 windows 证书管理工具&…

Python(二)---数据类型与变量、以及运算符

文章目录 前言1.Python程序的构成1.1.代码的组织和缩进1.2.使用\行连接符 2.对象和引用、标识符规则2.1.对象2.2.引用2.3.标识符规则 3.变量和简单赋值语句3.1.变量的声明和赋值3.2.删除变量和垃圾回收机制3.3.常量3.4.链式赋值3.5.系列解包赋值 4.最基本内置数据类型4.1.数字和…

【MySQL】BIT_OR函数在二进制分组group by中的妙用

BIT_OR函数的妙用 使用的是官方文档的例子。参考地址&#xff1a;https://dev.mysql.com/doc/refman/8.0/en/calculating-days.html 1. 先看例子 1、假设有如何的表&#xff08;year&#xff0c;month&#xff0c;day字段分别表示年、月、日&#xff09; CREATE TABLE t1 (…

使用了代理IP怎么还会被封?代理IP到底有没有效果

代理IP作为一种网络工具&#xff0c;被广泛应用于各种场景&#xff0c;例如网络爬虫、海外购物、规避地区限制等。然而&#xff0c;很多用户在使用代理IP的过程中却发现自己的账号被封禁&#xff0c;这让他们不禁产生疑问&#xff1a;使用了代理IP怎么还会被封&#xff1f;代理…

速盾:cdn加速怎么计费?

CDN加速&#xff08;Content Delivery Network&#xff09;是一种将内容部署在全球多个节点上&#xff0c;通过就近访问提供服务的技术。它可以加快网站的速度和可靠性&#xff0c;同时减轻源服务器的负载。在使用CDN加速服务时&#xff0c;计费是一个重要的问题&#xff0c;下…

芯片验证分享8 —— 代码审查2

大家好&#xff0c;我是谷公子&#xff0c;上节课给大家讲了代码审查中的代码正向检查&#xff0c;今天我们来讲代码审查的其他方法。 今天介绍的检查方法有&#xff1a; 代码反向检查 桌面检查 同行评审 可用性验证 这些验证方法可以应用在芯片开发的任何阶段。代码审查…

《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 01 为什么需要一个新的网络架构

关于专栏 本专栏是工作之后阅读 Cloud Native Data Center Networking &#xff08; O’Reilly, 2019&#xff09;的读书笔记。这本书是我在数据中心从事云网络工作的启蒙、扫盲读物。可惜&#xff0c;其中文版翻译并非尽善尽美&#xff0c;必须结合英文原版才能理解原作者要表…

第 4 章:从 Spring Framework 到 Spring Boot

通过前面几个章节的介绍&#xff0c;相信大家已经对 Spring Framework 有了一个基本的认识&#xff0c;相比早期那些没有 Spring Framework 加持的项目而言&#xff0c;它让生产力产生了质的飞跃。但人们的追求是无止境的&#xff0c;这也驱动着技术的发展。开发者认为 Spring …