Heim >Java >javaLernprogramm >So implementieren Sie eine Baumstrukturabfrage mit Springboot + Mybatis Plus

So implementieren Sie eine Baumstrukturabfrage mit Springboot + Mybatis Plus

WBOY
WBOYnach vorne
2023-05-21 17:01:062610Durchsuche

Hintergrund

Im tatsächlichen Entwicklungsprozess ist es häufig erforderlich, den Knotenbaum abzufragen und die Liste der untergeordneten Knoten basierend auf dem angegebenen Knoten abzurufen Der Baum ist für den Notfall unten aufgeführt.

Nutzungsszenarien

kann für Datenstrukturen mit hierarchischen Beziehungen wie Systemabteilungsorganisationen, Produktklassifizierungen, Stadtbeziehungen usw. verwendet werden; #🎜 🎜#Designidee


Rekursives Modell


Das heißt, Wurzelknoten, Zweigknoten, Blattknoten, das Datenmodell ist wie folgt :

# 🎜🎜#

idcodenameparent_code# 🎜🎜##🎜 🎜 #110000PC# 🎜🎜#220000手机0#🎜 🎜## ?? 🎜##🎜 🎜##🎜 🎜# 410002HP. NOTEBOOK10000#🎜🎜 ##🎜🎜 #5#🎜 🎜# 1000101 Implementierungscode#🎜 🎜## 🎜 🎜#Tabellendaten
INSERT INTO `tree_table`(`code`, `name`, `parent_code`) VALUES ("10000", "电脑", "0");
INSERT INTO `tree_table`(`code`, `name`, `parent_code`) VALUES ("10001", "联想笔记本", "10000");
INSERT INTO `tree_table`(`code`, `name`, `parent_code`) VALUES ("10002", "惠普笔记本", "10000");
INSERT INTO `tree_table`(`code`, `name`, `parent_code`) VALUES ("1000101", "联想拯救者", "10001");
INSERT INTO `tree_table`(`code`, `name`, `parent_code`) VALUES ("1000102", "联想小新系列", "10001");
#🎜 🎜#
@Data
@TableName("tree_table")
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class TreeTable {

    /**
     * 主键ID
     */
    @TableId(type = IdType.AUTO)
    private Integer id;
    /**
     * 编码
     */
    private String code;
    /**
     * 名称
     */
    private String name;
    /**
     * 父级编码
     */
    private String parentCode;

    /**
     * 子节点
     */
    @TableField(exist = false)
    private List<TreeTable> childNode;
}
mybatismapper
public interface TreeTableMapper extends BaseMapper<TreeTable> {
    /**
     * 获取树形结构数据
     *
     * @return 树形结构
     */
    public List<TreeTable> noteTree();
}
#🎜 🎜## 🎜🎜 #noteTree: Alle übergeordneten Knotendaten abrufen; Wenn Sie Mapper-XML bei Verwendung von mybatis nicht laden können, muss die folgende Konfiguration zu pom.xml hinzugefügt werden:
# 🎜🎜# 0
Lenovo #🎜🎜 ##🎜 🎜# 1000102 Lenovo Xiaoxin-Serie 10001
Tabellenstruktur
CREATE TABLE `tree_table` (
  `id` int NOT NULL AUTO_INCREMENT COMMENT "主键ID",
  `code` varchar(10) NOT NULL COMMENT "编码",
  `name` varchar(20) NOT NULL COMMENT "名称",
  `parent_code` varchar(10)  NOT NULL COMMENT "父级编码",
  PRIMARY KEY (`id`) USING BTREE
) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT="树形结构测试表";
Entity
xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.springboot.example.mysqltree.mapper.TreeTableMapper">
    <resultMap id="BaseResultMap" type="com.springboot.example.mysqltree.model.entity.TreeTable">
        <result column="id" property="id"/>
        <result column="code" property="code"/>
        <result column="name" property="name"/>
        <result column="parent_code" property="parentCode"/>
    </resultMap>
    <resultMap id="NodeTreeResult" type="com.springboot.example.mysqltree.model.entity.TreeTable"
               extends="BaseResultMap">
        <collection property="childNode" column="code" ofType="com.springboot.example.mysqltree.model.entity.TreeTable"
                    javaType="java.util.ArrayList" select="nextNoteTree">

        </collection>
    </resultMap>

    <sql id="Base_Column_List">
                id,
                code,
                `name`,
                parent_code
    </sql>
   
    <select id="nextNoteTree" resultMap="NodeTreeResult">
        select
        <include refid="Base_Column_List"/>
        from tree_table
        where parent_code=#[code]
    </select>
    <select id="noteTree" resultMap="NodeTreeResult">
        select
        <include refid="Base_Column_List"/>
        from tree_table
        where parent_code="0"
    </select>
</mapper>
nextNoteTree: Schleife, um untergeordnete Knotendaten abzurufen, bis der Blattknoten endet; 🎜🎜## 🎜🎜#Spalte: Der Spaltenname der zugehörigen Tabelle; 🎜🎜#
@Slf4j
@Component
public class TreeTableCommandLineRunner implements CommandLineRunner {
    @Resource
    private TreeTableMapper treeTableMapper;

    @Override
    public void run(String... args) throws Exception {
        log.info(JSONUtil.toJsonPrettyStr(treeTableMapper.noteTree()));
    }
}

Das obige ist der detaillierte Inhalt vonSo implementieren Sie eine Baumstrukturabfrage mit Springboot + Mybatis Plus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen