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

相关文章:

  • YApi本地部署后,接口测试插件cross-request装不上?手把手教你解决Chrome扩展加载难题
  • E57点云格式:从标准规范到工程实践的数据桥梁
  • 想要快速提分,如何选择雅思机构?2026雅思机构专业推荐榜单 - 速递信息
  • 如何用计算机视觉技术让原神效率提升300%:BetterGI智能辅助实战指南
  • 农业AI落地最后一公里:R语言轻量化产量预测模型部署指南(支持树莓派边缘推理,含Docker封装脚本)
  • 2026全国正规亲子鉴定机构标杆名录:资质与技术实力盘点 - 资讯焦点
  • 377. Java IO API - 什么是 Glob?——轻量级的文件名匹配语法
  • 踩过坑才明白:为什么 ZooKeeper 集群才是正经事
  • 3分钟掌握Taskbar11:Windows 11任务栏自定义的完整解决方案
  • 分享 种 .NET 桌面应用程序自动更新解决方案云
  • 2026届毕业生推荐的五大AI论文神器推荐
  • 浙江润鑫STW-18小车轮轴重检测磅 提升小型车辆轮轴重检测效率 - 资讯焦点
  • SINUMERIK数控系统数据采集全流程:从口令设置到S7协议配置的完整教程
  • CodeCombat离线部署踩坑记:从循环跳转到VIP权限,我的避坑指南
  • 2026 年粉尘烟气处理设备六大品牌排名及解析 - 十大品牌榜
  • SEATA分布式事务——AT模式琅
  • 一行命令,让你的 Code Agent 会读PDF
  • 2026 年废气处理设备六大品牌排名及解析 - 十大品牌榜
  • 厦门食品级不锈钢水箱厂家:二次供水安全的工程化解决路径 - 资讯焦点
  • 树莓派5-GPU加速实战:从OpenCL到TensorFlow Lite的探索之旅
  • 查看Ubuntu的版本
  • 你的标定结果真的准吗?深入聊聊张正友标定法背后的精度陷阱与评估方法
  • Vue3前端项目集成指南:调用Qwen3-14B-AWQ模型API实现智能交互
  • 工业设备故障预测R代码全披露:7个必用函数+4类特征工程技巧,90%工程师从未见过的生产级模板
  • Python DXF处理终极挑战:如何用ezdxf解决工程数据自动化难题
  • 国内免费云服务器阿贝云
  • 释放戴尔G15散热潜能:开源散热控制神器tcc-g15完全指南
  • 5步解锁Windows远程桌面完整功能:RDP Wrapper终极配置指南
  • GitHub开源项目日报 · 2026年4月8日 · Superpowers登顶,多款AI开发工具齐发力
  • 免疫组化蛋白检测技术指南:从抗体选择到信号放大