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

相关文章:

  • Leather Dress Collection 模型微调概念入门:何时需要以及如何准备数据
  • 2026仓储货架技术分享:台州货架/嘉兴货架/奉化货架/宁波货架/杭州货架/江北货架/海曙货架/温州货架/湖州货架/选择指南 - 优质品牌商家
  • Linux驱动篇开篇——《驱动篇》
  • 幻镜NEURAL MASK在文化遗产数字化中的应用:古籍插图主体提取
  • 荣耀最强数字旗舰来了!荣耀600 Pro真机揭晓
  • 【推荐】银发经济小程序
  • ANIMATEDIFF PRO效果展示:看看这些用文字生成的电影级动态画面
  • Llama-3.2V-11B-cot企业实操:中小企业低成本视觉AI部署方案
  • 构建基于SDMatte的智能相册:自动人物分类与场景相册生成
  • Phi-3-mini-4k-instruct-gguf赋能课程设计:自动生成Multisim电路仿真报告
  • CHORD-X在复杂网络环境下的部署:解决403 Forbidden等访问问题
  • Hunyuan-MT-7B-WEBUI部署详解:Jupyter环境下一键启动全流程
  • RMBG-2.0 API封装教程:将Streamlit工具转为REST接口供其他系统调用
  • LFM2.5-1.2B-Thinking-GGUF快速体验:无需安装的在线API调用演示
  • DeepSeek-R1-Distill-Qwen-1.5B开箱即用:本地AI服务搭建全攻略
  • 新概念英语第一册125_Tea for two
  • Python的__enter__中的预防泄漏资源
  • 板级支持包的构建
  • Hunyuan-MT-7B部署教程:vLLM推理+Chainlit前端完整配置
  • CosyVoice入门指南:使用Typora编辑Markdown并一键生成语音笔记
  • OFA图文匹配系统实战教程:3步搭建智能内容审核Web应用
  • Pixel Dream Workshop 软件测试实战:AI图像生成模型的自动化测试策略
  • 模型血缘追踪不是可选项,而是生存线:20年MLOps专家亲授7步构建不可篡改的AI溯源链
  • CentOS 7.9 SNAT/DNAT 详解与 VMware 17 实验全流程【20260412】001篇
  • Stable Diffusion Anything V5保姆级教程:零基础小白也能玩转AI绘画
  • 一文学习 Spring 声明式事务源码全流程总结脊
  • 2026年质量好的长春钝化处理工艺/汽车零部件钝化处理/铝合金钝化处理/压铸件钝化处理行业内知名厂家推荐 - 品牌宣传支持者
  • 锂电池测试规范MSDS与UN38.3认证的关系
  • 训练阶段未对齐,推理必然崩塌!,SITS2026首次公开长上下文预训练数据配比黄金公式(含Python验证脚本)
  • 翻译模型Hunyuan-MT-7B体验分享:开箱即用,38种语言互译效果超预期