C++ MYSQL常用操作

1.使用mysql_init()初始化连接

//声明如下:
 MySQL *mysql_init(MYSQL *mysql)

这个函数用来分配或者初始化一个MYSQL对象,用于连接mysql服务端。如果你传入的参数是NULL指针,它将自动为你分配一个MYSQL对象,如果这个MYSQL对象是它自动分配的,那么在调用mysql_close的时候,会释放这个对象。那么,这就有可能出现一个问题,就是,当你主动调用mysql_close之后,可能因为某些原因,又调用一次mysql_close,第二次调用,有可能因为mysql已经是野指针导致程序崩溃。因此,为了安全起见,建议不要让mysql_init api自动创建MYSQL对象,而由自己管理这个对象,并且传入地址让它完成初始化,这样来避免多次调用mysql_close()后出现程序崩溃的情况。
2.使用mysql_real_connect()建立一个到mysql数据库的连接

//函数原型
MYSQL *mysql_real_connect(MYSQL *mysql,
 const char *host,
 const char *user,
 const char *passwd,
 const char *db,
 unsigned int port,
 const char *unix_socket,
 unsigned long client_flag)

1.MYSQL * 为mysql_init()返回的指针
2.host为IP地址,本地数据库一般填localhost或127.0.0.1,这两者最大的区 别是Localhost是不经过网卡传输的,所以,它不受网络防火墙和与网卡相关的种种限制;而127.0.0.1则要通过网卡传输数据,是必须依赖网卡的。
3.user就是数据库的用户名。
4.passwd:数据库密码。
5.db:数据库名
6.port:端口号,一般为填0或3306
7.unix_socket:是否使用socket或管道机制,为null时表示不使用
8.最后一个一般为0

//具体用例
bool connect()
{
    MYSQL mysql;
    mysql_init(&mysql);
    MYSQL *conn = mysql_real_connect(&mysql, DB_HOST, DB_USER, DB_PWD, DB_DATABASE, 0, NULL, 0); // 对确定的数据库建立一个连接,如果失败返回一个空指针
    if(conn == NULL)
    {
        return false;
    }
    else
    {
        return true;
    }
}

3.mysql_real_query()

//函数原型:
int mysql_real_query(MYSQL *mysql, const char *query, unsigned int length)
//若查询成功,返回0,查询失败,返回非0数字

参数1:已初始化的MYSQL 实例;
参数2:SQL语句
参数3:SQL语句字符数
说明:
执行由query指向的SQL查询,它应该是一个length个字节的字符串。查询必须由一个单个的SQL语句组成。你不应该在语句后增加一个终止的分号(“;”)或\g。
对于包含二进制数据的查询,你必须使用mysql_real_query()而不是mysql_query(),因为二进制代码数据可能包含“\0”字符,mysql_query() 不能传二进制BLOB字段,二进制信息中的\0会被误判为语句结束。
而且,mysql_real_query()比mysql_query()更快,因为它不会在查询字符串上调用strlen()。

4.mysql_store_result()

//函数原型
MYSQL_RES *mysql_store_result(MYSQL *mysql)
//如果查询未返回结果集,mysql_store_result()将返回Null指针
//如果返回有结果集,返回0.

说明:
对于成功检索了数据的每个查询(SELECT、SHOW、DESCRIBE、EXPLAIN、CHECK TABLE等),必须调用mysql_store_result()或mysql_use_result() 。对于其他查询,不需要调用mysql_store_result()或mysql_use_result(),但是如果在任何情况下均调用了mysql_store_result(),它也不会导致任何伤害或性能降低。
如果希望了解查询是否应返回结果集,可使用mysql_field_count()进行检查,如果mysql_field_count()返回0,则结果为空。mysql_store_result()将查询的全部结果读取到客户端,分配1个MYSQL_RES结构,并将结果置于该结构中。
可以调用mysql_fetch_row()来获取结果集中的行,或调用mysql_row_seek()和mysql_row_tell()来获取或设置结果集中的当前行位置。一旦完成了对结果集的操作,必须调用mysql_free_result()。

5.mysql_num_fields()

int mysql_num_fields(int result);
//返回结果集字段个数,如果失败,则返回 false

7.mysql_fetch_row()

MYSQL_ROW mysql_fetch_row(MYSQL_RES *result)
//检索一个结果集合的下一行。当在mysql_store_result()之后使用时,如果没有更
//多的行可检索或出现错误时,mysql_fetch_row()返回NULL。

8.mysql_fetch_fields()

MYSQL_FIELD *mysql_fetch_fields(MYSQL_RES *result);
//返回结果集中代表字段(列)的对象的数组,如果没有可用信息则返回 FALSE。

具体用例:

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值