C++orm使用插曲——MySQL保留字

devtools/2024/10/22 18:45:44/

近日开始对数据库开始涉猎,在编写数据库操作类调试过程中遇到一个问题:

mysql> select * from environmental_variable_table where key='temperature' AND dev_ip='192.168.1.1';
1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'key='temperature' AND dev_ip='192.168.1.1'' at line 1
mysql> 

部分涉及代码如下:

struct environmental_variable_table
{std::string station_num;std::string dev_type;std::string dev_nid;std::string dev_sn;std::string dev_ip;std::string key;std::string m_value;std::string value_desc;
};
REFLECTION(environmental_variable_table, station_num, dev_type, dev_nid, dev_sn, dev_ip, key, m_value, value_desc)class CEnvironmentalVariableTable
{
private:dbng<mysql> m_mysql;bool connectDB(){return m_mysql.connect(MYSQL_IP, MYSQL_USER, MYSQL_PASSWORD, MYSQL_DATABASE);}public:CEnvironmentalVariableTable(){if (!connectDB()){throw std::runtime_error("Failed to connect to the database.");}}void addData(const environmental_variable_table &envVar){if (!m_mysql.insert(envVar)){throw std::runtime_error("Failed to insert environmental variable.");}}void addData(const std::vector<environmental_variable_table> &envVars){if (!m_mysql.insert(envVars)){throw std::runtime_error("Failed to insert environmental variables.");}}environmental_variable_table getData(const std::string &key, const std::string &dev_ip){auto result = m_mysql.query<environmental_variable_table>("key='" + key + "' AND dev_ip='" + dev_ip + "'");if (result.empty()){throw std::runtime_error("Failed to retrieve environmental variable or variable not found. key=" + key + ", dev_ip=" + dev_ip);}return result.front();}void updateData(const std::string &key, const std::string &dev_ip, const environmental_variable_table &updatedEnvVar){if (!m_mysql.update(updatedEnvVar, "key='" + key + "' AND dev_ip='" + dev_ip + "'")){throw std::runtime_error("Failed to update environmental variable.");}}void removeData(const std::string &key, const std::string &dev_ip){if (!m_mysql.execute("delete from environmental_variable_table where key='" + key + "' AND dev_ip='" + dev_ip + "'")){throw std::runtime_error("Failed to remove environmental variable.");}}
};

这段的代码实际是对数据库表封装的一个工具模板。

经过调查发现,类似于key这样的内容是一个保留字,在 SQL 中,KEY 是一个保留字,如果你的表中有一个列名叫做 key,你需要使用反引号将其包围起来,以便正确执行查询。

或者直接修改名称。这里我将key 修改为了m_key,解决了问题。

同样的,这里把相关的类似保留字都列出来,防止再出现类似的问题。
以下是一些常见的 MySQL 保留字及其含义:

保留字含义
ADD添加新列或索引到表中
ALTER修改表结构
AND逻辑运算符 AND
AS重命名列或表
BETWEEN在某个范围内
BY按照某种方式
CREATE创建数据库或表
DELETE删除记录
FROM从哪个表中检索数据
GROUP BY按照某个列分组
HAVING对 GROUP BY 的结果进行条件过滤
IN在某个值列表中
INSERT插入记录
INTO插入数据的目标表
IS判断是否为某个值
JOIN连接两个或多个表
KEY索引关键字
LIKE模糊匹配
NOT逻辑运算符 NOT
NULL空值
OR逻辑运算符 OR
ORDER BY按照某个列排序
SELECT查询数据
SET设置变量值
UPDATE更新记录
VALUES插入数据的值列表
WHERE指定条件

分享一个有趣的 学习链接:https://xxetb.xet.tech/s/HY8za


http://www.ppmy.cn/devtools/20233.html

相关文章

k8s部署alertmanager

修改alertmanager-pvc.yaml文件中的信息&#xff0c;然后应用YAML文件 cat > /opt/k8s/alertmanager/alertmanager-pvc.yaml <<EOF apiVersion: v1 kind: PersistentVolumeClaim metadata:name: alertmanager-data-pvc spec:accessModes:- ReadWriteManystorageClass…

记一次线上日志堆栈不打印问题排查(附:高并发系统日志打印方案可收藏)

目录 一.线上的日志堆栈不打印了二.一步一步仔细排查三.最后搞定四.聊一聊线上日志到底应该怎么打印4.1 日志打印的诉求4.2 常见的系统日志上报方案4.2.1 ELK 方案4.2.2 自定义log appender 完成应用日志采集. 4.3 日志常见框架傻傻分不清4.4 日志在高并发系统中需要注意的 tip…

STM32之串口中断接收丢失数据

五六年没搞STM32了&#xff0c;这个项目一切都挺顺利&#xff0c;万万没想到被串口接收中断恶心到了。遇到的问题很奇怪 HAL_UART_Receive_IT(&huart1, &rx_buffer[rx_index], LCD_UART_LEN); 这个代码中 LCD_UART_LEN1的时候&#xff0c;接收过来的数据&#xff0c;数…

(学习日记)2024.05.03:UCOSIII第五十七节:User文件夹函数概览(uCOS-III->Source文件夹)第三部分

写在前面&#xff1a; 由于时间的不足与学习的碎片化&#xff0c;写博客变得有些奢侈。 但是对于记录学习&#xff08;忘了以后能快速复习&#xff09;的渴望一天天变得强烈。 既然如此 不如以天为单位&#xff0c;以时间为顺序&#xff0c;仅仅将博客当做一个知识学习的目录&a…

认识HTTP

HTTP缺点 通信使用明文&#xff08;不加密&#xff09;&#xff0c;内容可能会被窃听 不验证通信方的身份&#xff0c;可能遭遇伪装 无法证明报文的完整性&#xff0c;所以有可能遭篡改 一、通信使用明文&#xff08;不加密&#xff09;&#xff0c;内容可能会被窃听 TCP/…

每日JAVA高级面试题

Java 高级面试问题及答案 以下是一些在Java高级面试中可能会遇到的问题&#xff0c;以及对这些问题的探讨和回答。 问题 1: Java内存模型是什么&#xff1f;请解释其重要性。 探讨&#xff1a; Java内存模型&#xff08;Java Memory Model, JMM&#xff09;是Java虚拟机&…

Rust序列化和反序列化

Rust 编写python 模块 必备库 docker 启动 nginx 服务 NGINX 反向代理配置

笔记:.NET的框架梳理及相关概念了解(“.NET Core“ “.NET“ “.NET Framework“)

一、.NET设计 架构&#xff1a;C/C程序是直接将源码编译成机器码&#xff08;CPU可以识别和运行的指令&#xff09;&#xff0c;对于不同CPU&#xff0c;其指令集不同&#xff0c;机器码也就不同&#xff0c;故&#xff1a;C/C程序编译时&#xff0c;需选择具体的CPU架构&…