0

0

Python中的ORM框架Databases详解

WBOY

WBOY

发布时间:2023-06-11 13:34:37

|

2828人浏览过

|

来源于php中文网

原创

近年来,python作为一种易学易用、极为灵活的编程语言在开发领域中愈发受欢迎。在python应用程序中,orm(object-relational mapping,对象关系映射)框架扮演着至关重要的角色,不仅极大地提高了开发效率,还让开发者更加方便管理数据和对象。

在ORM框架中,Databases库是一种新兴的Python库,在开发过程中经常用于访问关系型数据库。虽然这个库在Python开发领域中还算新生代,但它已经展现出了极大的潜力。因此,在这篇文章中,我们将对Databases库进行详细介绍,帮助开发者更好地了解和学习这个强大的Python ORM框架。

一、Databases开发背景

Databases库是一个轻量级的Python库,用于简化使用异步SQL数据库的开发工作。它使用asyncio进行异步编程,可以与多种SQL数据库引擎协作,如PostgreSQL、MySQL、MariaDB、SQLite等等。并且,Databases库还提供了高度简洁且易于使用的API。

Databases库的目标是让开发者更快地构建应用程序,并消除大量重复性代码。它在性能上表现得非常出色,并提供了诸如连接池、事务管理等高级功能以及诸多异步驱动的增强特性和帮助文档。因此,对于那些需要协作访问SQL数据库的复杂微服务或大型Web应用程序而言,Databases库无疑是一个非常不错的选择。

立即学习Python免费学习笔记(深入)”;

二、Databases核心功能

Databases库的设计目标是让开发者使用简单的API,从而实现与SQL数据库的快速交互。下面我们将介绍一些Databases库的核心功能:

1.代码简洁清晰

Databases库使用Python的简洁语法来最大限度地提高开发者的开发效率,它可以实现Python的所有高级特性,如异步和并发操作。

例如,下面的这段代码创建了一个名为"users"的表。其中,表的几个属性包括ID、Name、Age和Email。

import databases

database = databases.Database("sqlite:///example.db")

query = "CREATE TABLE users (ID INT PRIMARY KEY, Name TEXT, Age INT, Email TEXT)"

await database.execute(query=query)

2.协作客户端和服务端的API

Databases库提供了一个高级API,其中包括了异步以及同步的操作,因此我们在使用时可以将这些操作统一起来。

import database

database = databases.Database("sqlite:///example.db")

# 异步操作(async)
async with database.transaction():
   query = "INSERT INTO users (ID, Name, Age, Email) VALUES (:id, :name, :age, :email)"
   values = {"id": 1, "name": "John Doe", "age": 23, "email": "[email protected]"}
   await database.execute(query=query, values=values)

# 同步操作
query = "SELECT * FROM users WHERE ID=:id"
values = {"id": 1}
result = database.fetch_one(query=query, values=values)

3.连接池

Databases库能够轻松地管理连接池问题,提高了数据库访问的效率。开发者在使用Databases库时,只需要指定连接池大小,即可轻松实现自动化连接,而无需手动管理连接,非常方便。

例如,下面的这段代码,我们可以指定最大连接数和最小连接数,使得Databases库可以更好地管理连接池。

import databases

database = databases.Database("sqlite:///example.db", min_size=1, max_size=10)

4.事务管理

Databases库提供了集成事务管理,确保在执行操作时,可以确保一致性和可靠性。事务是一个非常重要的DBMS特性,它使得开发者可以批量执行操作。

例如,下面的这段代码,我们可以通过异步开始和提交事务来协作处理数据。

Android WebView实例详解 中文WORD版
Android WebView实例详解 中文WORD版

本文档主要讲述的是Android WebView实例详解;Android手机中内置了一款高性能webkit内核浏览器,在SDK中封装为一个叫做WebView组件。 WebKit是Mac OS X v10.3及以上版本所包含的软件框架(对v10.2.7及以上版本也可通过软件更新获取)。 同时,WebKit也是Mac OS X的Safari网页浏览器的基础。WebKit是一个开源项目,主要由KDE的KHTML修改而来并且包含了一些来自苹果公司的一些组件。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来

