0
点赞
收藏
分享

微信扫一扫

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

桑二小姐 2024-04-27 阅读 34
c++mysqladb

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

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

举报

相关推荐

0 条评论