随笔录--SQLAlchemy

SQLAlchemy是一个用纯Python编写的开源SQL工具包和ORM(Object Relational Mapping)框架,它使得Python程序员可以轻松地与关系型数据库(比如MySQL、PostgreSQL、Oracle)交互。使用SQLAlchemy可以方便地创建、编辑、删除和查询数据库中的数据,同时还提供了一些高级功能,比如事务处理、连接池、连接复用等。



SQLAlchemy的主要特点是:

1. ORM模型:SQLAlchemy提供了基于ORM映射关系,将面向对象的Python语言和关系型数据库联系在了一起。ORM的思想是把关系型数据库中的表结构映射到对象上,并提供良好的接口让开发者进行数据的增删改查等操作。这样可以避免直接操作数据库、手写SQL语句等低效的操作方法。

2. 支持多种数据库:SQLAlchemy支持多种数据库,包括Mysql、PostgreSQL、SQLite、Oracle、Microsoft SQL Server等。

3. 灵活性:SQLAlchemy提供了大量的功能和选项来满足开发者的不同需求。它支持动态的SQL语句构建方式,允许SQL查询语句中的参数化输入,从而防止SQL注入攻击。

4. 可靠性:SQLAlchemy提供了许多保证数据一致性和完整性的功能,比如事务处理、自动回滚等。

总之,SQLAlchemy是一个功能强大、灵活、可靠的Python SQL工具包和ORM框架,它使得开发者可以更加方便地使用Python与关系型数据库交互。

下面是一个使用SQLAlchemy创建表、插入数据和查询数据的简单示例代码:


from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

# 创建数据库连接
engine = create_engine('sqlite:///example.db')
Session = sessionmaker(bind=engine)
session = Session()
Base = declarative_base()

# 定义数据模型
class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String)
    age = Column(Integer)

# 创建表
Base.metadata.create_all(engine)

# 插入数据
user1 = User(name='Alice', age=25)
user2 = User(name='Bob', age=30)
session.add(user1)
session.add(user2)
session.commit()

# 查询数据
users = session.query(User).all()
for user in users:
    print(f"ID: {user.id}, Name: {user.name}, Age: {user.age}")

上述代码首先创建了一个SQLite数据库连接,并通过`declarative_base()`创建了一个基础的数据模型类`Base`。然后定义了一个名为`User`的数据模型类,其中包含了`id`、`name`和`age`三个字段。

使用`Base.metadata.create_all(engine)`可以根据定义的数据模型在数据库中创建对应的表。

接下来,我们创建了两个`User`对象并使用`session.add()`将它们添加到会话中,然后使用`session.commit()`提交更改,将数据写入数据库。

最后,我们通过`session.query(User)`执行查询操作,使用`.all()`获取所有的结果,并遍历输出每个用户的ID、姓名和年龄。

这只是一个简单的示例,SQLAlchemy还提供了更多丰富的功能,比如条件查询、更新、删除等操作,以及更复杂的关联关系处理。你可以参考SQLAlchemy的官方文档来了解更多详细的用法和示例:https://docs.sqlalchemy.org/

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值