使用C编程语言在Linux下访问MySQL数据库。 (linux下c访问mysql)

使用C编程语言在Linux下访问MySQL数据库

MySQL是一种广泛使用的关系型数据库管理系统,具有高速、稳定、开源等优点,因而备受开发者的青睐。在Linux系统下,使用C编程语言访问MySQL数据库是一种较为常见的操作,下面将详细介绍如何在Linux操作系统下使用C编程语言访问MySQL数据库。

一、MySQL安装配置

在使用C语言访问MySQL数据库之前,需要先在Linux系统中安装和配置MySQL服务。可以通过以下步骤来安装MySQL:

1. 打开终端,使用以下命令安装MySQL:

sudo apt-get install mysql-server

2. 安装成功后,使用以下命令进入MySQL服务器:

mysql -u root -p

3. 此时会要求输入密码,输入系统密码进入MySQL管理界面。

4. 在MySQL管理界面输入以下命令创建新的用户和密码:

CREATE USER ‘newuser’@’%’ IDENTIFIED BY ‘user_password’;

其中,newuser是新的用户名,%表示所有IP地址都可以访问,user_password是新的密码,这里可以根据自己的需要设置。

5. 给新用户授权:

GRANT ALL PRIVILEGES ON *.* TO ‘newuser’@’%’;

6. 输入以下命令来使上述更改生效:

FLUSH PRIVILEGES;

这样,就可以成功创建一个新用户,并赋予它访问MySQL数据库的权限。

二、C语言访问MySQL

在安装和配置好MySQL之后,就可以使用C语言代码来访问MySQL数据库了。下面使用MySQL C API来实现C语言访问MySQL数据库的操作。

1. 安装MySQL C API

MySQL C API是MySQL提供的一套用于C/C++语言访问MySQL数据库的API接口,它可以帮助开发者轻松地实现与MySQL数据库的交互。使用以下命令可以安装MySQL C API:

sudo apt-get install libmysqlclient-dev

2. 连接MySQL数据库

使用以下代码来连接MySQL数据库:

#include

#include

int mn(){

MYSQL *conn;

conn = mysql_init(NULL);

if(!mysql_real_connect(conn, “localhost”, “newuser”,

“user_password”, NULL, 3306, NULL, 0)){

fprintf(stderr, “%s\n”, mysql_error(conn));

exit(1);

}

return 0;

}

上述代码实现了连接到名为test的MySQL数据库的操作,newuser和user_password是前面创建的新用户和密码,3306是MySQL数据库的默认端口号。

3. 查询MySQL数据库

使用以下代码来查询MySQL数据库:

#include

#include

int mn(){

MYSQL *conn;

MYSQL_RES *res;

MYSQL_ROW row;

char *server = “localhost”;

char *user = “newuser”;

char *pass = “user_password”;

char *database = “test”;

char *query = “SELECT * from table1”;

conn = mysql_init(NULL);

if(!mysql_real_connect(conn, server, user, pass, database, 0, NULL, 0)){

fprintf(stderr, “%s\n”, mysql_error(conn));

exit(1);

}

if(mysql_query(conn, query)){

fprintf(stderr, “%s\n”, mysql_error(conn));

exit(1);

}

res = mysql_use_result(conn);

printf(“id\tname\tscore\n”);

while((row = mysql_fetch_row(res)) != NULL){

printf(“%s\t%s\t%s\n”, row[0], row[1], row[2]);

}

mysql_free_result(res);

mysql_close(conn);

return 0;

}

上述代码实现了查询test数据库中名为table1的表格的记录。通过mysql_real_connect函数连接到MySQL数据库后,使用mysql_query函数来执行查询操作,最后通过mysql_fetch_row函数将结果打印出来。

4. 插入/更新MySQL数据库

使用以下代码来插入/更新MySQL数据库:

#include

#include

