postgresql用dapper操作并且联合protobuf的array数组问题

假设你的pg数据库有这样一个table结构

test{

integer[] arr

}

如果用dapper查询ids,那么会返回一个int[]类型

如果你同时用protobuf生成了消息文件,

{

repeated int32 arr

}

他在程序中实际为一个集合类型(IList类型)

我阅读了Protobuf相关的代码和Dapper相关代码,

尝试重载操作符转换[] 为list 

但是发现reapted 字段属性只有get没有set.

曾经一度想改protobuf或者dapper的源代码进行适应,但是权衡后发现并不合适,

突然想起来protobuf生成的文件为partial类.(部分类)
顿时醍醐灌顶,思如泉涌.

由于proto文件生成的类会自动首字母大写.

而postgresql对列名和表名区分大小写,所以

proto文件生成的列名为Arr

而我们数据库里的列名为arr

写一个扩展类 

public sealed partial class test
{
    public RepeatedField<int> arr {
        get { return arr_; }
        set { arr_.AddRange(value); }
    }
}

再写一个Dapper的自定义列处理函数,如果要处理多种数组类型,那么把int改为T即可.

public class myCustomTypeCast : SqlMapper.TypeHandler<RepeatedField<int>>
{
    public n
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值