Ubuntu10.04下C连接mysql数据库
来源:互联网 发布:淘宝图片版权保护 编辑:程序博客网 时间:2024/06/04 18:56
关于linux下用C连MySQL接数据的文章,看了不少,亲自试过,有的成功,有的失败,现总结如下:
1.安装mysql-server,在Ubuntu10.04下安装mysql-server-5.1,会自动安装mysql-client_5.1
sudo apt-get install mysql-server-5.1
2.C APIs包含在mysqlclient库文件中与MySQL的源代码一块发行,用于连接到数据库和执行数据库查询,因此需要安装libmysqlclient-dev
sudo apt-get install libmysqlclient-dev
假定已安装成功,相关文件如下:
头文件在/usr/include/mysql目录下;
库文件在/usr/lib/mysql和/usr/lib目录下
3.启动和关闭mysql
启动mysql:sudo start mysql
关闭mysql:sudo stop mysql
使用ps aux |grep mysql 查看mysql启动状态
ps命令用于查看当前系统中运行的进程信息,命令格式:ps [选项]
常见参数:
-a 显示系统中所有进程,包括其他用户进程
-e 显示所有进程信息
-f 显示进程的所有信息
-l 显示长格式显示进程的信息
-r 只显示正在运行的程序
-u 以用户的格式显示进程信息
-x 显示所有终端上的进程信息
最常用的方法是ps aux,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。例如前面使用的ps aux |grep mysql
4.链接库时需要库文件,有静态库文件,也有动态库文件,也有名字相同的静态库文件和动态库文件,如何区分:
.o,.a,.so,.lo,.la后缀文件含义
.o: 编译的目标文件
.a: 静态库,其实就是把若干o文件打了个包
.so: 动态链接库(共享库)
.lo: 使用libtool编译出的目标文件,其实就是在o文件中添加了一些信息
.la: 使用libtool编译出的库文件,其实是个文本文件,记录同名动态库和静态库的相关信息
la只有在用libtool编译应用程序或库时才用,即开发者只指明la文件,至于最终链接a还是so由libtool决定,不使用libtool的小程序用不上la。
5.连接MySql
a、连接到本机上的MYSQL:
首先打开终端窗口,再键入命令mysql -u root -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入
到MYSQL中了,MYSQL的提示符是:mysql>
b.修改密码,格式:mysqladmin -u用户名 -p旧密码 password 新密码
例1:给root加个密码ab12。首先打开终端窗口,然后键入以下命令:mysqladmin -uroot password ab12.(注:因为开始时root没有密码,所以-p旧密码一项就可以省略了)。
例2:再将root的密码改为djg345。 mysqladmin -uroot -pab12 password djg345 (注:u与root可以不用加空格,其它也一样)。
c、退出MYSQL命令: exit
6.增加新用户(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)
格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。
首先用以root用户连入MYSQL,然后键入以下命令:grant select,insert,update,delete privileges on *.* to "test1"@"%" Identified by "abc" with grant option; 但例1增加的用户是十分危险的,
你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。
例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),
这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。
grant select,insert,update,delete on mydb.* to test2@localhost identified by “abc”;如果你不想test2有密码,可再打一个命令将密码消掉。
grant select,insert,update,delete on mydb.* to test2@localhost identified by “”;
1.安装mysql-server,在Ubuntu10.04下安装mysql-server-5.1,会自动安装mysql-client_5.1
sudo apt-get install mysql-server-5.1
2.C APIs包含在mysqlclient库文件中与MySQL的源代码一块发行,用于连接到数据库和执行数据库查询,因此需要安装libmysqlclient-dev
sudo apt-get install libmysqlclient-dev
假定已安装成功,相关文件如下:
头文件在/usr/include/mysql目录下;
库文件在/usr/lib/mysql和/usr/lib目录下
3.启动和关闭mysql
启动mysql:sudo start mysql
关闭mysql:sudo stop mysql
使用ps aux |grep mysql 查看mysql启动状态
ps命令用于查看当前系统中运行的进程信息,命令格式:ps [选项]
常见参数:
-a 显示系统中所有进程,包括其他用户进程
-e 显示所有进程信息
-f 显示进程的所有信息
-l 显示长格式显示进程的信息
-r 只显示正在运行的程序
-u 以用户的格式显示进程信息
-x 显示所有终端上的进程信息
最常用的方法是ps aux,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。例如前面使用的ps aux |grep mysql
4.链接库时需要库文件,有静态库文件,也有动态库文件,也有名字相同的静态库文件和动态库文件,如何区分:
.o,.a,.so,.lo,.la后缀文件含义
.o: 编译的目标文件
.a: 静态库,其实就是把若干o文件打了个包
.so: 动态链接库(共享库)
.lo: 使用libtool编译出的目标文件,其实就是在o文件中添加了一些信息
.la: 使用libtool编译出的库文件,其实是个文本文件,记录同名动态库和静态库的相关信息
la只有在用libtool编译应用程序或库时才用,即开发者只指明la文件,至于最终链接a还是so由libtool决定,不使用libtool的小程序用不上la。
5.连接MySql
a、连接到本机上的MYSQL:
首先打开终端窗口,再键入命令mysql -u root -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入
到MYSQL中了,MYSQL的提示符是:mysql>
b.修改密码,格式:mysqladmin -u用户名 -p旧密码 password 新密码
例1:给root加个密码ab12。首先打开终端窗口,然后键入以下命令:mysqladmin -uroot password ab12.(注:因为开始时root没有密码,所以-p旧密码一项就可以省略了)。
例2:再将root的密码改为djg345。 mysqladmin -uroot -pab12 password djg345 (注:u与root可以不用加空格,其它也一样)。
c、退出MYSQL命令: exit
6.增加新用户(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)
格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"
例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。
首先用以root用户连入MYSQL,然后键入以下命令:grant select,insert,update,delete privileges on *.* to "test1"@"%" Identified by "abc" with grant option; 但例1增加的用户是十分危险的,
你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。
例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),
这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。
grant select,insert,update,delete on mydb.* to test2@localhost identified by “abc”;如果你不想test2有密码,可再打一个命令将密码消掉。
grant select,insert,update,delete on mydb.* to test2@localhost identified by “”;
例3、远程登录:
a、默认情况下Mysql只允许本地登录,所以需要修改配置文件将地址绑定给注释掉:
vi /etc/mysql/my.cnf
# Instead of skip-networking the default is now to listen only on
# localhost which is more compatible and is not less secure.
#bind-address = 127.0.0.1 <---注释掉这一行就可以远程登录了
b、允许远程登录后,还应设置远程登录权限:
mysql>grant all privileges on *.* to "root"@"%" identified by "123456" with grant option;
c、使修改生效:
mysql> flush privileges;
d、在另一台机器上远程登录(mysql所在机器地址:192.168.0.30):
mysql -h192.168.0.30 -uroot -p123456
e、如果仍不能登录,就把远程mysql关闭,之后重启
sudo stop mysql
sudo start mysql
7.显示命令:(注:下面来看看MYSQL中有关数据库方面的操作。注意:必须首先登录到MYSQL中,以下操作都是在MYSQL的提示符下进行的,而且每个命令以分号结束)。
a、显示数据库列表:show databases; 刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
b、显示库中的数据表:use mysql; show tables;
c、显示数据表的结构:describe 表名;
d、建库: create database 库名;
e、建表: use 库名; create table 表名 (字段设定列表);
f、删库和删表: drop database 库名; drop table 表名;
g、将表中记录清空:delete from 表名;
h、显示表中的记录:select * from 表名;
8.编写c代码,文件名:mysql.c
//gcc mysql.c -o test -I /usr/include/mysql -L /usr/lib -lmysqlclient
#include
#include
#include
int main()
{
MYSQL mysql;
MYSQL_RES *res;
MYSQL_ROW row;
char sql[50];
int t;
sprintf(sql,"select * from Student"); // 定义执行的SQL语句 这里是test数据库里的Student表
mysql_init(&mysql); //初始化mysql结构
if(!mysql_real_connect(&mysql,"localhost","root","123456","test",3306,NULL,0))
printf("\n数据库连接发生错误: %s\n",mysql_error(&mysql));
else
printf("\n数据库连接成功!\n");
t = mysql_real_query(& mysql, sql, (unsigned int)strlen(sql)); //在服务器上执行定义的SQL语句
if(t)
printf("查询语句错误: %s\n",mysql_error(&mysql));
else
{
res = mysql_store_result(&mysql);
while(row = mysql_fetch_row(res))
{
for(t = 0; t < mysql_num_fields(res); t++)
printf("%s",row[t]);
printf("\n");
}
}
printf("释放结果集的空间...\n");
mysql_free_result(res);
mysql_close(&mysql); //释放数据库
printf("sql errror! %s\n",mysql_error(&mysql)); //如果发生错误打印错误代码
return 0;
}
编译 :gcc -c mysql.c -I /usr/include/mysql/ 这里的-I 是指定头文件目录 -c 是编译成目标代码
连接 :gcc mysql.o -o test -L /usr/lib/ -lmysqlclient 这里的-L是指定库文件路径 这个参数-lmysqlclient是因为 C API代码包含在mysqlclient库中,正因为有了它才允许C程序访问数据库。
7.显示命令:(注:下面来看看MYSQL中有关数据库方面的操作。注意:必须首先登录到MYSQL中,以下操作都是在MYSQL的提示符下进行的,而且每个命令以分号结束)。
a、显示数据库列表:show databases; 刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。
b、显示库中的数据表:use mysql; show tables;
c、显示数据表的结构:describe 表名;
d、建库: create database 库名;
e、建表: use 库名; create table 表名 (字段设定列表);
f、删库和删表: drop database 库名; drop table 表名;
g、将表中记录清空:delete from 表名;
h、显示表中的记录:select * from 表名;
8.编写c代码,文件名:mysql.c
//gcc mysql.c -o test -I /usr/include/mysql -L /usr/lib -lmysqlclient
#include
#include
#include
int main()
{
MYSQL mysql;
MYSQL_RES *res;
MYSQL_ROW row;
char sql[50];
int t;
sprintf(sql,"select * from Student"); // 定义执行的SQL语句 这里是test数据库里的Student表
mysql_init(&mysql); //初始化mysql结构
if(!mysql_real_connect(&mysql,"localhost","root","123456","test",3306,NULL,0))
printf("\n数据库连接发生错误: %s\n",mysql_error(&mysql));
else
printf("\n数据库连接成功!\n");
t = mysql_real_query(& mysql, sql, (unsigned int)strlen(sql)); //在服务器上执行定义的SQL语句
if(t)
printf("查询语句错误: %s\n",mysql_error(&mysql));
else
{
res = mysql_store_result(&mysql);
while(row = mysql_fetch_row(res))
{
for(t = 0; t < mysql_num_fields(res); t++)
printf("%s",row[t]);
printf("\n");
}
}
printf("释放结果集的空间...\n");
mysql_free_result(res);
mysql_close(&mysql); //释放数据库
printf("sql errror! %s\n",mysql_error(&mysql)); //如果发生错误打印错误代码
return 0;
}
编译 :gcc -c mysql.c -I /usr/include/mysql/ 这里的-I 是指定头文件目录 -c 是编译成目标代码
连接 :gcc mysql.o -o test -L /usr/lib/ -lmysqlclient 这里的-L是指定库文件路径 这个参数-lmysqlclient是因为 C API代码包含在mysqlclient库中,正因为有了它才允许C程序访问数据库。
0
上一篇:ubuntu下添加开机自动启动程序
下一篇:linux下粘滞位引出的SUID和SGID
相关热门文章
- MyBatis 入门(四)--链表查询...
- APP开发流程,你知道多少...
- hive 连接客户端 SQuirrel SQ...
- ZIP压缩算法详细分析及解压实...
- mysql: blocked because of ma...
- A sample .exrc file for vi e...
- IBM System p5 服务器 HACMP ...
- 游标的特征
- DB2 9 应用开发(733 考试)认...
- busybox的httpd使用CGI脚本(Bu...
- linux dhcp peizhi roc
- 关于Unix文件的软链接
- 求教这个命令什么意思,我是新...
- sed -e "/grep/d" 是什么意思...
- 谁能够帮我解决LINUX 2.6 10...
给主人留下些什么吧!~~
评论热议
0 0
- Ubuntu10.04下C连接mysql数据库
- Ubuntu10.04下C连接mysql数据库
- ubuntu10.10下qt连接mysql数据库
- 详解Ubuntu10.10下Qt连接Mysql数据库
- linux下c语言连接mysql数据库
- CentOS下的C连接Mysql数据库
- Linux下C连接MySQL数据库方法
- Linux下C连接MySQL数据库
- Ubuntu 10.04 下 C 连接mysql数据库
- Ubuntu下C连接mysql数据库
- Linux 下 C语言连接MYSQL数据库
- Linux下C连接MySQL数据库方法
- CentOS下的C连接MySQL数据库
- VS2010环境下 用MySQL Connector C 连接 MySql数据库
- VS2010环境下 用MySQL Connector C 连接 MySql数据库
- c连接mysql数据库
- c连接mysql数据库
- c 连接mysql数据库
- 通过管道和重定向实现linux管道命令
- Servlet(1)web开发入门
- linux(ubuntu)下外接投影仪或着显示器的方法
- ubuntu下添加开机自动启动程序
- 0410
- Ubuntu10.04下C连接mysql数据库
- oracle误删数据恢复方法
- linux下粘滞位引出的SUID和SGID
- 静默安装Oracle数据库10g篇
- 二维数组中的查找
- 华为网络笔试题
- Keyboard Row
- ADB Interface 驱动安装失效
- 向IPC进发
原创粉丝点击
热门IT博客
热门问题
老师的惩罚
人脸识别
我在镇武司摸鱼那些年
重生之率土为王
我在大康的咸鱼生活
盘龙之生命进化
天生仙种
凡人之先天五行
春回大明朝
姑娘不必设防,我是瞎子
上海环贸广场
环贸iapm商场
环贸中心
环贸
北京二环路
成都环路
北京环路
无锡北环路
北京五环路
沈阳环路
合肥三环路
西安三环路
沈阳四环路
三环路
环路定理
西安二环路
沈阳一环路
合肥四环路
成都五环路
沈阳二环路
合肥二环路
东外环路
三环路口
成都六环路
东环路街道
环路
内环路
石家庄三环路
成都市四环路
福州四环路规划图
贵阳一环路示意图
成都三环路全长
营山县一环路
沈阳环路公交车路线
成都二环路全长
一环路北三段
环路公交车路线
环跳
环跳疼痛
环跳的准确位置图和作用
环跳的准确位置图