int mn(){

MYSQL *conn;

MYSQL_RES *res;

MYSQL_ROW row;

char *server = “localhost”;

char *user = “newuser”;

char *pass = “user_password”;

char *database = “test”;

char *query = “INSERT INTO table1 VALUES(3,’Bob’,85)”;

conn = mysql_init(NULL);

if(!mysql_real_connect(conn, server, user, pass, database, 0, NULL, 0)){

fprintf(stderr, “%s\n”, mysql_error(conn));

exit(1);

}

if(mysql_query(conn, query)){

fprintf(stderr, “%s\n”, mysql_error(conn));

exit(1);

}

printf(“Successful insert.\n”);

mysql_close(conn);

return 0;

}

上述代码实现了向test数据库的table1表格中插入一条记录的操作,如果要进行更新操作,只需将query变量改为相应的更新语句即可。

五、

相关问题拓展阅读:

linux中c++怎么与mysql数据库相连时api怎么安装

在linux下安装mysql数据库并配置的流程比较繁琐,需要耐心调试,具体方法和步骤如下:

1.查找以前是否安装有mysql,使用下面命令:

rpm -qa|grep -i mysql

如果显示有如下包则说明已安装mysql

mysql-4.1.12-3.RHEL4.1

mysqlclient10-3.23.58-4.RHEL4.1

2.如果已安装,则需要删除已安装的数据库,使用以下命令来删除数据库

删除命令:rpm -e –nodeps 包名

( rpm -ev mysql-4.1.12-3.RHEL4.1 )

删除老版本mysql的开发头文件和库

命令:rm -fr /usr/lib/mysql

rm -fr /usr/include/mysql

注意:卸载后/var/lib/mysql中的数据及/etc/my.cnf不会删除,如果确定没用世敬后就手工删除

rm -f /etc/my.cnf

rm -fr /var/lib/mysql

3.下载mysql的rpm包

可以通过wget下载具体的地址因为不能用链接请大家去官网去找

(1)MySQL-server-5.6.10-1.rhel5.x86_64.rpm:MySQL服务器;

(2)MySQL-client-5.6.10-1.rhel5.x86_64.rpm:MySQL客户端;

(3)MySQL-devel-5.6.10-1.rhel5.x86_64.rpm:Mysql开发依赖包。

下载后放到Liunx服务器中。

4.安装MySQL Server的rpm包

rpm -ivh MySQL-server-5.6.21-1.linux_glibc2.5.x86_64.rpm

安装完成后会生成root用户的随机密码,请使用“cat /root/.mysql_secret”或类似命令进行查看。

5.安装MySQL客户端

rpm -ivh MySQL-client-5.6.21-1.linux_glibc2.5.x86_64.rpm

6.安装MySQL开发依赖包

rpm -ivh MySQL-devel-5.6.21-1.linux_glibc2.5.x86_64.rpm

7.启动msyql

安装完成后mysql是没有启动的,运行mysql命令会提示如下错误:

ERROR 2023 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2)

可使用如下命令启动MySQL:

service mysql start

或者使用如下命令:

/etc/init.d/mysql start

可使用SET PASSWORD命令修改root用户的密码,参考如下:SET PASSWORD = PASSWORD(‘root123456’);

8.登录MySQL

使用mysql命令登录MySQL服务器,运行MySQL的命令时,会提示需要设置root用户密码。

9.设置开机自启动

/etc/init.d/mysql start

设置完成后重启系统,使用natstat –nat命令可看到MySQL的3306端口。搜喊慎

10.至此已经安装好了mysql数据库,当渗宴然现在我们的数据库还不支持远程连接,远程连接会出现以下代码:1130,ERROR 1130: Host 192.168.0.10 is not allowed to connect to this MySQL server,可以通过以下以下来解决。

11.改表法:在本机登入mysql后,更改“mysql”数据库里的“user”表里的“host”项,从”localhost”改为’%’。

mysql>

mysql>use mysql;

mysql>select ‘host’ from user where user=’root

12.到此为止,mysql数据库在linux中安装完毕。

关于linux下c访问mysql的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » 使用C编程语言在Linux下访问MySQL数据库。 (linux下c访问mysql)