Python链接MySQL数据库的多种方式

上篇文章分享了windows下载mysql5.7压缩包配置安装mysqlhtml

后续能够选择python

①在本地建立一个数据库,使用navicat工具导出远程测试服务器的数据库至本地,用于学习操做,且不影响测试服务器的数据mysql

②链接测试服务器的数据库帐号和密码,在测试服务器上操做,内部测试服务器的数据库帐号和密码在分配时会给不一样帐号作权限限制,如不一样帐号容许登陆的方式、开放的数据库范围、帐号可读写操做的权限都会不同,若出现一直使用代码登陆不上远程数据库服务器,应检查下帐号是否具备权限,可询问负责管理测试服务器数据库管理员。(本人亲测不一样帐号相同代码,一个能操做成功一个报错链接不上数据库;另,在navicat工具或pycharm ide内配置可视化数据库时帐号登陆须要使用ssh通道认证,相同的帐号用python代码链接却彻底不须要ssh远程链接的代码,提供帐号和密码就能登陆成功。数据库权限限制相关的着实深!)sql

本次代码实现链接远程服务器数据库

因为MySQL服务器以独立的进程运行,并经过网络对外服务,因此,须要支持Python的MySQL驱动来链接到MySQL服务器。windows

目前,MySQL驱动有几种:服务器

mysql-connector-python:是MySQL官方的纯Python驱动;网络

MySQL-python:是封装了MySQL C驱动的Python驱动。ssh

安装MySQL驱动:ide

  • pip install mysql-connector-python

测试是否安装成功,测试python下是否可成功导入mysql.connector便可(import mysql.connector)

  • pip install MySQL-python (不支持python3)

测试是否安装成功,测试python下是否可成功导入MySQLdb便可(import MySQLdb)

  • pip install mysqlclient (mysqlclient 彻底兼容MySQLdb,同时支持python3)

测试是否安装成功,测试python下是否可成功导入MySQLdb便可(import MySQLdb)

  • pip install PyMySQL

测试是否安装成功,测试python下是否可成功导入pymysql便可(import pymysql)

python链接MySQL数据库的多种方式(方式一)

# 方式一:
import mysql.connector

# 打开数据库链接
db = mysql.connector.connect(host='*.*.*.*',
                             port=3306,
                             user='*',      # 数据库IP、用户名和密码
                             passwd='*',
                             charset = 'utf8')       

# 使用 cursor() 方法建立一个游标对象 cursor
cursor = db.cursor()

# 使用 execute()  方法执行 SQL 查询
cursor.execute("show databases;")
cursor.execute("use database_name;")
cursor.execute("show tables;")

# 使用 fetchone() 方法获取单条数据;使用 fetchall() 方法获取全部数据
data = cursor.fetchall()

for item in data:
     print(item[0])

# 关闭数据库链接
db.close()

python链接MySQL数据库的多种方式(方式二)

# 方式二:
import MySQLdb

# 打开数据库链接
conn = MySQLdb.connect(host='*.*.*.*',
                       port=3306,
                       user='*',
                       passwd='*',
                       charset = 'utf8'
                       )
                       
# 使用 cursor() 方法建立一个游标对象 cursor
cursor = conn.cursor()

# 使用 execute()  方法执行 SQL 查询
cursor.execute("show databases;")
cursor.execute("use database_name;")
cursor.execute("show tables;")
cursor.execute("select * from tables_name")

# 使用 fetchone() 方法获取单条数据;使用 fetchall() 方法获取全部数据
data = cursor.fetchall()
for item in data:
    print(item)

# 关闭数据库链接
cursor.close()

python链接MySQL数据库的多种方式(方式三)

# 方式三:
import pymysql

# 打开数据库链接
conn = pymysql.connect(host='*.*.*.*',
                       port=3306,
                       user='*', 
                       passwd='*', 
                       charset = 'utf8'
                       )
               
# 使用 cursor() 方法建立一个游标对象 cursor                       
cursor = conn.cursor()

# 使用 execute()  方法执行 SQL 查询
cursor.execute("show databases;")
cursor.execute("use database_name;")
cursor.execute("show tables;")
cursor.execute("select * from tables_name")

# 使用 fetchone() 方法获取单条数据;使用 fetchall() 方法获取全部数据
data = cursor.fetchall()
for item in data:
    print(item[0])
    
# 关闭数据库链接
cursor.close()

  

原文出处:https://www.cnblogs.com/kristin/p/10718048.html

相关文章
相关标签/搜索