下载
import databases

database = databases.Database("sqlite:///example.db")

async with database.transaction():
   query_1 = "INSERT INTO users (ID, Name, Age, Email) VALUES (:id, :name, :age, :email)"
   values_1 = {"id": 1, "name": "John Doe", "age": 23, "email": "[email protected]"}
   await database.execute(query=query_1, values=values_1)

   query_2 = "UPDATE users SET Age=:age WHERE ID=:id"
   values_2 = {"age": 25, "id": 1}
   await database.execute(query=query_2, values=values_2)

await database.commit()

5.支持多种数据库引擎

Databases库支持多种常见的数据库引擎,包括MySQL、PostgreSQL、MariaDB等等。这使得我们可以很方便地搭建我们想要的数据库环境。

例如我们有如下的代码片段,我们就可以根据需要选择自己常用的数据库引擎。

import databases

database = databases.Database("postgresql://user:[email protected]:5432/example")

三、使用Databases库

在学习使用Databases库之前,我们需要先进行库的安装工作。

1.安装Databases库

我们可以通过以下命令安装Databases库:

pip install databases

2.创建数据库连接

要使用Databases库,我们首先需要通过URL字符串为我们的PHP应用程序创建一个与数据库引擎的连接。

import databases
from databases import Database

database = Database("sqlite:///example.db")

3.查询数据

Databases库提供了8个异步和同步函数,可用于查询数据库: `fetch_all()`,`fetch_one()`, `fetch_val()`, `fetch_many()`, `fetch_optional()`, `execute()`, `execute_many()`和`iterate()`

查询所有行

result = database.fetch_all("SELECT * FROM users")

查询第一行数据

result = database.fetch_one("SELECT * FROM users WHERE ID=:id", value = {"id": 1})

获取单元格数据

result = database.fetch_val("SELECT Name FROM users WHERE ID=:id", value = {"id": 1})

获取多个行数据

result = database.fetch_many(query="SELECT * FROM users", values=[{'id':1}, {'id':2})

如果数据不存在返回 None

result = database.fetch_optional(query="SELECT * FROM users WHERE ID=:id", value={"id": 3})

执行任意查询(返回插入的行数)

result = await database.execute("INSERT INTO users (ID,Name,Age,Email) VALUES (:id,:name,:age,:email)",value={"id":5, "name":"John","age":25,"email":"[email protected]"})

以批量方式执行任意查询(返回插入的行数)

result = await database.execute_many("INSERT INTO users (ID,Name,Age,Email) VALUES (:id,:name,:age,:email)",values=[{"id":5, "name":"John","age":25,"email":"[email protected]"},{"id":6,"name":"Jack", "age":26,"email":"[email protected]"}])

使用异步迭代器处理数据

async with database.connection() as connection:
async with connection.transaction():

   async for row in connection.iterate(query="SELECT * FROM users"):
      print(row)
4.使用事务

Databases库还提供了事务管理的机制。我们可以使用异步with语句来绑定事务。如果with语句内的所有操作成功完成,则会提交事务。否则,事务将被回滚。

async with database.transaction():
query = "INSERT INTO users (ID,Name,Age,Email) VALUES (:id,:name,:age,:email)"
value = {"id": 5, "name": "Hassen", "age": 26, "email": "[email protected]"}
await database.execute(query, values)

query = "INSERT INTO user1 (ID,Name,Age,Email) VALUES (:id,:name,:age,:email)"
value = {"id": 6, "name": "Fatima", "age": 22, "email": "[email protected]"}
await database.execute(query, values)

以上就是Databases库在Python ORM框架中的详细介绍。Databases库是一个新生代的Python ORM框架,它拥有很多优秀的特性,如代码简明优化、异步通信操作、连接池等等,可大大提高开发者的开发效率,促进其优秀性能的发挥。虽然Databases库在Python开发领域中还较新,但它越来越受到社区的关注和认可。我们相信,这个库将会在Python开发者的未来工作中扮演着越来越重要的角色。

相关文章

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1090

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2028

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1560

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

33

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号