Linux C实现MySql数据库操作简单实例

博客展示了用C语言连接MySQL数据库的示例代码。包含创建数据库、表,插入数据以及查询数据的操作,还给出了编译命令。同时提醒使用rpm包安装的数据库需下载MySQL - devel的rpm开发包以获取开发所需头文件和库。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//Test1.c:

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

int main(int argc, char *argv[])
{
 int i;
 char *names[3];
 names[0] = "haha";
 names[1] = "xixi";
 names[2] = "wuwu";

 char execsql[1024];

 MYSQL mysql_conn;

 if(mysql_init(&mysql_conn) != NULL){
  if(mysql_real_connect(&mysql_conn, "localhost", "root", "xiaodan", "test", MYSQL_PORT, NULL, 0) != NULL)
  {
   printf("Good connection!/n");
   sprintf(execsql, "create database one_db");
   mysql_real_query(&mysql_conn, execsql, strlen(execsql));

//   if (!mysql_create_db(&mysql_conn, "one_db")){
   i = mysql_affected_rows(&mysql_conn);
   if (i<=0){
    printf("Can not create database one_db /n");
   }
   else{
    mysql_select_db(&mysql_conn, "one_db");
    sprintf(execsql, "create table girls(name char(10), age int(8))");
    mysql_real_query(&mysql_conn, execsql, strlen(execsql));
    mysql_select_db(&mysql_conn, "one_db");
    for(i=0; i<3; i++){
     sprintf(execsql,"insert into girls values('%s', %d)", names[i], 19+i);
     printf("%s /n", execsql);
     mysql_query(&mysql_conn, execsql);
    }
   }
  }else{
   printf("Connection Failed!/n");
  }
 }else{
  printf("Initialization Failed./n");
  return -1;
 }

 mysql_close(&mysql_conn);
 return 0;
}

编译命令:gcc -g -o test1   -I/usr/include/mysql test1.c -L/usr/lib/mysql -lmysqlclient -lz

//Test2.c

#include <stdio.h>

//#include <dmalloc.h>

#include <mysql.h>

int main(int argc, char **argv) {

    MYSQL mysql_conn; /* Connection handle */

    MYSQL_RES *mysql_result; /* Result handle */

    MYSQL_ROW mysql_row; /* Row data */

    int f1, f2, num_row, num_col;

    if (mysql_init(&mysql_conn) != NULL) {

        if (mysql_real_connect(&mysql_conn, "localhost", "root", "xiaodan", "one_db", MYSQL_PORT, NULL, 0) != NULL) {

            if (mysql_query(&mysql_conn, "select * from girls") == 0) {

    /*  以上我们执行select语句,查询表中所以记录*/

                mysql_result = mysql_store_result(&mysql_conn); // get the result from the executing select query

                num_row = mysql_num_rows(mysql_result); /* Get the no. of row */

                num_col = mysql_num_fields(mysql_result); /* Get the no. of column */

                for (f1 = 0; f1 < num_row; f1++) {

//                  for (f2 = 0; f2 < num_col; f2++) {

                        mysql_row = mysql_fetch_row(mysql_result); /* Fetch one by one */

                        printf("[Row %d, Col 0] ==> [%s]/n", f1, mysql_row[0]);
   printf("[Row %d, Col 1] ==> [%s]/n", f1, mysql_row[1]);

//                  }

                }

            } else {

                (void) printf("Query fails/n");

            }

        } else {

            (void) printf("Connection fails/n");

        }

    } else {

        (void) printf("Initialization fails/n");

    }

    mysql_free_result(mysql_result);

    mysql_close(&mysql_conn);

    return 0;

}

编译命令:gcc -g -o test2   -I/usr/include/mysql test2.c -L/usr/lib/mysql -lmysqlclient -lz

注意:使用rpm包安装的数据库没有用于开发的头文件和库,需要下载MySQL-devel的rpm开发包

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值