当前位置: 首页 > 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/624068/

相关文章:

  • 10分钟打造专属AI声优:RVC语音转换框架完全指南 [特殊字符]
  • 智能验证码自动化解决方案:Cursor Free VIP项目的技术架构与实现路径
  • 终极Betaflight配置器使用指南:5步完成无人机完美调校
  • 别再死记公式了!用Excel手把手带你算一遍神经网络的梯度更新(附详细步骤截图)
  • 别再只用Sniper了!BurpSuite Intruder四种爆破模式保姆级对比与实战选型指南
  • TrendPublish 模板开发完全手册:从零打造个性化微信公众号模板
  • 终极免费GTA5增强工具:YimMenu完全使用指南
  • 终极暗黑破坏神2存档编辑器:d2s-editor完全指南
  • 5分钟搞定B站视频下载:BilibiliDown让你的离线收藏库瞬间扩容![特殊字符]
  • HBuilderX 实战:从零搭建uni-app项目到微信小程序部署全流程
  • Ostrakon-VL-8B行业落地:药店阴凉柜温湿度标签识别+GSP合规性自动核验
  • 终极视觉自动化测试指南:5分钟掌握零代码解决方案
  • Suo5实战教程:如何在复杂网络环境中部署和使用高性能HTTP正向代理
  • 终极指南:如何用Python-Chess快速构建智能象棋应用
  • Linux系统遭遇挖矿病毒深度排查与根治指南
  • 别只顾着改数据,也要把留痕这件事做好,SAP 里用 Change Documents 做业务对象审计追踪
  • 科研人必备:5分钟搞定arXiv邮件订阅,让最新论文自动送到你邮箱
  • 【51单片机】红外通信实战:NEC协议解码与电机控制
  • Behaviac行为树框架:构建智能AI决策的终极指南
  • 一个人的取经之路
  • 团队协作营销文案工具推荐|3 款实用工具,高效不内耗
  • UOS系统下Python3.7环境配置全攻略:从安装到PyInstaller打包避坑指南
  • 避坑指南:若依集成通义千问时,如何处理流式响应和HTML样式渲染?
  • Illustrator脚本终极指南:3分钟掌握22个效率神器,免费提升设计效率500%
  • JAVA-SSM学习2 Spring-注解开发
  • APK Installer:Windows原生运行Android应用的技术架构深度解析
  • 定义莫尔-库仑土体材料
  • 如何用Hessian矩阵快速判断凸函数?附Python代码示例
  • 数据预处理实战指南:从原始数据到模型输入的完整流程
  • 芯片SVD文件生成实战:从零到一构建ARM Cortex-M4设备描述