免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2579 | 回复: 3
打印 上一主题 下一主题

[C] mysql API C Programming error [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-04-26 15:04 |只看该作者 |倒序浏览
Hello CU friends, I got an error in the  following code, I suppose it is right, and it has compiled succeeded; but when I run it, the terminal shows an error with :
Cannot insert data into artist with error: 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 'INTERT INTO artist VALUES (8, "Shakira")' at line 1.
Please help me, thanks!

#include <mysql.h>
#include <stdio.h>

int insert_data(MYSQL *conn, char *table_name, char *sqlcmd);

int main(int argc, char *argv[])
{
  MYSQL *conn = mysql_init(NULL);
  if(conn == NULL)
    {
      printf("init mysql server error: %s\n", mysql_error(conn));
      return -1;
    }
  if(!mysql_real_connect(conn, "localhost", "root", "db3788", "music",
                         0, NULL, 0))
    {
      printf("Connect to  mysql server error: %s\n", mysql_error(conn));
      return -1;
    }

  char sqlcmd[64];
  int id = 8;
  char *str = "Shakira";
char *table_name = "artist";
  sprintf(sqlcmd, "INTERT INTO %s VALUES (%d, \"%s\")", table_name, id, str);
  
  insert_data(conn, table_name, sqlcmd);
  
  mysql_close(conn);
  return 0;
}

int insert_data(MYSQL *conn, char *table_name, char *sqlcmd)
{
  if(mysql_query(conn, sqlcmd))
    {
      printf("Cannot insert data into %s with error: %s\n",
             table_name, mysql_error(conn));
      return -1;
    }
  else
    printf("inserted\n");
  return 0;
}

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
2 [报告]
发表于 2014-04-28 10:51 |只看该作者
INTERT INTO artist VALUES (8, "Shakira")

在shell中可以执行?

论坛徽章:
1
白羊座
日期:2013-09-18 22:02:26
3 [报告]
发表于 2014-05-04 19:35 |只看该作者
好像必须以分号结尾。
dev.mysql.com/doc/refman/5.0/en/mysql-query.html

论坛徽章:
7
巳蛇
日期:2014-04-10 08:54:57白羊座
日期:2014-04-22 20:06:262015年亚洲杯之沙特阿拉伯
日期:2015-02-10 14:18:532015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之吉达阿赫利
日期:2015-06-02 11:34:112015亚冠之武里南联
日期:2015-06-24 12:13:082015亚冠之阿尔纳斯尔
日期:2015-08-03 09:08:25
4 [报告]
发表于 2014-05-04 20:17 |只看该作者
回复 3# file3

C API 不需要以分号结尾的,他的错误是单词拼写错误。insert写成intert了。
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP