UBuntu18.04通过ODBC连接MySQL远程数据库

今天在做一个Qt视频播放器的小项目然后想要在ubuntu18.04运行这个项目,需要在Qt中连接远程的MySQL数据库,所以用到了ODBC。我在连接时遇到了一些问题,加之网上的教程各说纷纭,所以我花了很多时间去解决,所以决定做做笔记记录下来。

步骤一、安装unixODBC

这里需要注意版本的选择,我就因为版本的原因卡卡了很久(我之前下载的是最新版的)

sudo wget ftp://ftp.unixodbc.org/pub/unixODBC/unixODBC-2.3.4.tar.gz
 
tar -xvzf unixODBC-2.3.4.tar.gz 
 
cd unixODBC-2.3.4/
 
sudo ./configure --sysconfdir=/etc
make
sudo make install

检验是否安装成功

odbcinst -j

成功如下:

这里大概率会报错:

odbcinst: error while loading shared libraries: libodbcinst.so.2: cannot open shared object file: No such file or directory

然后百度发现解决办法是:

sudo ldconfig

步骤二、安装mysql odbc驱动

驱动下载地址:

MySQL :: Download Connector/ODBC

解压,拷贝bin及lib 目录到 /usr/local 下。

sudo tar zxvf mysql-connector-odbc-8.0.15-linux-ubuntu18.04-x86-64bit.tar.gz 
 
cd mysql-connector-odbc-8.0.15-linux-ubuntu18.04-x86-64bit/
sudo cp bin/* /usr/local/bin
sudo cp lib/* /usr/local/lib

安装MySQL 8.0 ODBC Driver 驱动程序

// Registers the Unicode driver:
sudo myodbc-installer -a -d -n "MySQL ODBC 8.0 Driver" -t "Driver=/usr/local/lib/libmyodbc8w.so"
 
// Registers the ANSI driver 
sudo myodbc-installer -a -d -n "MySQL ODBC 8.0" -t "Driver=/usr/local/lib/libmyodbc8a.so"

其中,-n指定驱动程序的名称为"MySQL ODBC 8.0 Driver",-t指定驱动程序的路径为"/usr/local/lib/libmyodbc8w.so"。

验证是否安装成功

myodbc-installer -d -l

看到列表里有 

MySQL ODBC 8.0 Driver
MySQL ODBC 8.0

即代表安装成功。

步骤三、设置ODBC 参数

sudo vi /etc/odbc.ini

将下面的内容添加进去:

[mysql]
Description     = Data source MySQL
Driver          = MySQL ODBC 8.0 Driver
Server          = 你远程IP地址
Host            = 你远程IP地址
Database        = 要连接这个数据库服务中的那个数据库
Port            = 3306
User            = root
Password        = 该数据库的密码
isql mysql

成功进入数据库。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在 Ubuntu 18.04 的 MySQL 5.7 上开放远程连接,请执行以下步骤: 1. 登录 MySQL 控制台:打开终端并输入以下命令: ``` mysql -u root -p ``` 2. 修改 MySQL 配置文件:使用以下命令编辑 MySQL 配置文件: ``` sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf ``` 3. 修改 bind-address 参数:找到 bind-address 参数并将其值从 127.0.0.1 改为 0.0.0.0。这样,MySQL 服务器将允许从任何 IP 地址进行连接。 4. 重启 MySQL 服务:使用以下命令重启 MySQL 服务: ``` sudo service mysql restart ``` 5. 创建用户并授予远程访问权限:在 MySQL 控制台中执行以下命令: ``` GRANT ALL PRIVILEGES ON *.* TO 'your_user'@'%' IDENTIFIED BY 'your_password'; ``` 6. 刷新权限:执行以下命令: ``` FLUSH PRIVILEGES; ``` 7. 退出 MySQL 控制台:使用以下命令退出 MySQL 控制台: ``` exit ``` 接下来,您就可以使用任何远程工具(如 MySQL Workbench)从远程计算机连接MySQL 服务器了。 ### 回答2: 要在Ubuntu 18.04上开放MySQL 5.7的远程连接,你需要按照以下步骤进行操作: 1. 确保你已经登录到Ubuntu的终端或远程终端,使用管理员权限(sudo)执行以下命令来安装MySQL服务器: ```shell sudo apt-get update sudo apt-get install mysql-server ``` 2. 安装完成后,执行以下命令来启动MySQL服务: ```shell sudo systemctl start mysql ``` 3. 执行以下命令来设置MySQL服务自动启动: ```shell sudo systemctl enable mysql ``` 4. 为了能够远程访问MySQL服务器,你需要修改MySQL的配置文件。执行以下命令来编辑该文件: ```shell sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf ``` 5. 在编辑器中,找到以下行并将其注释掉(在行前面加上`#`符号): ```shell bind-address = 127.0.0.1 ``` 6. 添加以下行来允许所有远程IP地址连接MySQL服务器: ```shell bind-address = 0.0.0.0 ``` 7. 保存并关闭编辑器(使用Ctrl + X,然后输入Y来保存修改)。 8. 执行以下命令来重启MySQL服务以使配置修改生效: ```shell sudo systemctl restart mysql ``` 现在,你的Ubuntu 18.04上的MySQL服务器已经开放了远程连接。你可以使用其他计算机上的MySQL客户端工具来连接它。请不要忘记在远程连接之前设置适当的安全性措施。 ### 回答3: 要在Ubuntu 18.04上开放远程连接MySQL 5.7,您需要按照以下步骤进行操作: 1. 首先,确保您已经在Ubuntu上安装了MySQL 5.7版本。如果尚未安装,请使用以下命令进行安装: ``` sudo apt-get update sudo apt-get install mysql-server-5.7 ``` 2. 访问MySQL配置文件以进行修改: ``` sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf ``` 3. 在该文件中找到“bind-address”行,并将其注释掉。注释的符号是“#”,将行变为: ``` # bind-address = 127.0.0.1 ``` 4. 保存并关闭文件。 5. 重启MySQL服务使更改生效: ``` sudo service mysql restart ``` 6. 接下来,您需要为远程访问的MySQL用户创建授权。打开MySQL命令行界面: ``` mysql -u root -p ``` 7. 在MySQL命令行中,使用以下命令创建一个允许远程连接的用户,并将其替换为您想要使用的用户名和密码: ``` GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION; ``` 请确保在'username'和'password'之间使用您的用户名和密码。 8. 刷新MySQL权限: ``` FLUSH PRIVILEGES; ``` 9. 现在,您已经成功地开放了MySQL 5.7的远程连接。您可以使用远程客户端连接MySQL服务器: ``` mysql -u username -p -h <服务器IP地址> ``` 请将<服务器IP地址>替换为您的MySQL服务器的实际IP地址。 通过这些步骤,您应该能够在Ubuntu 18.04上成功地开放MySQL 5.7的远程连接。请记住,远程连接可能会带来安全风险,因此请确保在网络上采取适当的安全措施。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值