获取多个实体关联查询,封闭到对象
一、Hibernate Query查询部分属性
select new com.golf.back.dto.video.VideFavourDetailDto(v.id, v.thumb, v.videoName, v.videoUrl, v.orgUrl, v.orgUrlSmall, vc.catName, vc.parentId, v.summary, v.content, v.price,v.isFree, v.lookFront, vf.createTime) from VideoFavour vf,Video v ,VideoCat vc where vf.videoId=v.id and v.catId=vc.id
VideFavourDetailDto类添加相同参数类型及个数的实例化对象;
二、多表查询,返回多个实体
StringBuffer sql = new StringBuffer("select {vpl.*}, {v.*}, {vc.*} from zg_video_playlog vpl "); sql.append("left join zg_video v on vpl.video_id=v.id "); sql.append("left join zg_video_cat vc on vc.id=v.cat_id "); sql.append("group by vpl.video_id "); sql.append("order by vpl.id desc"); Query query = super.getSession().createSQLQuery(sql.toString()) .addEntity( "vpl" , VideoPlayLog.class ) .addEntity( "v" , Video.class ) .addEntity("vc", VideoCat.class); query.setFirstResult(startPos); query.setMaxResults(pageSize); List<Object[]> list = query.list(); List<VideFavourDetailDto> vdList = new ArrayList<VideFavourDetailDto>(); if(null!=list && list.size()>0){ VideFavourDetailDto dto = null; VideoPlayLog vpl = null; Video v = null; VideoCat vc = null; for(int i=0; i<list.size(); i++){ vpl = (VideoPlayLog)list.get(i)[0]; v = (Video)list.get(i)[1]; vc = (VideoCat)list.get(i)[2]; dto = new VideFavourDetailDto(vpl.getId(), v.getId(), v.getThumb(), v.getVideoName(), v.getVideoUrl(), v.getOrgUrl() , v.getOrgUrlSmall(), vc.getCatName(), vc.getParentId(), v.getSummary(), v.getContent(), v.getPrice(), v.getIsFree(), v.getLookFront(), vpl.getCreateTime(), vpl.getPlayTimes()); vdList.add(dto); } }
特别注意: 这块有些问题,明明应该返回Clazz的List的,但确返回包含Clazz和Student的Object的List, 使用场合:基于对象的查询,复杂查询
相关推荐
c#读取CAD的dxf文件,包括样式,颜色,存储文件,只要需要的都能有,,并直接存csv文件
dxf.AddEntity(entity); // save to file dxf.Save(file); // this check is optional but recommended before loading a DXF file DxfVersion dxfVersion = DxfDocument.CheckDxfFileVersion(file); // ...
原创代码:对netdxf类库扩展的示例,构建你自己的dxf文件处理类。 C# public void AddText(string text, Vector3 position, double height,... this.AddEntity(new Text(splitstr[i], pos, height, style)); } }
uniVocity-kairosdb 带有自定义数据存储的示例项目,使能够访问 KairosDB 编码 创建自定义数据存储时,至少需要... kairosConfig.addEntity("observations", "observationKind"); EngineConfiguration engineConfig
becs-位屏蔽的ECS 快速简单的ECS库。 在引擎盖下使用位屏蔽以提高性能。 用法 npm install --save becs import { System , // Choose one from the following ... addEntity ( { Position : { x : 1 , y : 2
IndexedDB ORM /包装器 该项目仍处于Alpha状态,某些情况可能会发生变化 该项目的目的是简化IndexedDB数据库的工作。 当前,我们依赖于但根据反馈,我们将删除或保留此依赖关系。... addEntity ( exampleDef ,
MaltegoTransform-Python 免责声明:这不是我... addEntity ( "maltego.Phrase" , "hello world" );me . returnOutput ()读取输入这是显示从实体读取输入并将其返回到图形的简单转换(在这种情况下使用域并返回包含该域
实现dxf文件的解析功能,可实现版本的不同
core-spring-boot-autoconfigure spring boot自动化配置,封装第三方如百度鹰眼、阿里云api...public void addEntity() throws Exception { int serviceId = baiduProperties.getServiceIds().get(0); String entity
这是一套ecs游戏框架,里面包含ECS框架用于管理场景实体,一些常用2D碰撞检测及游戏中常用的工具项目规划及讨论交流群点击链接...您需要在场景内进行创建或添加实体(createEntity / addEntity)注意:创建实体需要在场
export let addEntity = ( entityArray , child ) => { // if has no parent - add to the top level if ( ! child . parentId ) { return [ ... entityArray , child ] ; } // trace path to parent ...