查询部门----返回给前台TreeView数据格式的数据
实体类:
public class AddressTreeDto {
private Long id;
private String text;//位置名称
private Long pId;//上一级
private Integer able; private List<AddressTreeDto> nodes; public Long getId() {
return id;
} public void setId(Long id) {
this.id = id;
} public String getText() {
return text;
} public void setText(String text) {
this.text = text;
} public Long getpId() {
return pId;
} public void setpId(Long pId) {
this.pId = pId;
} public Integer getAble() {
return able;
} public void setAble(Integer able) {
this.able = able;
} public List<AddressTreeDto> getNodes() {
return nodes;
} public void setNodes(List<AddressTreeDto> nodes) {
this.nodes = nodes;
}
}
Service接口:
public interface AddressService {
//查询所有存放地,返回TreeView数据格式 List<AddressTreeDto> getAddressTree();
}
ServiceImpl实现类
public class AddressServiceImpl implements AddressService {
@Autowired
private AddressMapper addressMapper;
private List<AddressTreeDto> getChild(Long id, List<AddressTreeDto> rootAddress) {
// 子菜单
List<AddressTreeDto> childList = new ArrayList<>();
for (AddressTreeDto treeDto : rootAddress) {
// 遍历所有节点,将父菜单id与传过来的id比较
if (treeDto.getpId()!=null) {
if (treeDto.getpId().equals(id)) {
childList.add(treeDto);
}
}
}
// 把子菜单的子菜单再循环一遍
for (AddressTreeDto treeDto: childList) {
// 没有url子菜单还有子菜单---判断还有子菜单
if(getIds(treeDto.getId())!=null){
//递归
treeDto.setNodes(getChild(treeDto.getId(),rootAddress));
}
} // 递归退出条件
if (childList.size() == 0) {
return null;
}
return childList;
}
@Override
public List<AddressTreeDto> getAddressTree() {
// 原始的数据
List<AddressTreeDto> rootAddress = addressMapper.selectTree(Constants.ABLE_CONFIG.DEFAULT_ABLE);
// 查看结果
for (AddressTreeDto treeDto1 : rootAddress) {
System.out.println(treeDto1);
}
// 最后的结果
List<AddressTreeDto> addressList = new ArrayList<>();
// 先找到所有的一级菜单
for (int i = 0; i < rootAddress.size(); i++) {
// 一级菜单没有parentId
if (rootAddress.get(i).getpId()==0) {
addressList.add(rootAddress.get(i));
}
}
// 为一级菜单设置子菜单,getChild是递归调用的
for (AddressTreeDto treeDto1 : addressList) {
treeDto1.setNodes(getChild(treeDto1.getId(), rootAddress));
}
return addressList; } }
查询部门----返回给前台TreeView数据格式的数据的更多相关文章
- js上传文件带参数,并且,返回给前台文件路径,解析上传的xml文件,存储到数据库中
ajaxfileupload.js jQuery.extend({ createUploadIframe: function(id, uri) { //create frame var frameId ...
- <MyBatis>入门五 查询的返回值处理
select : 返回对象: <select id = " " resultType= "对象的全类名" /> List: <sele ...
- Atitit.列表页面and条件查询的实现最佳实践(1)------设置查询条件and提交查询and返回json数据
Atitit.列表页面and条件查询的实现最佳实践(1)------设置查询条件and提交查询and返回json数据 1. 1. 配置条件字段@Conditional 1 1 2. 2. 配置条件字段 ...
- 部门树形结构,使用Treeview控件显示部门
部门树形结构.设计张部门表用于存储部门编码.名称.上级部门id,使用Treeview控件显示部门树,并实现部门增删改.移动.折叠等功能.特别提示,部门有层级关系,可用donetbar的adtree控件 ...
- PDO 查询mysql返回字段整型变为String型解决方法
PDO 查询mysql返回字段整型变为String型解决方法 使用PDO查询mysql数据库时,执行prepare,execute后,返回的字段数据全都变为字符型. 例如id在数据库中是Int的,查询 ...
- **CI两种方式查询所返回的结果数量
区别:第一个是有条件的:第二个没有条件 $this->db->count_all_results(); 允许你获得某个特定的Active Record查询所返回的结果数量.可以使用Acti ...
- Atitit.列表页and查询条件的最佳实践(1)------设定搜索条件and提交查询and返回json数据
Atitit.列表页and查询条件的最佳实践(1)------设置查询条件and提交查询and返回json数据 1. 1. 配置条件字段@Conditional 1 1 2. 2. 配置条件字段显示类 ...
- Linq to Sql:N层应用中的查询(上) : 返回自定义实体
原文:Linq to Sql:N层应用中的查询(上) : 返回自定义实体 如果允许在UI层直接访问Linq to Sql的DataContext,可以省去很多问题,譬如在处理多表join的时候,我们使 ...
- Hibernate SQLQuery 原生SQL 查询及返回结果集处理-1
第一篇:官方文档的处理方法,摘自官方 在迁移原先用JDBC/SQL实现的系统,难免需要采用hibernat native sql支持. 1.使用SQLQuery hibernate对原生SQL查询执行 ...
随机推荐
- 如何用jquery实现实时监控浏览器宽度
如何用jquery实现实时监控浏览器宽度 2013-06-05 14:36匿名 | 浏览 3121 次 $(window).width();这代码只能获取浏览器刷新时的那一刻的宽度,如何才能达到实时获 ...
- 关于var与function的解析顺序问题
先给几段代码,看看你能知道运行结果不 function example1() { var f = function() {return 1;}; return f; var f = function( ...
- magento2.2.5安装
首先肯定要去下载源码,然后配置虚拟主机访问,例:http://magento.cn 这里我们采用命令行安装: php bin/magento setup:install --admin-firstna ...
- 一次ASM磁盘空间假装耗尽 ORA-15041: DISKGROUP SPACE EXHAUSTED
给ASM磁盘新增一块盘进去,ASM_DISK2剩余空间四百多G: SQL> select * from v$asm_diskgroup; GROUP_NUMBER NAME ...
- JavaScript高级程序设计学习(六)之设计模式
每种编程语言都有其自己的设计模式.不禁让人疑惑设计模式是用来做什么?有什么用? 简单的说,设计模式是为了让代码更简洁,更优雅,更完美. 同时设计模式也会让软件的性能更好,同时也会让程序员们更轻松.设计 ...
- zabbix学习-zabbix安装
本次安装教程完全参考官方rpm安装教程: https://www.zabbix.com/documentation/3.4/zh/manual/installation/install_from_pa ...
- PAT A1098 Insertion or Heap Sort (25 分)——堆排序和插入排序,未完待续。。
According to Wikipedia: Insertion sort iterates, consuming one input element each repetition, and gr ...
- spring batch批量处理框架
spring batch精选,一文吃透spring batch批量处理框架 前言碎语 批处理是企业级业务系统不可或缺的一部分,spring batch是一个轻量级的综合性批处理框架,可用于开发企业信息 ...
- C# 语法二 值类型引用类型
1.值类型 2.引用类型 一 值类型 值类型存放在栈中,引用类型存放在堆中. 值类型有:数值.布尔.字符,例如:int i;bool i2;char cr='a'; 二 引用类型 大多数类型是引用类型 ...
- 如何利用Skyline的TerraExplorer Pro 6.5提供的API接口实现矢量图层数据的动态投影
Skyline 支持国内常见的地图投影坐标系,包括WGS84.Beijing54.西安80.2000坐标系等,也可以自定义坐标系,比如一些做过参数变换加密的坐标系等. <!DOCTYPE htm ...