C++调用MySQL实例

#include <mysql/mysql.h>
#include <iostream>
#include <string.h>
#include <stdio.h>
#include <unistd.h>

using namespace std;

int main(){
    MYSQL _sql;
    mysql_init(&_sql);
    if(!mysql_real_connect(&_sql, "localhost", "root", "123", "shiyao", 0, NULL, 0)){
        cout<<"not connected!!"<<endl;
        cout<<mysql_error(&_sql)<<endl;
    }
    else{
        cout<<"connected!!"<<endl;
    }

    //get the result from the executing select query
    char *query = "SELECT * FROM test1";

    int t = mysql_real_query(&_sql, query, (unsigned int)strlen(query));
    if(t){
        cout<<"Error making query:"<<mysql_error(&_sql);
    }

    MYSQL_RES* res = mysql_store_result(&_sql);
    if(!res){
        cout<<"res failed!"<<endl;
    }
    MYSQL_ROW row;
    while (row = mysq
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Python提供的"C API"来实现C++调用Python的功能。以下是一个简单的示例,展示了如何在C++调用Python代码: ```cpp #include <Python.h> int main() { // 初始化Python解释器 Py_Initialize(); // 加载Python模块 PyObject* pModule = PyImport_ImportModule("test"); // 获取Python函数对象 PyObject* pFunc = PyObject_GetAttrString(pModule, "test_func"); // 调用Python函数 PyObject* pArgs = PyTuple_New(1); PyTuple_SetItem(pArgs, 0, Py_BuildValue("s", "Hello from C++!")); PyObject* pResult = PyObject_CallObject(pFunc, pArgs); // 打印Python函数返回值 char* result; PyArg_Parse(pResult, "s", &result); printf("%s\n", result); // 释放资源 Py_DECREF(pModule); Py_DECREF(pFunc); Py_DECREF(pArgs); Py_DECREF(pResult); // 关闭Python解释器 Py_Finalize(); return 0; } ``` 在上面的示例中,我们首先使用`Py_Initialize()`初始化Python解释器,然后使用`PyImport_ImportModule()`加载名为"test"的Python模块。接着,我们使用`PyObject_GetAttrString()`获取模块中名为"test_func"的函数对象,然后使用`PyObject_CallObject()`调用该函数。最后,我们通过`PyArg_Parse()`获取函数返回值,并使用`printf()`打印出来。 需要注意的是,上述示例中调用的Python函数必须满足以下条件: - 函数的参数和返回值类型必须为Python支持的类型,例如字符串、整数、列表、字典等; - 函数名和模块名必须与C++代码中使用的一致; - Python解释器必须在C++代码中正确初始化和关闭; - C++代码必须正确处理Python函数返回的对象,并在不使用时释放相应的资源。 如果你需要在C++代码中频繁地调用Python函数,可以考虑使用Boost.Python或pybind11等第三方库来简化操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值