C++中tostring函数与数据库交互

发布时间:2024-09-08 09:09:45 作者:小樊
来源:亿速云 阅读:82

在C++中,std::to_string()是一个标准库函数,用于将数字类型(如int、float、double等)转换为字符串。当你需要将数字存储到数据库或者需要与数据库进行交互时,这个函数会非常有用。

以下是一个简单的示例,展示了如何使用std::to_string()函数与SQLite数据库进行交互:

#include<iostream>
#include<string>
#include<sqlite3.h>

int main() {
    sqlite3* db;
    char* errorMessage = nullptr;
    int exitcode = sqlite3_open("test.db", &db);

    if (exitcode) {
        std::cerr << "Can't open database: "<< sqlite3_errmsg(db)<< std::endl;
        return exitcode;
    } else {
        std::cout << "Opened database successfully!"<< std::endl;
    }

    std::string sql = "CREATE TABLE IF NOT EXISTS USERS("
                      "ID INTEGER PRIMARY KEY AUTOINCREMENT,"
                      "NAME           TEXT    NOT NULL,"
                      "AGE            INT     NOT NULL,"
                      "SALARY         REAL);";

    exitcode = sqlite3_exec(db, sql.c_str(), nullptr, nullptr, &errorMessage);

    if (exitcode != SQLITE_OK) {
        std::cerr << "SQL error: "<< errorMessage<< std::endl;
        sqlite3_free(errorMessage);
    } else {
        std::cout << "Table created successfully"<< std::endl;
    }

    int id = 1;
    std::string name = "John Doe";
    int age = 30;
    double salary = 60000.50;

    std::string insert_sql = "INSERT INTO USERS (ID, NAME, AGE, SALARY) VALUES (" +
                             std::to_string(id) + ", '" + name + "', " +
                             std::to_string(age) + ", " +
                             std::to_string(salary) + ");";

    exitcode = sqlite3_exec(db, insert_sql.c_str(), nullptr, nullptr, &errorMessage);

    if (exitcode != SQLITE_OK) {
        std::cerr << "SQL error: "<< errorMessage<< std::endl;
        sqlite3_free(errorMessage);
    } else {
        std::cout << "Records created successfully"<< std::endl;
    }

    sqlite3_close(db);

    return 0;
}

在这个示例中,我们首先创建了一个SQLite数据库连接,并创建了一个名为USERS的表。然后,我们使用std::to_string()函数将整数和浮点数转换为字符串,以便将它们插入到数据库中。最后,我们关闭了数据库连接。

请注意,这个示例仅用于演示目的。在实际项目中,你可能需要考虑使用预编译的SQL语句和参数绑定来防止SQL注入攻击。

推荐阅读:
  1. 怎么使用C++流插入和流提取运算符的重载
  2. C++中怎么调用C接口

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++

上一篇:字符串处理新思路:C++ tostring

下一篇:C++编程中tostring的替代方案

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》