#include <mysql.h>
#include <stdio.h>
main() {
MYSQL *conn;
MYSQL_RES *res;
MYSQL_ROW row; char *server = "localhost";
char *user = "root";
char *password = "123456"; /* 此处改成你的密码 */
char *database = "aaa";
char sql[200] ;
conn = mysql_init(NULL); /* Connect to database */
if (!mysql_real_connect(conn, server,
user, password, database, 0, NULL, 0)) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
if (!mysql_set_character_set(conn,"utf8")){
printf("New client character set is error \n");
}
sprintf(sql,"insert into lijin values('huang','2008-11-10',30)");
/*这样插入数据库能成功/
if(mysql_query(conn,sql)){
fprintf(stderr,"%s\n",mysql_error(conn));
exit(1);
}
sprintf(sql,"select * from lijin");
if(mysql_query(conn,sql)){
fprintf(stderr,"%s\n",mysql_error(conn));
exit(1);
} res = mysql_use_result(conn); /* output table name */
printf("MySQL Tables in mysql database:\n");
while ((row = mysql_fetch_row(res)) != NULL)
printf("%s,%s \n", row[0],row[1]); /* close connection */
mysql_free_result(res);
mysql_close(conn);
}上面有这样的一条语句:
sprintf(sql,"insert into lijin values('huang','2008-11-10',30)");
这样插入数据库能成功,也能查出来.但是我改为汉字,sprintf(sql,"insert into lijin values('黄','2008-11-10',30)");
也能插入,但是不能查出"黄"这个值,我的mysql 数据库的编码格式是utf8,如何改请帮帮小弟弟.
#include <stdio.h>
main() {
MYSQL *conn;
MYSQL_RES *res;
MYSQL_ROW row; char *server = "localhost";
char *user = "root";
char *password = "123456"; /* 此处改成你的密码 */
char *database = "aaa";
char sql[200] ;
conn = mysql_init(NULL); /* Connect to database */
if (!mysql_real_connect(conn, server,
user, password, database, 0, NULL, 0)) {
fprintf(stderr, "%s\n", mysql_error(conn));
exit(1);
}
if (!mysql_set_character_set(conn,"utf8")){
printf("New client character set is error \n");
}
sprintf(sql,"insert into lijin values('huang','2008-11-10',30)");
/*这样插入数据库能成功/
if(mysql_query(conn,sql)){
fprintf(stderr,"%s\n",mysql_error(conn));
exit(1);
}
sprintf(sql,"select * from lijin");
if(mysql_query(conn,sql)){
fprintf(stderr,"%s\n",mysql_error(conn));
exit(1);
} res = mysql_use_result(conn); /* output table name */
printf("MySQL Tables in mysql database:\n");
while ((row = mysql_fetch_row(res)) != NULL)
printf("%s,%s \n", row[0],row[1]); /* close connection */
mysql_free_result(res);
mysql_close(conn);
}上面有这样的一条语句:
sprintf(sql,"insert into lijin values('huang','2008-11-10',30)");
这样插入数据库能成功,也能查出来.但是我改为汉字,sprintf(sql,"insert into lijin values('黄','2008-11-10',30)");
也能插入,但是不能查出"黄"这个值,我的mysql 数据库的编码格式是utf8,如何改请帮帮小弟弟.
SET NAMES UTF8
试试