如何使用Python进行数据库操作
创始人
2025-01-09 12:34:04
0

在Python中进行数据库操作通常涉及以下几个步骤:安装数据库适配器(也称为数据库驱动或接口)、连接到数据库、执行SQL语句、处理结果以及关闭连接。下面我将以几个流行的数据库为例,介绍如何使用Python进行数据库操作。

1. SQLite

SQLite是一种轻量级的数据库,它不需要独立的服务器进程或操作,可以直接在Python中使用。Python标准库中的sqlite3模块提供了对SQLite数据库的支持。

 

python复制代码

import sqlite3
# 连接到SQLite数据库
# 如果文件不存在,会自动在当前目录创建
conn = sqlite3.connect('example.db')
# 创建一个Cursor对象,并通过它执行SQL命令
c = conn.cursor()
# 创建表
c.execute('''CREATE TABLE IF NOT EXISTS stocks
(date text, trans text, symbol text, qty real, price real)''')
# 插入数据
c.execute("INSERT INTO stocks VALUES ('2023-01-01','BUY','RHAT',100,35.14)")
# 提交事务
conn.commit()
# 查询数据
c.execute('SELECT * FROM stocks WHERE symbol=?', ('RHAT',))
print(c.fetchall())
# 关闭连接
conn.close()

2. MySQL

对于MySQL数据库,Python提供了mysql-connector-pythonPyMySQL等第三方库来支持。这里以mysql-connector-python为例。

首先,你需要安装mysql-connector-python

 

bash复制代码

pip install mysql-connector-python

然后,你可以像这样连接到MySQL数据库并执行操作:

 

python复制代码

import mysql.connector
# 连接到MySQL数据库
conn = mysql.connector.connect(
host="localhost",
user="yourusername",
password="yourpassword",
database="mydatabase"
)
c = conn.cursor()
# 创建表
c.execute("CREATE TABLE IF NOT EXISTS employees (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255), position VARCHAR(255))")
# 插入数据
c.execute("INSERT INTO employees (name, position) VALUES (%s, %s)", ("John Doe", "Developer"))
# 提交事务
conn.commit()
# 查询数据
c.execute("SELECT * FROM employees")
print(c.fetchall())
# 关闭连接
conn.close()

3. PostgreSQL

对于PostgreSQL数据库,可以使用psycopg2库。

首先,安装psycopg2

 

bash复制代码

pip install psycopg2-binary

然后,连接到PostgreSQL数据库并执行操作:

 

python复制代码

import psycopg2
# 连接到PostgreSQL数据库
conn = psycopg2.connect(
dbname="mydatabase",
user="myuser",
password="mypassword",
host="127.0.0.1",
port="5432"
)
cur = conn.cursor()
# 创建表
cur.execute("CREATE TABLE IF NOT EXISTS test (id SERIAL PRIMARY KEY, num INTEGER, data VARCHAR(50))")
# 插入数据
cur.execute("INSERT INTO test (num, data) VALUES (%s, %s)", (100, "abc'def"))
# 提交事务
conn.commit()
# 查询数据
cur.execute("SELECT * FROM test")
rows = cur.fetchall()
for row in rows:
print(row)
# 关闭连接
cur.close()
conn.close()

以上是在Python中操作SQLite、MySQL和PostgreSQL数据库的基本步骤。不同的数据库系统可能需要安装不同的库,并且连接字符串(用于连接到数据库的参数)也可能会有所不同。但是,一旦你建立了连接,执行SQL语句和处理结果的基本模式通常是相似的。

相关内容

热门资讯

今年以来!老k麻将有挂吗,家乡... 今年以来!老k麻将有挂吗,家乡大二辅助,扑克教程(总是存在有挂)-哔哩哔哩老k麻将有挂吗辅助器中分为...
在玩家背景下!丫丫陕西打锅子辅... 在玩家背景下!丫丫陕西打锅子辅助,微信小程序雀神挂件,微扑克教程(切实真的有挂)-哔哩哔哩1、微信小...
现有关情况通报如下!同城游破解... 现有关情况通报如下!同城游破解版下载,海盗来了辅助器无限炮,攻略教程(一直真的有挂)-哔哩哔哩1、该...
这一现象值得深思!潮汕掌上辅助... 这一现象值得深思!潮汕掌上辅助挂定制交易平台,兴动互娱辅助工具,透明挂教程(切实真的是有挂)-哔哩哔...
连日来!新518互游脚本下载,... 连日来!新518互游脚本下载,多乐辅助,微扑克教程(好像真的有挂)-哔哩哔哩运新518互游脚本下载辅...
近日!四川辅助工具,潮汕掌上娱... 近日!四川辅助工具,潮汕掌上娱有破解版吗,德州教程(其实有挂)-哔哩哔哩1、近日!四川辅助工具,潮汕...
今天下午!大唐撸麻雀辅助码,福... 今天下午!大唐撸麻雀辅助码,福建天天开心辅助软件大全,科技教程(本来是有挂)-哔哩哔哩1、打开软件启...
据目击者称!福州十八扑外卦,新... 据目击者称!福州十八扑外卦,新畅游互娱辅助,技巧教程(确实是有挂)-哔哩哔哩新畅游互娱辅助是一种具有...
出乎意料的是!欢聚水鱼智能辅助... 出乎意料的是!欢聚水鱼智能辅助教程,博雅红河西元红河挂,教你教程(都是有挂)-哔哩哔哩欢聚水鱼智能辅...
最终!约战竞技场辅助器,邳州友... 最终!约战竞技场辅助器,邳州友友有没有辅助软件,wpk教程(都是真的有挂)-哔哩哔哩1、每一步都需要...