您的位置:首页 > 数据库 > MySQL

客户端通过unix_socket方式连接MySQL

2009-07-26 12:29 579 查看
我的系统是Ubuntu 8.10 desktop x86版,使用apt-get安装mysql服务端,配置文件路径:/etc/mysql/my.inf

1.查看mysql server的配置文件

27 [mysqld_safe]

28 socket = /var/run/mysqld/mysqld.sock

29 nice = 0

可以看到unix_socket路径是 /var/run/mysqld/mysqld.sock

2.填写客户端连接函数参数

函数原型:MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user,

const char *passwd, const char *db, unsigned int port, const char *unix_socket,

unsigned long client_flag)

mysql_real_connect(&mysql, NULL, "root", "123456;", "mysql", 0, "/var/run/mysqld/mysqld.sock", 0)

重点解释一下:

第二个参数host,要么写成"localhost",要么写成NULL,但是绝对不能写成IP地址,如果写成IP地址,连接方式会选择TCP/IP,而不是unix_socket;

第七个参数unix_socket,必须写成mysql server配置文件中的那个路径。

最后的建议:

如果程序和mysql服务器不在同一台电脑上,是无法使用unix_socket连接方式的,所以必须位于同一台主机。对于位于同一台主机上,而使用API进行开发的项目,强烈建议使用unix_socket连接方式,而不要使用TCP/IP方式,因为前者的效率更高!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