在mysql数据库插入中文及中文查询实例教程
来源:易贤网 阅读:961 次 日期:2015-12-10 11:53:38
温馨提示:易贤网小编为您整理了“在mysql数据库插入中文及中文查询实例教程”,方便广大网友查阅!

//我修改之,能正常运行,测试环境为mysql5.0,xp

//关键是设置对字符集,设置gbk,gb2312测试通过,utf8测试未通过

//在运行程序前先建立数据库jj,注意下面几个参数(修改为你自己的)

// char *host = "localhost";

// char *user = "root";

// char *pass = "674800";

// char *db = "jj";

#include <windows.h>

#include <iostream>

#include <mysql.h>

#include <stdio.h>

#include <string.h>

using namespace std;

#pragma comment(lib,"libmysql.lib")

int connDB();

int create_table();

int insert_table();

int select_table();

int disconnDB();

MYSQL *mysql;

MYSQL_RES *res;

MYSQL_FIELD * fd;

MYSQL_ROW row;

char szSqlText[500]="";

int i;

int main()

{

connDB();

// create_table();

insert_table();

select_table();

disconnDB();

return 0;

}

///////////////子函数

int connDB()//连接数据库

{

char *host = "localhost";

char *user = "root";

char *pass = "674800";

char *db = "jj";

mysql = mysql_init((MYSQL*) 0);

mysql_real_connect( mysql, host, user, pass, db,3306, NULL, 0 ) ; //链接到服务器

mysql_set_character_set(mysql,"gb2312"); //设置字符集

cout<<"conn OK!"<<endl;

return 0;

}

//关闭数据库

int disconnDB()

{

mysql_close( mysql ) ;

cout<<"disconn OK!"<<endl;

return 0 ;

}

//创建表

int create_table()

{

mysql_set_character_set(mysql,"gb2312");

sprintf(szSqlText, \

"create table mytable \

(s0 varchar(100), \

s1 char(6),\

s2 varchar(4),\

s3 varchar(3),s4 int)\

ENGINE=InnoDB \

DEFAULT CHARSET=gb2312");

if(mysql_query( mysql, szSqlText))

cout<<"occurred an error:"<<mysql_error(mysql)<<endl;

return 0;

}

int insert_table()

{

mysql_set_character_set(mysql,"gb2312");

sprintf(szSqlText,

"insert into mytable\

values('2000-3-10 21:01:30',\

'Test',\

'清风寒剑',\

'岁月情',\

2500)");

if( mysql_query( mysql, szSqlText) )

cout<<"occurred an error:"<<mysql_error(mysql)<<endl;

return 0;

}

int select_table()

{

mysql_set_character_set(mysql,"gb2312");

sprintf(szSqlText, "select * from mytable ");

if (mysql_query( mysql, szSqlText))

{

cout<<"occurred an error:"<<mysql_error(mysql)<<endl;

mysql_close( mysql ) ;

return FALSE ;

}

res = mysql_store_result( mysql) ;

i = (int) mysql_num_rows( res ) ;

cout<<"Query: "<<szSqlText<<"\n"<<i<<" records found:"<<endl;

for ( i = 0 ; fd = mysql_fetch_field( res ) ; i++ )

cout<<fd->name<<"\t";

cout<<endl;

while(row = mysql_fetch_row( res ))

cout<<row[0]<<"\t"<<row[1]<<"\t"<<row[2]<<"\t"<<row[3]<<"\t"<<row[4]<<endl;

mysql_free_result( res ) ;

cout<<"select OK!"<<endl;

return 0;

}

更多信息请查看IT技术专栏

更多信息请查看数据库
由于各方面情况的不断调整与变化,易贤网提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:易贤网
云南网警报警专用图标