当前位置: 首页 > news >正文

扩散模型对抗样本经典baselines劣

一、简化查询

1. 先看一下查询的例子

///

/// 账户获取服务

///

///

///

public class AccountGetService(AccountTable table, IShadowBuilder builder)

{

private readonly SqlSource _source = new(builder.DataSource);

private readonly IParamQuery _accountQuery

= builder.BuildResult(

table.ToQuery()

.And(account => account.Id.Equal())

.ToSelect()

.SelectSelfColumns()

);

///

/// 获取账户

///

///

///

///

public Task GetAsync(Account param, CancellationToken token = default)

=> _accountQuery.GetFirstAsync(_source, param, token);

}

2. 调用方式如下

var account = await accountGetService.GetAsync(new Account { Id = 1L });

3. 这个例子我们可以简化一下

参数直接使用Id(类型由Account简化为long)

很大一部分数据库操作都只有一个参数(GetById、GetByName等)

为此定义一个含单个属性类有点浪费

按上面的例子使用实体类作为参数也感觉怪怪的

DBShadow.net支持这种简化操作

单个参数无需封装,直接使用参数类型即可

public class AccountGetService(AccountTable table, IShadowBuilder builder)

{

private readonly SqlSource _source = new(builder.DataSource);

private readonly IParamQuery _accountQuery

= builder.BuildResult(

table.ToQuery()

.And(account => account.Id.Equal())

.ToSelect()

.SelectSelfColumns()

);

public Task GetAsync(long accountId, CancellationToken token = default)

=> _accountQuery.GetFirstAsync(_source, param, token);

}

var account = await accountGetService.GetAsync(1L);

4. 特别注意不要在Dapper中这样使用

Dapper是不支持这种简化操作

以下Dapper错误示例会抛出异常

System.InvalidOperationException:“Must add values for the following parameters: @Id”

await using var conn = _dataSource.CreateConnection();

var sql = "SELECT \"Id\",\"Title\",\"Content\",\"Done\",\"LastTime\" FROM \"Todo\" WHERE \"Id\"=@Id";

var first = await conn.QueryFirstOrDefaultAsync(sql, 1L);

二、 集合参数也支持简化操作

1. IN查询简化的例子

In的参数名是可选和前面例子的Equal是一样的,默认字段名

In查询的实参支持数组、集合及字典

只有In一个集合参数时支持直接传数组、集合或字典

这时参数名(eg: AccountIds)就无所谓取什么名了

因为不需要按参数名反射获取属性了

///

/// 批量账户获取服务

///

///

///

public class AccountBatchService(AccountTable table, IShadowBuilder builder)

{

private readonly SqlSource _source = new(builder.DataSource);

private readonly IParamQuery _accountQuery

= builder.BuildResult(

table.ToQuery()

.And(account => account.Id.In("AccountIds"))

.ToSelect()

.SelectSelfColumns()

);

///

/// 批量获取账户

///

///

///

///

public IAsyncEnumerable GetAsync(long[] accountIds, CancellationToken token = default)

=> _accountQuery.QueryAsync(_source, accountIds, token);

}

2. 以上调用的例子如下

[Fact]

public async Task Batch()

{

var count = 0;

var service = new AccountBatchService(table, builder);

var list = service.GetAsync([1L, 2L, 3L]);

await foreach (var item in list)

{

_output.WriteLine($"{item.Id}:{item.Amount}");

count++;

}

Assert.Equal(3, count);

}

// 1:100

// 2:200

// 3:300

三、泛型查询

1. 泛型服务类代码

该服务用来按字段Id查询表Account

参数TParam是泛型,这样可以直接使用DTO参数来查询,减少类型转化的开销

返回值TAccount也是泛型,这样就可以直接返回视图模型或者领域模型

这样的泛型服务类就非常的通用

///

/// 账户获取泛型服务

///

///

///

public class AccountGetService(AccountTable table, IShadowBuilder builder)

{

private readonly SqlSource _source = new(builder.DataSource);

private readonly IParamQuery _accountQuery

= builder.BuildResult(

table.ToQuery()

.And(account => account.Id.Equal())

.ToSelect()

.SelectSelfColumns()

);

///

/// 获取账户

///

///

///

///

public Task GetAsync(TParam param, CancellationToken token = default)

=> _accountQuery.GetFirstAsync(_source, param, token);

}

2. 中规中矩的调用方式

var service = new AccountGetService(_table, _builder);

var account = await service.GetAsync(new Account { Id = 1L });

Assert.NotNull(account);

3. 支持简单调用方式

var service = new AccountGetService(_table, _builder);

var account = await service.GetAsync(1L);

Assert.NotNull(account);

四、总结

DBShadow.net预编译比较智能

只有1个参数时支持化繁为简,支持直接传值做为参数值

这样可以节约定义只有一个属性的参数类

参数和返回值类型还可以定义为泛型,可以做到更加灵活装敲既耪

http://www.jsqmd.com/news/631225/

相关文章:

  • VisionPro 9.6 搭配图漾PS800-E1相机:从环境部署到第一个3D点云显示的完整避坑指南
  • MCP 协议实战——用 Claude API 构建可扩展的 AI 工具链 - AI
  • WeChatMsg终极指南:掌控你的数字记忆,永久保存微信聊天记录
  • 告别软解卡顿:用FFmpeg+RKmpp+RGA打造你的Rockchip盒子硬解播放器
  • 工业仿真软件辅助:Phi-3-mini解读Multisim电路设计与仿真结果
  • 从零开始理解IIC和SPI:硬件工程师的通信协议选择指南
  • 基于一阶RC模型,FFRLS+EKF算法的电池SOC在线联合估计Matlab程序
  • 绵阳轻集料混凝土厂家哪家强 - 今日灵感
  • WindowResizer终极指南:如何强制调整任意Windows窗口尺寸
  • Mysql的行级锁到底是怎么加的?灼
  • 3分钟掌握B站视频下载:BilibiliDown全功能使用指南
  • MetaboAnalystR 4.0:3个核心理念重塑代谢组学分析工作流
  • Omni-Vision Sanctuary提示词(Prompt)工程高级教程:从入门到精通
  • vLLM调度策略深度剖析:吞吐量优化背后的队列博弈
  • newaliases: fatal: file /etc/postfix/main.cf: parameter mydomain: bad parameter value: 解决方案
  • iPhone免电脑安装IPA?App-Installer让你随时随地安装第三方应用
  • 2026最权威的六大AI辅助论文神器解析与推荐
  • Playwright + MCP:AI驱动的浏览器自动化革命,告别脚本编写时代!
  • 旧手机变身3D打印控制中心:Octo4a完整安装与配置指南
  • all-MiniLM-L6-v2开源大模型部署:适配国产昇腾/寒武纪芯片可行性分析
  • AR/VR技术应用:从理论到实践
  • 用51单片机+Proteus 8.10复刻一个金属探测器(附完整代码、原理图与避坑指南)
  • 利用动作捕捉SDK实现MATLAB/Simulink实时数据交互
  • 贾子科学定理 TMM 框架:三层结构定律的自证闭环与形式化证明
  • 光电对抗:多模/复合制导及其集成技术(2)
  • [简化版 GAMES 101] 计算机图形学 04:二维变换上
  • 从零到一:手把手教你搭建Doxygen自动化文档生成环境
  • QTableWidget 表格组件概
  • Arduino+DHT11温湿度报警器:从硬件连接到代码调试的完整指南(附避坑技巧)
  • DDD难落地?就让AI干吧! - cleanddd-skills介绍俚