MySQL 是最受欢迎的关系型数据库之一,非常适合用于数据管理和持久化存储。Python 提供了各种 API 来操作 MySQL,本文将从多个角度为大家介绍如何使用 Python 操作 MySQL,并提供一些实例。
一、连接 MySQL
在使用 Python 操作 MySQL 之前,需要使用正确的参数建立数据库连接。常用的参数包括:
host: 主机名,即数据库的 IP 地址。
user: 用户名,访问数据库时需要提供用户名和密码。
password: 访问数据库的密码。
database: 数据库名称。
使用 Python 连接 MySQL 的代码示例如下:
import mysql.connector
mydb = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="mydatabase"
)
二、创建数据库和数据表
使用 Python 可以方便地创建数据库和数据表。首先使用 cursor() 方法创建游标对象,然后可以使用 execute() 方法执行 SQL 查询语句。代码示例如下:
import mysql.connector
mydb = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword"
)
cursor = mydb.cursor()
cursor.execute("CREATE DATABASE mydatabase")
cursor.execute("CREATE TABLE customers (name VARCHAR(255), address VARCHAR(255))")
三、插入数据
使用 INSERT INTO 语句可以向 MySQL 数据库中插入数据。代码示例如下:
import mysql.connector
mydb = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="mydatabase"
)
mycursor = mydb.cursor()
sql = "INSERT INTO customers (name, address) VALUES (%s, %s)"
val = ("John", "Highway 21")
mycursor.execute(sql, val)
mydb.commit()
print(mycursor.rowcount, "record inserted.")
四、查询数据
使用 SELECT 语句可以从 MySQL 数据库中查询数据。代码示例如下:
import mysql.connector
mydb = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="mydatabase"
)
cursor = mydb.cursor()
cursor.execute("SELECT * FROM customers")
result = cursor.fetchall()
for x in result:
print(x)
五、更新数据
使用 UPDATE 语句可以更新 MySQL 数据库中的数据。代码示例如下:
import mysql.connector
mydb = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="mydatabase"
)
cursor = mydb.cursor()
sql = "UPDATE customers SET address = 'Canyon 123' WHERE name = 'John'"
cursor.execute(sql)
mydb.commit()
print(mycursor.rowcount, "record(s) affected")
六、删除数据
使用 DELETE 语句可以从 MySQL 数据库中删除数据。代码示例如下:
import mysql.connector
mydb = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="mydatabase"
)
mycursor = mydb.cursor()
sql = "DELETE FROM customers WHERE name = 'John'"
mycursor.execute(sql)
mydb.commit()
print(mycursor.rowcount, "record(s) deleted")
七、使用 ORM
ORM(Object Relational Mapping)是一种编程技术,通过使用面向对象编程的思想来操作关系型数据库。Python 提供了多种 ORM 框架,如 Django ORM、SQLAlchemy 等。
八、总结
通过 Python 操作 MySQL 可以轻松地进行数据管理和持久化存储。不同的操作可以使用不同的 SQL 语句来实现,同时还可以使用 ORM 框架来简化操作。希望本文能够对大家有所帮助。