欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL多層級(jí)結(jié)構(gòu)-區(qū)域表使用樹詳解

 更新時(shí)間:2016年07月08日 21:59:08   投稿:mdxy-dxy  
前面我們大概介紹了一下樹結(jié)構(gòu)表的基本使用。在我們項(xiàng)目中有好幾塊有用到多層級(jí)的概念。下面我們哪大家都比較熟悉的區(qū)域表來做演示

1.1. 前言

前面我們大概介紹了一下樹結(jié)構(gòu)表的基本使用。在我們項(xiàng)目中有好幾塊有用到多層級(jí)的概念。下面我們哪大家都比較熟悉的區(qū)域表來做演示。
1.2. 表結(jié)構(gòu)和數(shù)據(jù)

區(qū)域表基本結(jié)構(gòu),可能在你的項(xiàng)目中還有包含其他字段。這邊我只展示我們關(guān)心的字段:

CREATE TABLE `area` (
 `area_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '地區(qū)ID',
 `name` varchar(40) NOT NULL DEFAULT 'unkonw' COMMENT '地區(qū)名稱',
 `area_code` varchar(10) NOT NULL DEFAULT 'unkonw' COMMENT '地區(qū)編碼',
 `pid` int(11) DEFAULT NULL COMMENT '父id',
 `left_num` mediumint(8) unsigned NOT NULL COMMENT '節(jié)點(diǎn)左值',
 `right_num` mediumint(8) unsigned NOT NULL COMMENT '節(jié)點(diǎn)右值',
 PRIMARY KEY (`area_id`),
 KEY `idx$area$pid` (`pid`),
 KEY `idx$area$left_num` (`left_num`),
 KEY `idx$area$right_num` (`right_num`)
)

區(qū)域表數(shù)據(jù): area
導(dǎo)入到test表

mysql -uroot -proot test < area.sql

1.1. 區(qū)域表的基本操作

查看 '廣州' 的相關(guān)信息

SELECT * FROM area WHERE name LIKE '%廣州%';
+---------+-----------+-----------+------+----------+-----------+
| area_id | name   | area_code | pid | left_num | right_num |
+---------+-----------+-----------+------+----------+-----------+
|  2148 | 廣州市  | 440100  | 2147 |   2879 |   2904 |
+---------+-----------+-----------+------+----------+-----------+

查看 '廣州' 所有孩子

SELECT c.* 
FROM area AS p, area AS c
WHERE c.left_num BETWEEN p.left_num AND p.right_num
 AND p.area_id = 2148;
+---------+-----------+-----------+------+----------+-----------+
| area_id | name   | area_code | pid | left_num | right_num |
+---------+-----------+-----------+------+----------+-----------+
|  2148 | 廣州市  | 440100  | 2147 |   2879 |   2904 |
|  2161 | 從化市  | 440184  | 2148 |   2880 |   2881 |
|  2160 | 增城市  | 440183  | 2148 |   2882 |   2883 |
|  2159 | 花都區(qū)  | 440114  | 2148 |   2884 |   2885 |
|  2158 | 番禺區(qū)  | 440113  | 2148 |   2886 |   2887 |
|  2157 | 黃埔區(qū)  | 440112  | 2148 |   2888 |   2889 |
|  2156 | 白云區(qū)  | 440111  | 2148 |   2890 |   2891 |
|  2154 | 天河區(qū)  | 440106  | 2148 |   2892 |   2893 |
|  2153 | 海珠區(qū)  | 440105  | 2148 |   2894 |   2895 |
|  2152 | 越秀區(qū)  | 440104  | 2148 |   2896 |   2897 |
|  2151 | 荔灣區(qū)  | 440103  | 2148 |   2898 |   2899 |
|  2150 | 東山區(qū)  | 230406  | 2148 |   2900 |   2901 |
|  2149 | 其它區(qū)  | 440189  | 2148 |   2902 |   2903 |
+---------+-----------+-----------+------+----------+-----------+

查看 '廣州' 所有孩子 和 深度 并顯示層級(jí)關(guān)系

SELECT sub_child.area_id,
 (COUNT(sub_parent.name) - 1) AS depth,
 CONCAT(REPEAT(' ', (COUNT(sub_parent.name) - 1)), sub_child.name) AS name
FROM (
 SELECT child.* 
 FROM area AS parent, area AS child
 WHERE child.left_num BETWEEN parent.left_num AND parent.right_num
  AND parent.area_id = 2148
) AS sub_child, (  
 SELECT child.* 
 FROM area AS parent, area AS child
 WHERE child.left_num BETWEEN parent.left_num AND parent.right_num
  AND parent.area_id = 2148
) AS sub_parent
WHERE sub_child.left_num BETWEEN sub_parent.left_num AND sub_parent.right_num
GROUP BY sub_child.area_id
ORDER BY sub_child.left_num;
+---------+-------------+-------+
| area_id | name    | depth |
+---------+-------------+-------+
|  2148 | 廣州市   |   0 |
|  2161 |  從化市  |   1 |
|  2160 |  增城市  |   1 |
|  2159 |  花都區(qū)  |   1 |
|  2158 |  番禺區(qū)  |   1 |
|  2157 |  黃埔區(qū)  |   1 |
|  2156 |  白云區(qū)  |   1 |
|  2154 |  天河區(qū)  |   1 |
|  2153 |  海珠區(qū)  |   1 |
|  2152 |  越秀區(qū)  |   1 |
|  2151 |  荔灣區(qū)  |   1 |
|  2150 |  東山區(qū)  |   1 |
|  2149 |  其它區(qū)  |   1 |
+---------+-------------+-------+

顯示 '廣州' 的直系祖先(包括自己)

SELECT p.* 
FROM area AS p, area AS c
WHERE c.left_num BETWEEN p.left_num AND p.right_num
 AND c.area_id = 2148;
+---------+-----------+-----------+------+----------+-----------+
| area_id | name   | area_code | pid | left_num | right_num |
+---------+-----------+-----------+------+----------+-----------+
|  2147 | 廣東省  | 440000  |  0 |   2580 |   2905 |
|  2148 | 廣州市  | 440100  | 2147 |   2879 |   2904 |
|  3611 | 中國   | 100000  |  -1 |    1 |   7218 |
+---------+-----------+-----------+------+----------+-----------+

向 '廣州' 插入一個(gè)地區(qū) '南沙區(qū)'

-- 更新左右值
UPDATE area SET left_num = left_num + 2 WHERE left_num > 2879;
UPDATE area SET right_num = right_num + 2 WHERE right_num > 2879;
 
-- 插入 '南沙區(qū)' 信息
INSERT INTO area
SELECT NULL, '南沙區(qū)', '440115', 2148, left_num + 1, left_num + 2
FROM area WHERE area_id = 2148;
 
-- 查看是否滿足要求
SELECT c.* 
FROM area AS p, area AS c
WHERE c.left_num BETWEEN p.left_num AND p.right_num
 AND p.area_id = 2148;
+---------+-----------+-----------+------+----------+-----------+
| area_id | name   | area_code | pid | left_num | right_num |
+---------+-----------+-----------+------+----------+-----------+
|  2148 | 廣州市  | 440100  | 2147 |   2879 |   2906 |
|  3612 | 南沙區(qū)  | 440115  | 2148 |   2880 |   2881 |
|  2161 | 從化市  | 440184  | 2148 |   2882 |   2883 |
|  2160 | 增城市  | 440183  | 2148 |   2884 |   2885 |
|  2159 | 花都區(qū)  | 440114  | 2148 |   2886 |   2887 |
|  2158 | 番禺區(qū)  | 440113  | 2148 |   2888 |   2889 |
|  2157 | 黃埔區(qū)  | 440112  | 2148 |   2890 |   2891 |
|  2156 | 白云區(qū)  | 440111  | 2148 |   2892 |   2893 |
|  2154 | 天河區(qū)  | 440106  | 2148 |   2894 |   2895 |
|  2153 | 海珠區(qū)  | 440105  | 2148 |   2896 |   2897 |
|  2152 | 越秀區(qū)  | 440104  | 2148 |   2898 |   2899 |
|  2151 | 荔灣區(qū)  | 440103  | 2148 |   2900 |   2901 |
|  2150 | 東山區(qū)  | 230406  | 2148 |   2902 |   2903 |
|  2149 | 其它區(qū)  | 440189  | 2148 |   2904 |   2905 |
+---------+-----------+-----------+------+----------+-----------+

相關(guān)文章

  • mysql 5.7.17 安裝教程 附MySQL服務(wù)無法啟動(dòng)的解決方法

    mysql 5.7.17 安裝教程 附MySQL服務(wù)無法啟動(dòng)的解決方法

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.17安裝教程,并且為大家分享了MySQL服務(wù)無法啟動(dòng)的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • mysql 5.7.17 winx64免安裝版配置方法圖文教程

    mysql 5.7.17 winx64免安裝版配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.17 winx64免安裝版配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • mysql錯(cuò)誤處理之ERROR 1786 (HY000)

    mysql錯(cuò)誤處理之ERROR 1786 (HY000)

    最近一直在mysql的各個(gè)版本直接徘徊,這中間遇到了各種各樣的錯(cuò)誤,將已經(jīng)處理完畢的幾個(gè)錯(cuò)誤整理了一下,分享給大家,首先我們來看看錯(cuò)誤提示 ERROR 1786 (HY000)
    2014-07-07
  • 阿里面試MySQL死鎖問題的處理

    阿里面試MySQL死鎖問題的處理

    這篇文章主要介紹了在阿里面試中的一個(gè)問題MySQL死鎖問題的處理回答,對(duì)常見的死鎖案例進(jìn)行相關(guān)分析與探討,以及如何去盡可能避免死鎖給出一些建議
    2022-03-03
  • MySQL的視圖和索引用法與區(qū)別詳解

    MySQL的視圖和索引用法與區(qū)別詳解

    這篇文章主要介紹了MySQL的視圖和索引用法與區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • MySQL source命令的使用簡介

    MySQL source命令的使用簡介

    這篇文章主要介紹了MySQL source命令的使用簡介,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • MySQL數(shù)據(jù)庫中varchar類型的數(shù)字比較大小的方法

    MySQL數(shù)據(jù)庫中varchar類型的數(shù)字比較大小的方法

    varchar類型的數(shù)據(jù)是不能直接比較大小的,那么MySQL數(shù)據(jù)庫中varchar類型如何進(jìn)行數(shù)字比較大小的,本文就詳細(xì)的介紹一下
    2021-11-11
  • MySQL占用CPU過高排查過程及可能優(yōu)化方案

    MySQL占用CPU過高排查過程及可能優(yōu)化方案

    這篇文章主要介紹了MySQL占用CPU過高排查過程及可能優(yōu)化方案,具有很好的參考價(jià)值,希望對(duì)大家的學(xué)習(xí)或工作有所幫助,感興趣的朋友可以參考下
    2024-01-01
  • 通過mysql-proxy完成mysql讀寫分離

    通過mysql-proxy完成mysql讀寫分離

    前不久做了下mysql讀寫分離的實(shí)驗(yàn),也參考了很多的資料,謝謝哪些提供資料的兄弟
    2014-05-05
  • mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解

    mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解

    今天小編就為大家分享一篇關(guān)于mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03

最新評(píng)論