Python数据库操作大揭秘:掌握六种常见模块

在现代软件开发和数据处理中,与数据库进行交互是一项基本而且必不可少的任务。Python作为一门强大的编程语言,提供了多种数据库操作模块,能够满足不同数据库管理系统的需求。本文将深入研究六种常见的Python数据库操作模块,包括SQLite、MySQL、PostgreSQL、MongoDB、Redis和SQLAlchemy。通过对每个模块的详细介绍和示例演示,帮助读者全面掌握Python与数据库的交互技术。

1、SQLite

1.1 简介

SQLite是一个轻量级的嵌入式数据库引擎,无需独立的服务器进程,可以直接访问数据库文件。在Python中,我们可以使用sqlite3模块来进行SQLite数据库的操作。

1.2 示例
 import sqlite3  
   
 # 连接数据库(如果不存在则创建)  
 连接 = sqlite3.connect('my_database.db')  
   
 # 创建游标  
 游标 = 连接.cursor()  
   
 # 执行SQL语句  
游标.execute('''CREATE TABLE IF NOT EXISTS users   
                (id INT PRIMARY KEY, name TEXT, age INT)''')  
  
# 插入数据  
游标.execute("INSERT INTO users VALUES (1, 'Alice', 25)")  
  
# 提交事务  
连接.commit()  
  
# 查询数据  
游标.execute("SELECT * FROM users")  
数据 = 游标.fetchall()  
print(数据)  
  
# 关闭连接  
连接.close()

2、MySQL

2.1 简介

MySQL是一种流行的关系型数据库管理系统,支持多用户、多线程,并提供了丰富的SQL语法。Python中使用mysql-connector模块进行MySQL数据库操作。

2.2 示例
 import mysql.connector  
   
 # 连接数据库  
 连接 = mysql.connector.connect(  
     host="localhost",  
     user="root",  
     password="password",  
     database="my_database"  
 )  
  
# 创建游标  
游标 = 连接.cursor()  
  
# 执行SQL语句  
游标.execute('''CREATE TABLE IF NOT EXISTS users   
                (id INT PRIMARY KEY, name VARCHAR(255), age INT)''')  
  
# 插入数据  
游标.execute("INSERT INTO users VALUES (1, 'Bob', 30)")  
 
# 提交事务  
连接.commit()  
  
# 查询数据  
游标.execute("SELECT * FROM users")  
数据 = 游标.fetchall()  
print(数据)  
  
# 关闭连接  
连接.close()

3、PostgreSQL

3.1 简介

PostgreSQL是一种功能强大的开源关系型数据库系统,支持复杂的数据类型和高级的SQL查询。Python中使用psycopg2模块进行PostgreSQL数据库操作。

3.2 示例
 import psycopg2  
   
 # 连接数据库  
 连接 = psycopg2.connect(  
     host="localhost",  
     user="user",  
     password="password",  
     database="my_database"  
 )  
  
# 创建游标  
游标 = 连接.cursor()  
  
# 执行SQL语句  
游标.execute('''CREATE TABLE IF NOT EXISTS users   
                (id SERIAL PRIMARY KEY, name VARCHAR(255), age INT)''')  
  
# 插入数据  
游标.execute("INSERT INTO users (name, age) VALUES (%s, %s)", ('Charlie', 35))  
  
# 提交事务  
连接.commit()  
  
# 查询数据  
游标.execute("SELECT * FROM users")  
数据 = 游标.fetchall()  
print(数据)  
  
# 关闭连接  
连接.close()

4、MongoDB

4.1 简介

MongoDB是一种面向文档的NoSQL数据库,以其灵活的数据模型和横向可扩展性而闻名。在Python中,我们使用pymongo模块与MongoDB进行交互。

4.2 示例
 from pymongo import MongoClient  
   
 # 连接数据库  
 连接客户端 = MongoClient('mongodb://localhost:27017/')  
   
 # 获取数据库  
 数据库 = 连接客户端['my_database']  
  
 # 获取集合  
集合 = 数据库['users']  
  
# 插入文档  
用户数据 = {"name": "David", "age": 28}  
集合.insert_one(用户数据)  
  
# 查询文档  
所有用户 = 集合.find()  
for 用户 in 所有用户:  
    print(用户)  
  
# 关闭连接  
连接客户端.close()

5、Redis

5.1 简介

Redis是一种基于内存的数据存储,可用作数据库、缓存和消息中间件。在Python中,我们使用redis-py模块与Redis进行交互。

5.2 示例
 import redis  
   
 # 连接数据库  
 连接池 = redis.ConnectionPool(host='localhost', port=6379, decode_responses=True)  
 连接 = redis.StrictRedis(connection_pool=连接池)  
   
 # 插入数据  
 连接.set('counter', 100)  
   
# 查询数据  
计数器值 = 连接.get('counter')  
print(计数器值)  
  
# 关闭连接  
连接池.disconnect()

6、SQLAlchemy

6.1 简介

SQLAlchemy是一种SQL工具和对象关系映射(ORM)库,它提供了高层的SQL表达和灵活的数据库映射。在Python中,我们使用SQLAlchemy模块进行SQL数据库操作。

6.2 示例
 from sqlalchemy import create_engine, Column, Integer, String, MetaData  
 from sqlalchemy.orm import declarative_base, Session  
  
 # 连接数据库  
 引擎 = create_engine('sqlite:///my_database.db')  
 元数据 = MetaData(bind=引擎)  
   
 # 定义模型  
 Base = declarative_base()  
  
class User(Base):  
    __tablename__ = 'users'  
    id = Column(Integer, primary_key=True)  
    name = Column(String)  
    age = Column(Integer)  
 
# 创建表  
Base.metadata.create_all()  
  
# 插入数据  
会话 = Session(引擎)  
新用户 = User(name='Eva', age=22)  
会话.add(新用户)  
会话.commit()  
  
# 查询数据  
所有用户 = 会话.query(User).all()  
for 用户 in 所有用户:  
    print(用户.name, 用户.age)  
  
# 关闭连接  
会话.close()

7、总 结

通过本文,我们详细介绍了Python中六种常见数据库操作模块的使用方法,包括SQLite、MySQL、PostgreSQL、MongoDB、Redis和SQLAlchemy。这些模块各有特点,可根据项目需求选择合适的数据库。希望本文能够帮助读者更深入地了解和掌握Python与数据库交互的技术,提高在实际项目中的数据库操作能力。

感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

img
img

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!img

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

img

六、面试宝典

在这里插入图片描述

在这里插入图片描述

简历模板在这里插入图片描述
若有侵权,请联系删除
  • 26
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值