java 各种 树形结构构图方法和数据库函数 【非控件】

简介: java 各种 树形结构构图方法和数据库函数 【非控件】

一、数据库类:

1.建表:

 CREATE TABLE `dept` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `deptid` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;

数据:

INSERT INTO `dept` VALUES ('1', '语音业务部', null);
  INSERT INTO `dept` VALUES ('2', '小云AI', '1');
  INSERT INTO `dept` VALUES ('3', '云客宝', '1');
  INSERT INTO `dept` VALUES ('4', '流量业务部', null);
  INSERT INTO `dept` VALUES ('5', 'MIFI', '4');
  INSERT INTO `dept` VALUES ('6', '物联网卡', '4');

查询业务部下所有的子部门:

SELECT
        b.*
    FROM
        dept a
    INNER JOIN dept b ON a.id = b.deptid
    WHERE
        a.id = 1

00bc08727ac3281d473e6caa726784f.png

二、 数据库函数类:

ae0bb61dee872929faa9c89ab41c047.png

cba818e745cd644159b40a72aa7d9f0.png

delimiter /
    DROP FUNCTION IF EXISTS `mydb`.`getChild`/
    CREATE FUNCTION `getChild`(rootId varchar(36))
      RETURNS VARCHAR(1000)
      BEGIN
        DECLARE ptemp VARCHAR(1000);
        DECLARE ctemp VARCHAR(1000);
        SET ptemp = '#';
        SET ctemp = rootId;
        WHILE ctemp IS NOT NULL DO
          SET ptemp = concat(ptemp, ',', ctemp);
          SELECT group_concat(id)
          INTO ctemp
          FROM t_tree_table
          WHERE FIND_IN_SET(pid, ctemp) > 0;
        END WHILE;
        RETURN ptemp;
      END;

下面是查询语句,只要在getChild的参数中输入需要查询的父级id即可,

例如示例数据中的 河南 的 id 为 2.

select * from t_tree_table where find_in_set(id,getChild(2));
目录
相关文章
|
23天前
|
SQL 数据挖掘 测试技术
南大通用GBase8s数据库:LISTAGG函数的解析
南大通用GBase8s数据库:LISTAGG函数的解析
|
25天前
|
消息中间件 Java Kafka
在Java中实现分布式事务的常用框架和方法
总之,选择合适的分布式事务框架和方法需要综合考虑业务需求、性能、复杂度等因素。不同的框架和方法都有其特点和适用场景,需要根据具体情况进行评估和选择。同时,随着技术的不断发展,分布式事务的解决方案也在不断更新和完善,以更好地满足业务的需求。你还可以进一步深入研究和了解这些框架和方法,以便在实际应用中更好地实现分布式事务管理。
|
1月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
68 9
|
27天前
|
JSON Java 关系型数据库
Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
在Java中,使用mybatis-plus更新实体类对象到mysql,其中一个字段对应数据库中json数据类型,更新时报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
41 4
Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
|
23天前
|
安全 Java 开发者
Java中WAIT和NOTIFY方法必须在同步块中调用的原因
在Java多线程编程中,`wait()`和`notify()`方法是实现线程间协作的关键。这两个方法必须在同步块或同步方法中调用,这一要求背后有着深刻的原因。本文将深入探讨为什么`wait()`和`notify()`方法必须在同步块中调用,以及这一机制如何确保线程安全和避免死锁。
37 4
|
23天前
|
Java
深入探讨Java中的中断机制:INTERRUPTED和ISINTERRUPTED方法详解
在Java多线程编程中,中断机制是协调线程行为的重要手段。了解和正确使用中断机制对于编写高效、可靠的并发程序至关重要。本文将深入探讨Java中的`Thread.interrupted()`和`Thread.isInterrupted()`方法的区别及其应用场景。
24 4
|
21天前
|
Java 数据处理 数据安全/隐私保护
Java处理数据接口方法
Java处理数据接口方法
24 1
|
23天前
|
SQL 测试技术 数据库
|
SQL 存储 分布式计算
【Java新特性学习 四】JDK8: 库函数新特性之Optional,Streams,Date/Time API(JSR 310),Base64,并行数组
【Java新特性学习 四】JDK8: 库函数新特性之Optional,Streams,Date/Time API(JSR 310),Base64,并行数组
82 0
|
存储 小程序 Java
Java基础——函数与数组
今天让我们进一步学习一下java中的函数与数组吧。
130 0
Java基础——函数与数组
下一篇
DataWorks