1. [代码][C/C++]代码

#include <mysql/mysql.h>
#include <stdio.h>
#include <string.h>
int main()
{
    MYSQL mysql;//连接数据库的变量
    MYSQL_RES *res;//存放查询结果的变量
    MYSQL_ROW row;
    char *query;
    int t,r;
    char *server= "localhost";
    char *user = "root";
    char *password="test";
    char *database = "test";
    mysql_init(&mysql); //连接数据库前,必须调用此函数初始化变量
    /**
     * MYSQL *mysql_init(MYSQL *mysql)
     * 传入MYSQL类型的指针
     * 返回一个被初始化的MYSQL*句柄
     * 在内存不够的情况下,返回NULL
     */
    if(!mysql_real_connect(&mysql,server,user,password,database,0/*TCP IP端口*/,NULL/*Unix socket连接类型*/,0/*运行成ODBC数据库的标记*/))
    {
        printf("Error connection to database:%s/n",mysql_error(&mysql));
    }else
        printf("Connected.../n");
    query = "select * from t1";
    printf("query execute:%s/n",query);
    t = mysql_real_query(&mysql,query,(unsigned int) strlen(query));
    /**
     *
     * int STDCALL mysql_real_query(MYSQL *mysql,const char *q, unsigned int length);
     * 执行任何SQL查询语句进行查询。
     * mysql是我们前面用过的变量,q是SQL查询语句,length是这个查询语句的长度。
     */
    if(t)
    {
        printf("Error making query:%s/n",mysql_error(&mysql));
    }else
        printf("[%s] made.../n",query);
    res = mysql_store_result(&mysql);
    /**
     * mysql_store_result(MYSQL *mysql)
     * 立刻检索全部结果
     *
     * mysql_use_result(MYSQL *mysql)
     * 初始化一个一行一行地结果集合的检索
     */
    while(row = mysql_fetch_row(res))
    {
        /**
         * MYSQL_ROW STDCALL mysql_fetch_row(MYSQL_RES *result);
         * 检索行
         */
        for(t=0;t<=mysql_num_fields(res);t++)
        {
            printf("%s",row[t]);
        }
        printf("/n");
    }
    printf("mysql_free_result.../n");
    mysql_free_result(res);
    /**
     * mysql_free_result()
     * 释放由它使用的内存。
     */
    sleep(1);
    //execute the insert query
    query = "insert into t1(id,name) values(3,'kunp')";
    t = mysql_real_query(&mysql,query,(unsigned int) strlen(query));
    if(t)http://www.huiyi8.com/hunsha/hanshi/
    {韩式婚纱照片
        printf("Error making query:%s/n",query);
        mysql_error(&mysql);
    }
    else printf("[%s] made.../n",query);
    mysql_close(&mysql);
    /**
     * void mysql_close(MYSQL *mysql)
     * 传入MYSQL类型的指针
     * 功能,关闭一个服务器连接,并释放与连接相关的内存i
     */
    return 1;
}
//编译:gcc testsql.c -I/usr/include/mysql -L/usr/lib/mysql -lmysqlclient -o testsql
2. [代码][C/C++]代码   
#include <stdlib.h>
#include <stdio.h>
#include <mysql/mysql.h>
int main(void){
MYSQL_RES *res_ptr;
MYSQL_ROW sqlrow;
MYSQL *conn_ptr;
int result;//query result
int iTableRow,iTableCol,i,j;
 conn_ptr = mysql_init(NULL);
 if (!conn_ptr)
 {
        fprintf(stderr,"mysql_init failed!\n");
         return (-1);
 }
 conn_ptr = mysql_real_connect(conn_ptr,"127.0.0.1","root","123456","mysql",3306,0,NULL);
 if (conn_ptr)
 {
         printf ("connection succeed!\n");
 }
 else{
         printf ("connection failed!\n");
        return (-2);
 }
result = mysql_query(conn_ptr,"select * from test.tbl_user");
if(result){
        printf(stderr,"select error %d: %s !\n",mysql_errno(conn_ptr),mysql_error(conn_ptr));//
        return EXIT_FAILURE;
}
res_ptr = mysql_store_result(conn_ptr);//集合
if( res_ptr )
        {
            iTableRow = mysql_num_rows(res_ptr);//行
            iTableCol = mysql_num_fields(res_ptr);//列
            for(i=0; i<iTableRow; i++)
            {
              sqlrow = mysql_fetch_row(res_ptr);
              for(j=0; j<iTableCol; j++)
              {
                printf("%-8s  ",sqlrow[j]);//字符串向左靠,右补空格
              }
              printf("\n");
            }
 mysql_free_result(res_ptr);//完成对数据的所有操作后,调用此函数来让MySQL库清理它分配的对象
  mysql_close(conn_ptr);
 
 printf ("connection close!\n");
 return 0;
 }
 
 编译:gcc -o mydbcon -I /usr/include/mysql/ -L /usr/lib/mysql -lmysqlclient mysql.c
 
 运行:./mydbcon

C/C++连接查询MYSQL的更多相关文章

  1. Mysql 连接查询 Mysql支持的连接查询有哪些

    CREATE TABLE `chx` (   `id` VARCHAR(20) NOT NULL,   `name` VARCHAR(50) DEFAULT NULL,   `name2` CHAR( ...

  2. [Go] golang连接查询mysql

    package main import ( "database/sql" _ "github.com/go-sql-driver/mysql" "lo ...

  3. mysql的查询、子查询及连接查询

    >>>>>>>>>> 一.mysql查询的五种子句         where(条件查询).having(筛选).group by(分组). ...

  4. MySql学习(三) —— 子查询(where、from、exists) 及 连接查询(left join、right join、inner join、union join)

    注:该MySql系列博客仅为个人学习笔记. 同样的,使用goods表来练习子查询,表结构如下: 所有数据(cat_id与category.cat_id关联): 类别表: mingoods(连接查询时作 ...

  5. mysql连接查询,封装mysql函数

    连接查询 交叉连接语法: select  * | 字段列表 from 表1  cross join 表2 内连接: select *|字段列表 from 左表 inner join 右表 on 左表. ...

  6. MySql的连接查询

    类似于oracle的连接查询,mysql连接查询也有左外连接.右外连接.内连接查询.但是,不同的是没有直接 的全外连接查询. 这里介绍MySql的连接查询: 这里已两张表为例:STUDENT 表 和 ...

  7. mysql连接查询经典小例题

    mysql连接查询: Mysql连接查询支持多表连接 对同一张表可以重复连接多次(别名在多次连接同一张表时很重要) 例题1: 下面有2张表 teams表 比赛结果表:result 问题: 得出一张表: ...

  8. MySQL查询优化:连接查询排序limit

    MySQL查询优化:连接查询排序limit(join.order by.limit语句) 2013-02-27      个评论       收藏    我要投稿   MySQL查询优化:连接查询排序 ...

  9. 4.mysql数据库创建,表中创建模具模板脚本,mysql_SQL99标准连接查询(恩,外部连接,全外连接,交叉连接)

     mysql数据库创建,表创建模等模板脚本 -- 用root用户登录系统,运行脚本 -- 创建数据库 create database mydb61 character set utf8 ; -- ...

随机推荐

  1. struts2学习笔记2 -struts2的开发步骤和工作原理

    struts2的开发步骤: 1.先定义一个能发送请求的页面,可以是链接,也可以是表单(form) 2.开发action类,struts2对action并没有过多的要求,只要求: a 推荐实现actio ...

  2. js:Razor视图下服务器代码给Javascript变量赋值

    namespace Razor.Controllers { public class JSController : Controller { public ActionResult Index() { ...

  3. delphi 解析Json格式(转自:http://blog.csdn.net/jayqiang/article/details/7066824)

    SuperObject 是开源的 Delphi 的 JSON 工具包,可生成 JSON 数据以及进行 JSON 解析. unit Unit6; interface uses Windows, Mess ...

  4. golang生成随机函数的实现

    golang生成随机数可以使用math/rand包, 示例如下: package main import ( "fmt" "math/rand" ) func ...

  5. JavaScript -- JavaScript高级程序设计

    /* 基本类型 Undefined, Null, Boolean, Number, String. 复杂类型 Object 它是所有对象的基础类型. 引用类型 Object 创建:new Ojbect ...

  6. shell 获取当前svn代码目录版本号

    在当前svn代码目录下执行以下命令: svn info | grep "Last Changed Rev:" | awk -F ': ' '{print $2}' > svn ...

  7. git 工具 - 子模块(submodule)

    From: https://git-scm.com/book/zh/v2/Git-%E5%B7%A5%E5%85%B7-%E5%AD%90%E6%A8%A1%E5%9D%97 子模块 有种情况我们经常 ...

  8. php中的字符串和正則表達式

    一.字符串类型的特点 1.PHP是弱类型语言,其它数据类型一般都能够直接应用于字符串函数操作. 1: <? php 2: echo substr("123456",2,4); ...

  9. jQuery+bootstrap实现美化警告/确认/提示对话框插件

    http://www.html580.com/12067/demo http://craftpip.github.io/jquery-confirm/

  10. Unix环境高级编程第三版中实例代码如何在自己的linux上运行的问题

    学习Linux已经有2个月了,最近被期末考试把进度耽误了,前几天把Unix环境高级编程看了两章,感觉对Linux的整体有了一些思路,今天尝试着对第一章涉及到的一个简单的交互式shell编译运行一下,结 ...