mysql c操作函数

#include <winsock.h> 
#include <mysql.h> //绝对路径

MYSQL *sql;

MYSQL_RET res;

MYSQL_ROW row;

 


sql=mysql_init(0);//初始化
 if(sql)
       MessageBox(L"Init successful");
 else{
      CString st(mysql_error(sql));
       MessageBox(st);
 }

 if(!mysql_real_connect(sql,"localhost","user","pwd","student",3306,NULL,0)) //连接数据库
      MessageBox(L"connect mysql failure");
 mysql_set_character_set(sql,"utf-8");
 const char *t=mysql_character_set_name(sql); //字符集名
 CString str(t);
 MessageBox(str);
 
 mysql_query(sql,"insert into stu(first,second) values('china-pub','famous')"); //添加
 mysql_query(sql,"insert into stu(first,second) values('beautiful','girl')");
 mysql_query(sql,"delete from stu where second='girl'");//删除
 mysql_query(sql,"update stu set first='baidudog' where first='baidu'"); //更新记录
 mysql_query(sql,"select * from stu"); //进行查询
 res=mysql_store_result(sql);
 int numreow=mysql_num_rows(res); //行数
 while(row=mysql_fetch_row(res)){  //显示

    CString tm(row[2]);
    MessageBox(tm);
 }
 mysql_free_result(res); //释放结果
 mysql_close(sql); //关闭连接

 

调用   mysql_fetch_row   就查出返回的结果集共有多少行。
这由   int   mysql_num_rows(MYSQL_RES   *result)来完成。  
改变到被下一个   mysql_fetch_row   调用返回的行
可以用void   mysql_data_seek(MYSQL_RES   *res,   uint   offset)   改变到任意一行。  
如果你执行一个UPDATE,   INSERT   或者   DELETE   查询,你可以用    
int   mysql_affected_rows   来查出共有多少行数据被你影响到。  
如果在你的数据库里有二进制数据,那么得知数据的长度将是有用的。
unsigned int   *mysql_fetch_lengths(MYSQL_RES   *mysql)   将返回一指出了结果集中每一列的长度的整型数组。  
当你插入一个带有   AUTO_INCREMENT   列的表的时候,你可以用    
  int   mysql_insert_id(MYSQL   *mysql)   来查出生成的那一行的ID。  
====================== 
通过VC开发MySQL数据库应用软件有多种方式:
一、通过MyODBC界面
二、通过Connector/C++l界面
三、通过MySQL C API界面
四、第三方封装的MySQL类

 

MySQL提供了很多函数来对数据库进行操作

第一部分 控制类函数

mysql_init()初始化MySQL对象
mysql_options()设置连接选项
mysql_real_connect()连接到MySQL数据库

mysql_real_escape_string()将查询串合法化
mysql_query()发出一个以空字符结束的查询串
mysql_real_query()发出一个查询串

mysql_store_result()一次性传送结果
mysql_use_result()逐行传送结果

mysql_free_result()释放结果集

mysql_change_user()改变用户
mysql_select_db()改变默认数据库
mysql_create_db(MYSQL*,*db)

mysql_debug()送出调试信息
mysql_dump_debug_info()转储调试信息

mysql_ping()测试数据库是否处于活动状态
mysql_shutdown()请求数据库SHUTDOWN

mysql_close()关闭数据库连接

第二部分 信息获取类函数
mysql_character_set_name()获取默认字符集
mysql_get_client_info()获取客户端信息
mysql_host_info()获取主机信息
mysql_get_proto_info()获取协议信息
mysql_get_server_info()获取服务器信息
mysql_info()获取部分查询语句的附加信息
mysql_stat()获取数据库状态

mysql_list_dbs()获取数据库列表
mysql_list_tables()获取数据表列表
mysql_list_fields()获取字段列表

第三部分 行列类操作函数
mysql_field_count()获取字段数
mysql_affected_rows()获取受影响的行数
mysql_insert_id()获取AUTO_INCREMENT列的ID值

mysql_num_fields()获取结果集中的字段数
mysql_field_tell()获取当前字段位置
mysql_field_seek()定位字段
mysql_fetch_field()获取当前字段
mysql_fetch_field_direct()获取指定字段
mysql_frtch_fields()获取所有字段的数组

 

mysql_num_rows()获取行数
mysql_fetch_lengths()获取行长度
mysql_row_tell()获取当前行位置
mysql_row_seek()行定位
mysql_data_seek()行定位
mysql_fetch_row()获取当前行


第四部分 线程类操作函数
mysql_list_processes()返回所有线程列表
mysql_thread_id()获取当前线程ID
mysql_thread_safe()是否支持线程方式
mysql_kill()杀列一个线程


第五部分 出错处理类函数
mysql_errno()获取错误号
mysql_error()获取错误信息


mysql备份命令
关键字: mysql
还原或者导入数据库命令:

mysql -u root --password=root

备份数据库命令:

mysqldump -u root --password=root --database helloworld >helloworld_backup.sql


其他用法:

1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名表名> 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc users> wcnc_users.sql
3.导出一个数据库结构
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:/wcnc_db.sql

-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table

4.导入数据库
常用source 命令
进入mysql数据库控制台,
如mysql -u root -p

mysql>use 数据库

然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:/wcnc_db.sql

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值