Python操作Sqlserver数据库(多库同时异步执行:增删改查)
通过yaml文件配置数据库信息,实现多个数据库同时异步执行(增删改查)
在D盘新建一个后缀.yaml的文件 , 如文件Database.yaml内容:
DBConnector 类实现了以下功能:
- 多数据库连接支持:
该类支持连接多个 SQL Server 数据库。你可以在配置中提供多个数据库的连接信息,类会自动建立与这些数据库的连接。
- 自动执行 SQL 查询:
该类能够处理两种类型的 SQL 操作:查询操作 (SELECT):通过 fetch_query 方法执行查询操作并返回结果。非查询操作 (INSERT、UPDATE、DELETE 等):通过 execute_query 方法执行这些修改操作。
- 异步并行执行:
使用 Python 的 ThreadPoolExecutor,该类支持异步并行执行多个数据库的查询或更新操作。这意味着你可以同时向多个数据库发送查询请求,而无需等待每个请求单独完成。
- 自动区分 SQL 类型:
该类会自动判断 SQL 查询是查询操作(SELECT)还是更新操作(INSERT、UPDATE、DELETE等),并根据类型选择执行方式。通过 determine_query_type 方法自动识别查询类型。
- 错误处理:
类中有基本的错误处理机制,确保在连接数据库或执行 SQL 查询时如果发生错误,会输出相关的错误信息。
优点:这里读取yaml文件来获取数据库配置信息,使代码通用。当然也可以参考上一篇文章,用字典来获取数据库信息。
C# 数据操作系列 – 15 SqlSugar 增删改查详解(超长篇)
继上一篇,以及上上篇,我们对SqlSugar有了一个大概的认识,但是这并不完美,因为那些都是理论知识,无法描述我们工程开发中实际情况。而这一篇,将带领小伙伴们一起试着写一个能在工程中使用的模板类。
SqlSugar在操作的时候需要一个Client,用来管理数据库连接,并操作数据库。所以我们写一个DbContext用来创建Client:
SqlSugar 提供了一个SimpleClient,这里面有很多可以直接拿来用的方法,而且这个是一个泛型类。也就是说我们可以使用它对单个实体类进行操作,这在开发中很重要。
对于一个程序而言,数据就像是血液一样重要。对于ORM框架,插入是一切来源的基础。所以我们先来看看SqlSugar的插入是怎样的吧:
这是SqlSugar在SimpleClient里提供的两个默认插入方法,一个是插入单个实体对象,一个是插入一组对象。
默认情况下,SqlSugar插入并不会将主键返回给数据。如果后续操作需要当前数据的主键,则可以调用另外一个方法:
通过这个方法可以获取一个默认的int类型主键值。
SqlSugar还有一种插入模式,通过AsInsertable返回一个 IInsertable泛型接口:
这种模式与SimpleClient的普通插入模式不同,它并不会直接执行插入动作,需要手动调用并执行插入动作:
执行动作,然后返回受影响的行数。
执行动作,然后将主键插入实体对象,返回插入结果。执行完成后,主键数据保存到实体示例中。
执行动作,然后返回主键值,不会更新实体。
有一点值得特别注意:
所有会返回主键的插入都只针对单个数据,如果一次插入多个数据,并不会返回主键信息也无法将主键信息更新入实体中。
以上都是全列插入,SqlSugar还提供了只插入部分列和忽略某些列两种模式:
介绍完插入,那么来介绍一下更新。正所谓,没有更新数据就是一滩死水,有了更新数据才有了变化。所以,就让我们来看看如何优雅的更新数据吧:
先来两个最简单的:
传入实体,直接更新到数据库中,需要注意的是这种更新模式只需要保证主键有值,且与之对应即可。
这是另一种条件更新,会更新满足whereExpression的所有元素,更新示例:
columns需要返回一个要更新的对象的属性列,也就是在columns中设置需要更新的内容。
同样,通过AsUpdateable开启高级模式:
然后可以针对这些今天更多的操作:
返回命令执行影响的行数
返回是否有变化,也就是影响行数是否大于0。
- 只更新某些列:
更新示例:
传入一个lambda表达式,使数据满足lambda表达式。要求lambda表达式只能用 == 来判断列是否等于某个值。
传入要更新的实际列名。其中 object 用来接一个匿名对象,其中属性名字就是要更新的值。
- 不更新某些列
- 条件更新
来,简单猜一猜这几个是什么意思呢?
可以说很简单明了的几种条件设置模式,lambda表示筛选更新数据,字段值判断条件更新。
其中 conditionType的值,推荐使用 ConditionalType枚举的值。
在实际开发中可能会遇到插入或更新是走的一个方法,所以我们就要寻找一个可以直接更新或插入的方法。SqlSugar为此提供了解决方案:
不过这个方法是在SugarClient里,我们可以通过:
在SimpleClient中获得 与之关联的SugarClient对象。
关于更新或插入判断标准是,主键是否有值。如果主键有值且在数据库中存在该条记录,则执行更新,否则执行插入。
删除在实际开发过程中是一个非常重要的功能点,所以如何快速有效的删除数据也是一件很重要的事。那么,就来看看如何执行删除吧:
删除没有其他需要注意的地方,第一个是条件删除,所有满足条件的都要删除。第二个删除单个对象,后面两个根据主键删除对象。
悄悄吐槽一下,主键的地方用object会比较好一点,因为动态对象会增加一次装箱拆箱的过程。
当然了,删除也有AsDeleteable方法。IDeleteable接口特别提供了根据sql语句删除的方法,除此之外没有别的需要注意的地方了。
一个好的ORM框架,至少五分功力在查询上,如何更快更准的查询成为了现在开发对ORM框架的要求。同时简单易用更是程序员对ORM的期望。
那么我们来看看SqlSugar在查询上的功力吧:
分页获取数据:
其中IConditionModel是一个空的接口,用来定义规范查询规范,实际上使用的是类:
那么,我们看一下 ConditionType,定义了各种判断依据:
那么我们简单看一下 使用IConditionModel进行分页是怎样的效果:
生成如下SQL语句:
可以看出两者并没有区别,只不过是不同的查询习惯。
按照之前的习惯,到目前应该可以结束了。但是SqlSugar还有一些很重要的地方没有介绍,所以就加个下期预告
下一篇将为大家分析SqlSugar的一些更高级的内容,查询的高级模式、事务以及批量操作
好,总结一下这一篇,我们在这一篇看到了SqlSugar在增删改查上的亮点,可以说更贴合实际业务需求开发。嗯,悄悄给个赞。
再有三篇的内容《C# 数据操作系列》就要完结了。从下一系列开始,就要步入工作中最重要的技术栈了:Asp.net Core。这是可以写入简历的。嗯,没错。下一系列计划以实战的形式介绍asp.net core的知识点和设置。
更多内容烦请关注我的博客《高先生小屋》
SQL增删改查语句
SQL增、删、改、查的SQL语句,请惠存。
1、创建表
创建表用CREATE TABLE+路径.表名
CREATE TABLE IF NOT EXISTS public.test
(
vc_name character(128),
vc_age character(128)
)
2、插入数据
插入数据用INSERT INTO 表名(字段) VALUES(值),可以批量添加。
INSERT INTO “test”(“vc_name”, “vc_age”) VALUES (‘张三’,‘29’)
3、备份数据表
先创建备份表名,然后,需要选择备份的字段及表。
create table test_back as
select * from test ;
4、删除表
此方法是针对整个表进行删除操作。
drop test
5、清除表内容
此方法是针对表内容进行清除
delete FROM test—清除表内所有内容
DELETE from test where vc_name=\’张三\’—-清除表中名字等于‘张三’的行
6、更新字段
用update去更新特定条件的字段。
update test set vc_age=‘30’ where vc_name=‘张三’
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。