linux系统mysql安装,python链接mysql,mysql开放外部访问

我用的是ubuntu,安装mysql命令如下:

sudo apt-get install mysql-server
sudo apt-get install mysql-client
sudo apt-get install libmysqlclient-dev
sudo netstat -tap | grep mysql
查看mysql是否安装成功,mysql 的socket处于 listen 状态则表示安装成功

登陆mysql数据库可以通过如下命令:

  mysql -u root -p 
  -u 表示选择登陆的用户名, -p 表示登陆的用户密码
  上面命令输入之后会提示输入密码,此时输入密码就可以登录到mysql

创建用户:

create user 'username'@'%' identified by 'password';  
"%",表示在任何一台电脑上都可以登录。

给新建用户授权:

grant all privileges on DBName.* to username@localhost identified by 'password';
DBName数据库名 username用户名 ‘password’密码
格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码"; 

注意:外部接入不能将登陆主机设置为localhost,可设置为登陆主机IP或者‘%’。
外部主机接入代码运行报错1044 – Access denied for user ‘user’@’%’ to database ‘datrebase’ 可能就是登陆主机填写了localhost。
外部访问:
修改/etc/mysql/mysql.conf.d/mysqld.cnf文件
将bind-address = 127.0.0.1注释或者改为bind-address = 0.0.0.0
注意:mysql语句后面要敲上分号
查看用户:

select host,user from mysql.user;

我使用的是python3,所以安装的是pymysql。
安装命令:

pip install pymysql

python链接mysql代码如下:

#!/usr/bin/python3
 
import pymysql
 
# 连接数据库
db = pymysql.Connect(
    host='localhost', #数据库在本地就填写localhost,
                      #在服务器就填写服务器IP
    port=3306,        #如果在服务器需填写上port,本地可把这个删除
                      #port可在/etc/mysql/mysql.conf.d/
                      #mysqld.cnf文件内查看
    user='username',
    passwd='password',
    db='database',
    charset='utf8'
)
 
# 使用 cursor() 方法创建一个游标对象 cursor
cursor = db.cursor()
 
# 使用 execute()  方法执行 SQL 查询 
cursor.execute("SELECT VERSION()")
 
# 使用 fetchone() 方法获取单条数据.
data = cursor.fetchone()
 
print ("Database version : %s " % data)
 
# 关闭数据库连接
db.close()

上面 代码来自菜鸟教程,我改了下db = pymysql.Connect并加上了注释。


我现在还在看《mysql必知必会》,项目中可能会用到触发器,一开始是打算用轮询的方法,但想到轮询方法会很占用主机资源,就找了本sql的书学下触发器的使用,触发器的话后续学习有记录的话就更新下。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值