免费注册 查看新帖 |

Chinaunix

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

自己写的一个mysql C API 小型封装 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-03-21 13:55 |只看该作者 |倒序浏览
主要用于维护C结构的查询和返回。



#include <mysql/mysql.h>

typedef        std::string        string;

struct        mysql_parm{
        string        host;
        string        user;
        string        password;
        string        database;
        string        unixsock;
};
class        DBSTMT;
class        DBMysql;

class        DBSTMT{
        DBSTMT(const DBSTMT&);
        DBSTMT&        operator=(const DBSTMT&);
        MYSQL_STMT*        stmt_;
public:
        DBSTMT(pcsz_t        query,DBMysql&        mysql);
        void        execute(){
                if(mysql_stmt_execute(stmt_))
                        throw        mysql_stmt_error(stmt_);
        }

        void        execute(MYSQL_BIND* bind){
                if(mysql_stmt_execute(stmt_))
                        throw        mysql_stmt_error(stmt_);
                if(mysql_stmt_bind_result(stmt_,bind)){
                        throw        mysql_stmt_error(stmt_);
                }
                if(mysql_stmt_store_result(stmt_))
                        throw        mysql_stmt_error(stmt_);
        }

        //void        execute(){
        //        if(mysql_stmt_execute(stmt_))
        //                throw        mysql_stmt_error(stmt_);
        //}

        void        bind(MYSQL_BIND* bind){
                if(mysql_stmt_bind_param(stmt_,bind) )
                        throw        mysql_stmt_error(stmt_);
        }

        int        fetch(){
                return        mysql_stmt_fetch(stmt_)==0;
        }
        ~DBSTMT(){
                if(stmt_){
                        mysql_stmt_close(stmt_);
                }
        }

};


class        DBMysql{
        DBMysql(const DBMysql&);
        DBMysql&operator=(const DBMysql&);
        MYSQL        *        mysqlPtr_;

        uint32_t        errno_;
protected:
        friend        class        DBSTMT;
        MYSQL_STMT*        _createSTMT(){
                MYSQL_STMT        *ret=mysql_stmt_init(mysqlPtr_);
                if(ret)
                        return        ret;
                errno_=mysql_errno(mysqlPtr_);
                throw        mysql_error(mysqlPtr_);
        }
public:
        const        char*        strerr(){
                return        mysql_error(mysqlPtr_);
        }
        DBMysql():mysqlPtr_(NULL){
                mysqlPtr_=mysql_init(NULL);
                if(NULL== mysqlPtr_)
                        throw        "Mysql :outof memory";
        }
        void        open(const        mysql_parm& parm){
                if(!mysql_real_connect(mysqlPtr_,
                        parm.host.c_str(),
                        parm.user.c_str(),
                        parm.password.c_str(),
                        parm.database.c_str(),
                        0,
                        parm.unixsock.c_str(),
                        0        ))
                {
                        errno_=mysql_errno(mysqlPtr_);
                        throw(mysql_error(mysqlPtr_));
                }
        }

        void        close(){
                if(mysqlPtr_)
                {
                        mysql_close(mysqlPtr_);
                        mysqlPtr_=NULL;
                }
        }

};


DBSTMT::DBSTMT(pcsz_t        query,DBMysql&        mysql):stmt_(NULL){
        stmt_=mysql._createSTMT();
        if(!stmt_)
                throw        mysql.strerr();
        if( mysql_stmt_prepare(stmt_,query,strlen(query)) )
        {
                //const char*        err=

                throw        mysql_stmt_error(stmt_);
        }

}

#define        DECL_BIND(h,n)\
class bind_##h:public        h{\
        typedef        h        parent;\
        MYSQL_BIND                _bind[n];\
        my_bool                        _is_null[n];\
        unsigned        long        _length[n];\
public:\
        bind_##h(){\
        int        i=0;\
        bzero(_bind,sizeof(_bind));


#define        BIND_BIN(x,l)\
        _bind[i].buffer_type= MYSQL_TYPE_STRING;\
        _bind[i].buffer= (char *)&(parent::x);\
        _bind[i].buffer_length= l;\
        _bind[i].is_null= _is_null+i;\
        _bind[i].length= _length+i;\
        ++i;

#define        BIND_INT(x)\
        _bind[i].buffer_type= MYSQL_TYPE_LONG;\
        _bind[i].buffer= (char *)&(parent::x);\
        _bind[i].buffer_length= 0;\
        _bind[i].is_null= _is_null+i;\
        _bind[i].length= _length+i;\
        ++i;

#define        END_BIND(h)                }\
        operator        MYSQL_BIND*(){\
        return        _bind;\
        }\
};





使用方法;

例如想查询的内容具有以下结构
struct account{
        char        user[36];
        byte        password[16];
        uint32_t        status;
        uint32_t        id;
};

//声明查询bind 结构account,参数4个
DECL_BIND(account,4)
        BIND_BIN(user,32)
        BIND_BIN(password,16)
        BIND_INT(status)
        BIND_INT(id)
END_BIND(account)

int main(){

        try{
               
                DBMysql        mysql;
                mysql_parm        parm;
                parm.host="localhost";
                parm.user="root";
                parm.password="test";
                parm.unixsock="/var/lib/mysql/mysql.sock";
                parm.database="testdb";
                mysql.open(parm);//打开数据库
               
                DBSTMT        smt("select user,password,status,id from account",mysql);//生成一个查询语法
                DBSTMT        smt1("insert into account(user,password,status) value(?,?,?)",mysql);//另外一个
        //
               
                bind_account        acc;
               


                smt.execute(acc);//执行查询,并bind返回结果到account结构               
                while(smt.fetch()){
                printf("%s %d %d\n",acc.user,acc.status,acc.id);
                       
                };

                smt1.bind(acc);//bind查询参数
                smt1.execute();//执行
               
               
               
        }catch(const char* err){
                printf("error:%s\n",err);
        }

}

[[i] 本帖最后由 yejr 于 2006-3-21 14:10 编辑 [/i]]

论坛徽章:
0
2 [报告]
发表于 2006-03-21 14:09 |只看该作者
lz稍微整理一下吧,都被转换成表情了

论坛徽章:
0
3 [报告]
发表于 2006-03-28 16:19 |只看该作者
我也看得头晕

论坛徽章:
0
4 [报告]
发表于 2006-03-28 18:27 |只看该作者
C还是C++

论坛徽章:
0
5 [报告]
发表于 2006-03-28 18:51 |只看该作者
牛,学学

论坛徽章:
0
6 [报告]
发表于 2006-03-31 16:11 |只看该作者
使用的是mysql c api
实现为c++类和宏

论坛徽章:
0
7 [报告]
发表于 2006-04-04 17:27 |只看该作者
这个api对特殊字符,例如单引号,'\',等做处理了吗?

论坛徽章:
0
8 [报告]
发表于 2006-04-06 16:51 |只看该作者
这个是参数传递的,不需要处理特殊符号

论坛徽章:
0
9 [报告]
发表于 2006-04-23 13:45 |只看该作者
php 中的代码才值得参考

论坛徽章:
0
10 [报告]
发表于 2006-08-03 15:31 |只看该作者
可是我按照一般的编译方法编译你这个程序总是出错,我的编译方法如下:
#CFG=/usr/local/mysql/bin/mysql_config
#sh -c "g++ -o test `$CFG --cflags` test.cpp `$CFG --libs`"

不知道你是如何编译的。谢谢告知!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP