详解Python连接MySQL数据库的多种方式

作者:kristin_n 时间:2024-01-19 05:29:59 

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

后续可以选择

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

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

本次代码实现连接远程服务器

由于MySQL服务器以独立的进程运行,并通过网络对外服务,所以,需要支持Python的MySQL驱动来连接到MySQL服务器。

目前,MySQL驱动有几种:

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

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

安装MySQL驱动:

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()

以上所述是小编给大家介绍的Python连接MySQL数据库方式详解整合网站的支持!

来源:https://www.cnblogs.com/kristin/p/10718048.html

标签:Python,MySQL
0
投稿

猜你喜欢

  • Go压缩位图库roaring安装使用详解

    2024-05-22 10:16:42
  • MYSQL复杂查询练习题以及答案大全(难度适中)

    2024-01-12 14:54:45
  • MySQL redo死锁问题排查及解决过程分析

    2024-01-17 08:17:02
  • python调试模块ipdb详解

    2021-11-05 19:59:01
  • 关于Python作用域自学总结

    2023-11-02 12:19:53
  • 如何利用PyQt5美化你的GUI界面

    2023-06-18 19:58:55
  • Python中的rfind()方法使用详解

    2022-05-05 21:30:54
  • Python中的wordcloud库安装问题及解决方法

    2022-04-14 21:38:43
  • Firefox下正则诡异问题

    2009-08-03 14:03:00
  • 在网页中实现细线边框的两种方法

    2011-06-14 09:47:26
  • 2021年的Python 时间轴和即将推出的功能详解

    2023-07-14 22:32:04
  • pytorch 实现在预训练模型的 input上增减通道

    2023-12-02 00:49:33
  • Python可视化函数plt.scatter详解

    2023-07-02 17:54:01
  • IIS出现Active Server Pages错误“ASP 0201”的修复工具

    2009-05-25 18:06:00
  • 用Python写飞机大战游戏之pygame入门(4):获取鼠标的位置及运动

    2023-09-28 11:01:21
  • Oracle PL/SQL入门案例实践

    2010-07-18 13:13:00
  • go语言map字典删除操作的方法

    2024-02-03 16:19:37
  • Python教程之pytest命令行方式运行用例

    2022-08-01 22:08:06
  • Node.js系列之连接DB的方法(3)

    2024-05-03 15:55:26
  • Python全栈之队列详解

    2022-10-12 07:51:33
  • asp之家 网络编程 m.aspxhome.com