设为首页 收藏本站
查看: 861|回复: 0

[经验分享] mysql api---从一个小例子开始mysql编程入门(5)

[复制链接]

尚未签到

发表于 2018-10-6 14:03:27 | 显示全部楼层 |阅读模式
  多查询执行的C API处理
  支持在单个字符串中指定的多语句的执行。要想与给定的连接一起使用该功能,打开连接时,必须将标志参数中的CLIENT_MULTI_STATEMENTS选项指定给mysql_real_connect()。也可以通过调用mysql_set_server_option(MYSQL_OPTION_MULTI_STATEMENTS_ON),为已有的连接设置它
  多查询就几个点


  • CLIENT_MULTI_STATEMENTS选项指定
  • mysql_next_result  int mysql_next_result(MYSQL *mysql)

  描述
  如果存在多个查询结果,mysql_next_result()将读取下一个查询结果,并将状态返回给应用程序。
  如果前面的查询返回了结果集,必须为其调用mysql_free_result()。
  调用了mysql_next_result()后,连接状态就像你已为下一查询调用了mysql_real_query()或mysql_query()时的一样。这意味着你能调用mysql_store_result()、mysql_warning_count()、mysql_affected_rows()等等。
  如果mysql_next_result()返回错误,将不执行任何其他语句,也不会获取任何更多的结果
  返回值
  描述
  0成功并有多个结果。
  -1
  成功但没有多个结果。

  0出错

  #include
  #include
  #include
  #include
  int process_result_set(MYSQL mysql, MYSQL_RES result)
  {
  int     ret = 0, i = 0;
  unsigned int  num = 0;
  

if (mysql==NULL || result==NULL)  
{
  ret = 0;
  printf("func process_result_set() err:%d, check  if (mysql==NULL || result==NULL) \n", ret);
  return ret;
  
}
  
num = mysql_field_count(mysql) ;
  

  
//求表头
  
MYSQL_FIELD  *fields = mysql_fetch_fields(result);
  
for (i = 0; i0 = error, 0 = yes (keep looping) */
  if ((status = mysql_next_result(mysql)) > 0)
  printf("Could not execute statement\n");
  
} while (status == 0);
  

  mysql_close(connect);
  

  
printf("hello...\n");
  
return ret;
  

  }
  二进制协议允许你使用MYSQL_TIME结构发送和接受日期和时间值(DATE、TIME、DATETIME和TIMESTAMP)
  要想发送临时数据值,可使用mysql_stmt_prepare()创建预处理语句。然后,在调用mysql_stmt_execute()执行语句之前,可采用下述步骤设置每个临时参数:


  •   在与数据值相关的MYSQL_BIND结构中,将buffer_type成员设置为相应的类型,该类型指明了发送的临时值类型。对于DATE、TIME、DATETIME或TIMESTAMP值,将buffer_type分别设置为MYSQL_TYPE_DATE、MYSQL_TYPE_TIME、MYSQL_TYPE_DATETIME或MYSQL_TYPE_TIMESTAMP。

  •   将MYSQL_BIND结构的缓冲成员设置为用于传递临时值的MYSQL_TIME结构的地址。

  • 填充MYSQL_TIME结构的成员,使之与打算传递的临时支的类型相符。
  使用mysql_stmt_bind_param()将参数数据绑定到语句。然后可调用mysql_stmt_execute()。
  要想检索临时值,可采用类似的步骤,但应将buffer_type成员设置为打算接受的值的类型,并将缓冲成员设为应将返回值置于其中的MYSQL_TIME结构的地址。调用mysql_stmt_execute()之后,并在获取结果之前,使用mysql_bind_results()将缓冲绑定到语句上。
  请看代码:
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  int main()
  {
  int         ret = 0, status = 0;
  MYSQL       mysql;
  MYSQL_RES   result;
  

mysql =mysql_init(NULL);  
mysql =mysql_real_connect(mysql, "localhost", "root", "123456", "mydb2", 0, NULL, CLIENT_MULTI_STATEMENTS );
  
if (mysql == NULL)
  
{
  ret = mysql_errno(mysql);
  printf("%s", mysql_error(mysql));
  printf("func mysql_real_connect() err :%d\n", ret);
  return ret;
  
}
  
else
  
{
  printf(" ok......\n");
  
}
  

  
MYSQL_TIME  ts;
  
MYSQL_BIND  bind[3];
  
MYSQL_STMT  *stmt;
  

  //注意:
  // 创建的表语句
  // create table test_table (date_field date,  time_field time,  timestamp_field timestamp );
  
char query[1024] = "INSERT INTO test_table(date_field, time_field, timestamp_field) VALUES(?,?,?)";
  

  
stmt = mysql_stmt_init(mysql);
  
if (!stmt)
  
{
  fprintf(stderr, " mysql_stmt_init(), out of memory\n");
  exit(0);
  
}
  
if (mysql_stmt_prepare(stmt, query, strlen(query))) //向环境句柄中添加sql语言  带有占位符
  
{
  fprintf(stderr, "\n mysql_stmt_prepare(), INSERT failed");
  fprintf(stderr, "\n %s", mysql_stmt_error(stmt));
  exit(0);
  
}
  

  
/* set up input buffers for all 3 parameters */
  
bind[0].buffer_type= MYSQL_TYPE_DATE;  //设置绑定变量属性
  
bind[0].buffer= (char *)&ts;
  
bind[0].is_null= 0;
  
bind[0].length= 0;
  
//
  
bind[1]= bind[2]= bind[0];
  
//...
  

  
mysql_stmt_bind_param(stmt, bind);
  

  
/* supply the data to be sent in the ts structure */
  
ts.year= 2002;
  
ts.month= 02;
  
ts.day= 03;
  

  
ts.hour= 10;
  
ts.minute= 45;
  
ts.second= 20;
  

  
mysql_stmt_execute(stmt);
  

  
// Close the statement //
  
if (mysql_stmt_close(stmt))
  
{
  fprintf(stderr, " failed while closing the statement\n");
  fprintf(stderr, " %s\n", mysql_stmt_error(stmt));
  exit(0);
  
}
  

  
mysql_close(mysql);
  

  }
  啊,终于到最后一节了:
  事务
  mysql api---从一个小例子开始mysql编程入门(6)



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-613996-1-1.html 上篇帖子: MySQL数据库(四) 下篇帖子: mysql api---从一个小例子开始mysql编程入门(6)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表