生成DTO的两种方式

假设我们现在有一个DTO,其属性包括两张表的属性,我们现在需要将sql语句查询得到的内容转为一个DTO对象,其解决方法如下: 


方法一:
SQLQuery query = session.createSQLQuery("select a.id as areaId,a.name as areaName,c.id as screenId,c.name as screenName from HPS_ParkingLotArea a left join HPS_ParkingLotScreen c on a.screenId = c.id ");
List list = query
.addScalar("areaId",Hibernate.INTEGER)
.addScalar("areaName",Hibernate.STRING)
.addScalar("screenId",Hibernate.INTEGER)
.addScalar("screenName",Hibernate.STRING)
.setResultTransformer(Transformers.aliasToBean(AreaWithScreen.class)).list();
return list;
在执行完sql语句之后,取到相应的属性,并赋予其类型,最后借助aliasToBean来转化为相应的类的实例。(此类无需有其他构造方法)




方法二: 
Query q = session.createQuery("select new com.hibernate.MsgInfo(m.id, m.cont, m.topic.title, m.topic.category.name) from Msg m");  
List<MsgInfo> list=q.list();  

其中,MsgInfo是DTO。值得留意的是,第二种方法中DTO必须提供带参数的构造方法,并且HQL语句中属性的位置要与构造方法中的位置逐一对应。


对于DTO对象要注意,是int还是Integer。如果是int,但set方法中的方法也是int,则如果为空,会报错。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Protobuf(Protocol Buffers)是一种轻量级的数据序列化格式,用于结构化数据的存储和交换。它可以将数据对象序列化为二进制格式,也可以将二进制数据反序列化为数据对象。相比于JSON,Protobuf具有更高的性能和更小的数据体积。 在使用Protobuf进行DTO(Data Transfer Object)对象与JSON之间的相互转换时,可以按照以下步骤进行: 1. 定义Protobuf消息类型:首先需要定义Protobuf消息类型,即定义数据结构和字段。可以使用Protobuf的语言特定的语法来定义消息类型,例如使用.proto文件定义。 2. 生成代码:根据定义的Protobuf消息类型,使用Protobuf编译器生成对应的代码文件。不同的编程语言可能有不同的编译器,例如对于Java语言可以使用protoc编译器生成Java类。 3. 将DTO对象转换为Protobuf消息:使用生成的代码,将DTO对象转换为对应的Protobuf消息对象。可以通过设置消息对象的字段值来实现。 4. 将Protobuf消息转换为JSON:使用Protobuf提供的序列化方法,将Protobuf消息对象序列化为二进制数据。然后可以使用JSON库将二进制数据转换为JSON格式的字符串。 5. 将JSON转换为Protobuf消息:使用JSON库将JSON格式的字符串解析为二进制数据。然后使用Protobuf提供的反序列化方法,将二进制数据反序列化为Protobuf消息对象。 总结一下,将DTO对象转换为JSON可以分为两步:DTO对象转换为Protobuf消息,Protobuf消息转换为JSON。反之,将JSON转换为DTO对象也可以分为两步:JSON转换为Protobuf消息,Protobuf消息转换为DTO对象。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值