linux c調用 mysql代碼

 

代碼:python

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <mysql/mysql.h>
#include <time.h>
using namespace std;

MYSQL *g_conn; // mysql 鏈接
MYSQL_RES *g_res; // mysql 記錄集
MYSQL_ROW g_row; // 字符串數組,mysql 記錄行

#define MAX_BUF_SIZE 1024 // 緩衝區最大字節數

const char *g_host_name = "localhost";
const char *g_user_name = "root";
const char *g_password = "python123";
const char *g_db_name = "db_data_20170524164100";
const unsigned int g_db_port = 3306;

void print_mysql_error(const char *msg)   // 打印最後一次錯誤
{
    if (msg)
        printf("%s: %s\n", msg, mysql_error(g_conn));
    else
        puts(mysql_error(g_conn));
}

int executesql(const char * sql)
{
    /*query the database according the sql*/
    if (mysql_real_query(g_conn, sql, strlen(sql))) // 若是失敗
        return -1; // 表示失敗

    return 0; // 成功執行
}


int init_mysql()   // 初始化鏈接
{
    // init the database connection
    g_conn = mysql_init(NULL);

    /* connect the database */
    if(!mysql_real_connect(g_conn, g_host_name, g_user_name, g_password, g_db_name, g_db_port, NULL, 0)) // 若是失敗
        return -1;

    // 是否鏈接已經可用
    executesql("set names utf8"); // 若是失敗
    // return -1;
    return 0; // 返回成功
}


int main(void)
{
    if (init_mysql());
    print_mysql_error(NULL);

    char sql[MAX_BUF_SIZE];

    int firstTime = time((time_t*)NULL);
    printf("firstTime is: %d\n", firstTime);

    if (executesql("select * from data_stats_gov_cn_diqu_niandu")) // 句末沒有分號
        print_mysql_error(NULL);

    g_res = mysql_store_result(g_conn); // 從服務器傳送結果集至本地,mysql_use_result直接使用服務器上的記錄集

    int iNum_rows = mysql_num_rows(g_res); // 獲得記錄的行數
    int iNum_fields = mysql_num_fields(g_res); // 獲得記錄的列數

    printf("共%d個記錄,每一個記錄%d字段\n", iNum_rows, iNum_fields);

    // puts("id\tname\n");

    while ((g_row=mysql_fetch_row(g_res))) ;// 打印結果集
    //        printf("%s\t%s\n", g_row[0], g_row[1]); // 第一,第二字段
    {
        for(int i=0; i<iNum_fields; i++)
        {
            printf("%s\t",g_row[i]);
        }
        printf("\n");
    }

    int secodnT
View Code

 

方法二:mysql

這段代碼連接:https://andrew913.iteye.com/blog/433280sql

#include<stdio.h>  
#include<stdlib.h>  
#include<string.h>  
#include<mysql/mysql.h>  
#define MAX_COLUMN_LEN  32  
int main(int argc , char *argv[])  
{  
    MYSQL my_connection;  
    MYSQL_RES *result;  
    MYSQL_ROW sql_row;  
    MYSQL_FIELD *fd;  
    char column[MAX_COLUMN_LEN][MAX_COLUMN_LEN];  
    int res;  
    mysql_init(&my_connection);  
    if(mysql_real_connect(&my_connection,"127.0.0.1"  
                            ,"用戶","密碼","數據名稱",3306,NULL,0))  
    {  
        perror("connect");  
        res=mysql_query(&my_connection,"select * from app");//查詢  
        if(!res)  
        {  
            result=mysql_store_result(&my_connection);//保存查詢到的數據到result  
            if(result)  
            {  
                int i,j;  
                printf("the result number is %lu\n ",(unsigned long)mysql_num_rows(result));  
                for(i=0;fd=mysql_fetch_field(result);i++)//獲取列名  
                {  
                    bzero(column[i],sizeof(column[i]));  
                    strcpy(column[i],fd->name);  
                }  
                j=mysql_num_fields(result);  
                for(i=0;i<j;i++)  
                {  
                    printf("%s\t",column[i]);  
                }  
                printf("\n");  
                while(sql_row=mysql_fetch_row(result))//獲取具體的數據  
                {  
                    for(i=0;i<j;i++)  
                    {  
                        printf("%s\t",sql_row[i]);  
                    }  
                    printf("\n");  
                }  
                  
            }  
        }  
        else  
        {  
            perror("select");  
        }  
    }  
    else  
    {  
        perror("connect:error");  
    }  
    mysql_free_result(MYSQL_RES *result);//釋放結果資源  
    mysql_close(&my_connection);//斷開鏈接  
  
}  
View Code

 

時間:數組

root@corleone:/opt/code/testC++/test/test5/test# ./mysql 

firstTime is: 1547606246
共1485729個記錄,每一個記錄23字段
secodnTime is: 1547606249
remainTime is: 3
相關文章
相關標籤/搜索