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

从数据采集到回放验证:ADTF 适配 ROS 的 ADAS 测试实践涣

一、简化查询

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/626786/

相关文章:

  • 模型热更新失败、KV Cache泄漏、Tokenizer线程阻塞——2026奇点大会紧急预警的3个“静默杀手”级部署漏洞
  • (十九)32天GPU测试从入门到精通-SGLang 特性与测试day17
  • Hypermesh+Abaqus齿轮啮合仿真:从网格划分到结果后处理的完整避坑指南
  • 微信对接OpenClaw的常见问题和解决方案僚
  • 游戏开发入门:游戏循环与基础架构
  • 协同进化新范式:CMPSO如何通过分而治之破解多目标优化难题
  • Grafana离线环境下的插件管理与数据源配置实战
  • PDF-Parser-1.0文档理解模型:5分钟快速部署,小白也能轻松搞定
  • 银行数据中心基础设施建设与运维管理【1.0】
  • 动态维度TensorRT引擎调用实战:从Python到C++的完整指南
  • 别再被pyodbc的IM002错误搞懵了!手把手教你搞定Access驱动缺失问题
  • 从零到一:基于DS18B20的单总线温度监测系统实战指南
  • 从海康到大华:ONVIF协议兼容性避坑指南(附主流厂商测试报告)
  • 基于File-Based App开发MVP项目员
  • .NET微服务架构:从理论到实战的全维度解析
  • 【自定义类型实战解析】枚举与联合体:从语法到内存布局的深度探索
  • 2026年比较好的路灯杆优质厂家推荐榜 - 品牌宣传支持者
  • 实战案例:用Qwen3-TTS-Tokenizer-12Hz为短视频生成专属配音
  • DDD难落地?就让AI干吧! - cleanddd-skills介绍窗
  • 利用国内镜像源加速PyTorch2.0(GPU版)命令行安装全攻略
  • Nunchaku FLUX.1 CustomV3场景应用:电商海报、社交配图、角色设计一键生成
  • 低空经济“大脑”全解析:飞行控制系统如何定义未来天空?
  • 实现自定义向量存储后端
  • 从DeepSeek宕机到高并发救星:用vLLM的PagedAttention和Continuous Batching搭建你的大模型API服务
  • 云原生应用开发十二要素
  • 玩客云打造全能家庭服务器:Armbian+CasaOS+Docker+青龙面板+内网穿透一站式部署
  • AI开发-python-langchain框架(--并行流程 )抠
  • 大模型优化新思路:Chinchilla法则的实践与突破
  • 红帽撤离中国,一个时代的落幕。
  • Qwen3-TTS-1.7B-Base部署教程:镜像免配置+GPU显存优化实践