Rumah pangkalan data tutorial mysql MySql数据库查询多级部门及其下的所有用户信息

MySql数据库查询多级部门及其下的所有用户信息

Jun 07, 2016 pm 02:50 PM
mysql maklumat pangkalan data Pertanyaan pengguna jabatan

关于多级别菜单栏或者权限系统中部门上下级的树形遍历,oracle中有connect by来实现,mysql没有这样的便捷途径,所以MySQL遍历数据表是我们经常会遇到的头痛问题,下面通过数据库函数来实现 1、建表 ① 机构表 CREATE TABLE `t_sys_org` ( `ID` varchar(64)

             关于多级别菜单栏或者权限系统中部门上下级的树形遍历,oracle中有connect by来实现,  mysql没有这样的便捷途径,所以MySQL遍历数据表是我们经常会遇到的头痛问题,下面通过数据库函数来实现

1、建表

     ①  机构表

      CREATE TABLE `t_sys_org` (
 
  `ID` varchar(64) NOT NULL COMMENT '主键ID',
  `CODE` varchar(60) DEFAULT NULL COMMENT '编码',
  `NAME` varchar(200) DEFAULT NULL COMMENT '机构名称',
 
 `FULLNAME` varchar(100) DEFAULT NULL,
 
 `SHORTNAME` varchar(60) DEFAULT NULL COMMENT '机构简称',
 
 `ORGCODE` varchar(60) DEFAULT NULL COMMENT '机构代码',
`PARENTID` varchar(64) DEFAULT NULL COMMENT '上级机构',
  `DEPTH` int(10) DEFAULT NULL COMMENT '深度',
 
 `SORT` varchar(24) DEFAULT NULL COMMENT '排序',
 
       `REMARK` varchar(200) DEFAULT NULL COMMENT '备注',
 
 `STATUS` varchar(4) DEFAULT NULL COMMENT '状态',
  `ORGTYPE` varchar(2) DEFAULT NULL COMMENT '机构类型',
`CODENUM` varchar(80) DEFAULT NULL COMMENT '单位代码证编号',
  `LEAGALPERSON` varchar(18) DEFAULT NULL COMMENT '机构法人',
  `LEAGALPERSONID` int(10) DEFAULT NULL COMMENT '负责人ID',
  `SPLITLEADER` varchar(80) DEFAULT NULL COMMENT '分管领导',
  `SPLITLEADERID` int(10) DEFAULT NULL COMMENT '分管领导ID',
  `ADMINLEVEL` varchar(16) DEFAULT NULL COMMENT '机构行政级别',
  `NATURE` varchar(16) DEFAULT NULL COMMENT '机构性质',
  `WORKNATUREB` varchar(100) DEFAULT NULL COMMENT '机构工作性质(大类)',
  `WORKNATUREM` varchar(16) DEFAULT NULL COMMENT '机构工作性质(中类)',
  `WORKNATURES` varchar(100) DEFAULT NULL COMMENT '机构工作性质(小类)',
  `ARECODE` varchar(16) DEFAULT NULL COMMENT '单位所隶属行政区划',
  `ADDRESS` varchar(800) DEFAULT NULL COMMENT '单位驻地与地址',
 
       `MAILCODE` varchar(16) DEFAULT NULL COMMENT '单位邮编',
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='机构表(T_SYS_ORG)';

    ②用户表

        CREATE TABLE `t_sys_user` (
  `ID` varchar(64) NOT NULL COMMENT '主键ID',
  `ACCOUNT` varchar(200) DEFAULT NULL COMMENT '账号',
   `USERNAME` varchar(60) DEFAULT NULL COMMENT '姓名',
   `PASSWORD` varchar(120) DEFAULT NULL COMMENT '密码',
  `IDCARD` varchar(72) DEFAULT NULL COMMENT '身份证号',
   `SEX` varchar(4) DEFAULT NULL COMMENT '性别',
  `CREATETIME` datetime DEFAULT NULL COMMENT '创建时间',
  `MODTIME` datetime DEFAULT NULL COMMENT '修改时间',
  `MODPWDTIME` datetime DEFAULT NULL COMMENT '修改密码时间',
  `REMARK` varchar(500) DEFAULT NULL COMMENT '备注',
  `STATUS` int(10) DEFAULT NULL COMMENT '状态',
  `ADMINLEVLE` varchar(16) DEFAULT NULL COMMENT '行政级别',
   `ALARMBELL` varchar(16) DEFAULT NULL COMMENT '警衔',
   `ARCHIVEDEPTID` decimal(10,0) DEFAULT NULL COMMENT '档案部门ID',
  `AUTHORIZED` varchar(16) DEFAULT NULL COMMENT '编制',
  `BIRTHDAY` datetime DEFAULT NULL COMMENT '出生日期',
  `BIRTHPLACE` varchar(128) DEFAULT NULL COMMENT '籍贯',
 `CREATEBY` decimal(10,0) DEFAULT NULL COMMENT '创建人',
 `EDUCATIONALBG` varchar(16) DEFAULT NULL COMMENT '最高学历',
  `MODIFYBY` decimal(10,0) DEFAULT NULL COMMENT '修改人',
  `NATION` varchar(16) DEFAULT NULL COMMENT '民族',
   `POLICENUMBER` varchar(64) DEFAULT NULL COMMENT '警号',
   `POLITICAL` varchar(16) DEFAULT NULL COMMENT '政治面貌',
  `POSITION` varchar(16) DEFAULT NULL COMMENT '职务',
  `POSITIONLEVLE` varchar(16) DEFAULT NULL COMMENT '职级',
  `SORTNO` varchar(200) DEFAULT NULL COMMENT '排序级别',
  `WORKDEPTID` varchar(64) DEFAULT NULL COMMENT '工作部门ID',
  `ORGID` varchar(64) DEFAULT NULL COMMENT '所属机构',
 `USERSTATUS` decimal(10,0) DEFAULT NULL COMMENT '用户状态',
   `COCALLSTATUS` decimal(10,0) DEFAULT NULL COMMENT '即时通同步状态',
 `COMPOSITIONDEPTID` decimal(10,0) DEFAULT NULL COMMENT '编制部门',
   `RECORDSMAGORG` varchar(100) DEFAULT NULL COMMENT '档案管理单位',
   `NICKNAME` varchar(64) DEFAULT NULL COMMENT '昵称',
  `WORKNUMBER` varchar(100) DEFAULT NULL COMMENT '工作证号',
  `USERKEY` text COMMENT '用户键值',
   `PARTJOBNO` varchar(4) DEFAULT NULL,
  `IMG_PATH` varchar(200) DEFAULT NULL COMMENT '照片路径',
  PRIMARY KEY (`ID`),
   UNIQUE KEY `ACCOUNT_UNIQUE` (`ACCOUNT`) USING BTREE,
   KEY `IND_SUSR_ORGID` (`ORGID`) USING BTREE,
  KEY `IND_SUSR_STAT` (`STATUS`) USING BTREE,
   KEY `IND_SUSR_STNO` (`SORTNO`) USING BTREE,
  KEY `IND_SUSR_USTAT` (`USERSTATUS`) USING BTREE,
  KEY `IND_SUSR_WDPID` (`WORKDEPTID`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户表';


3、使用FUNCTION根据指定的ID流水号获取多级部门编号(包括当前ID)
BEGIN
DECLARE sTemp VARCHAR(4000);
DECLARE sTempChd VARCHAR(4000);

SET sTemp = '$';
SET sTempChd = cast(orgId  as char);


WHILE sTempChd is not NULL DO
SET sTemp = CONCAT(sTemp,',',sTempChd);
SELECT group_concat(id) INTO sTempChd FROM t_sys_org where FIND_IN_SET(parentId,sTempChd)>0;
END WHILE;
return sTemp;
END
 
4、根据部门ID获取该部门下的所有子部门
select id from t_sys_org where  FIND_IN_SET ( id,  queryAllChildByOrg('448457')) order by code;
5、根据获取的子部门获取其所有的用户信息
select username, WORKDEPTID from t_sys_user where WORKDEPTID in select id from t_sys_org where  FIND_IN_SET ( id,  queryAllChildByOrg('448457')) order by code)

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1672
14
Tutorial PHP
1277
29
Tutorial C#
1257
24
MySQL dan PHPMyAdmin: Ciri dan Fungsi Teras MySQL dan PHPMyAdmin: Ciri dan Fungsi Teras Apr 22, 2025 am 12:12 AM

MySQL dan phpmyadmin adalah alat pengurusan pangkalan data yang kuat. 1) MySQL digunakan untuk membuat pangkalan data dan jadual, dan untuk melaksanakan pertanyaan DML dan SQL. 2) Phpmyadmin menyediakan antara muka intuitif untuk pengurusan pangkalan data, pengurusan struktur meja, operasi data dan pengurusan kebenaran pengguna.

Peranan Oracle dalam dunia perniagaan Peranan Oracle dalam dunia perniagaan Apr 23, 2025 am 12:01 AM

Oracle bukan sahaja syarikat pangkalan data, tetapi juga pemimpin dalam pengkomputeran awan dan sistem ERP. 1. Oracle menyediakan penyelesaian yang komprehensif dari pangkalan data ke perkhidmatan awan dan sistem ERP. 2. Oraclecloud mencabar AWS dan Azure, menyediakan perkhidmatan IaaS, PaaS dan SaaS. 3. Sistem ERP Oracle seperti E-BusinessSuite dan FusionApplications membantu perusahaan mengoptimumkan operasi.

Terangkan tujuan kunci asing di MySQL. Terangkan tujuan kunci asing di MySQL. Apr 25, 2025 am 12:17 AM

Di MySQL, fungsi kunci asing adalah untuk mewujudkan hubungan antara jadual dan memastikan konsistensi dan integriti data. Kekunci asing mengekalkan keberkesanan data melalui pemeriksaan integriti rujukan dan operasi cascading. Perhatikan pengoptimuman prestasi dan elakkan kesilapan biasa apabila menggunakannya.

Bandingkan dan kontras MySQL dan Mariadb. Bandingkan dan kontras MySQL dan Mariadb. Apr 26, 2025 am 12:08 AM

Perbezaan utama antara MySQL dan MariaDB adalah prestasi, fungsi dan lesen: 1. MySQL dibangunkan oleh Oracle, dan Mariadb adalah garpu. 2. MariaDB boleh melakukan lebih baik dalam persekitaran beban tinggi. 3.MariADB menyediakan lebih banyak enjin dan fungsi penyimpanan. 4.MYSQL mengamalkan lesen dua, dan MariaDB adalah sumber terbuka sepenuhnya. Infrastruktur yang sedia ada, keperluan prestasi, keperluan fungsional dan kos lesen perlu diambil kira apabila memilih.

SQL vs MySQL: menjelaskan hubungan antara kedua -dua SQL vs MySQL: menjelaskan hubungan antara kedua -dua Apr 24, 2025 am 12:02 AM

SQL adalah bahasa standard untuk menguruskan pangkalan data relasi, manakala MySQL adalah sistem pengurusan pangkalan data yang menggunakan SQL. SQL mentakrifkan cara untuk berinteraksi dengan pangkalan data, termasuk operasi CRUD, sementara MySQL melaksanakan standard SQL dan menyediakan ciri -ciri tambahan seperti prosedur dan pencetus yang disimpan.

MySQL: Pangkalan Data, Phpmyadmin: Antara Muka Pengurusan MySQL: Pangkalan Data, Phpmyadmin: Antara Muka Pengurusan Apr 29, 2025 am 12:44 AM

MySQL dan phpmyadmin boleh diuruskan dengan berkesan melalui langkah -langkah berikut: 1. Buat dan hapus pangkalan data: hanya klik phpmyadmin untuk diselesaikan. 2. Mengurus Jadual: Anda boleh membuat jadual, mengubahsuai struktur, dan menambah indeks. 3. Operasi Data: Menyokong memasukkan, mengemas kini, memadam data dan melaksanakan pertanyaan SQL. 4. Data Import dan Eksport: Menyokong SQL, CSV, XML dan format lain. 5. Pengoptimuman dan Pemantauan: Gunakan arahan yang boleh dioptimumkan untuk mengoptimumkan jadual dan gunakan penganalisis pertanyaan dan alat pemantauan untuk menyelesaikan masalah prestasi.

Redis: Memahami seni bina dan tujuannya Redis: Memahami seni bina dan tujuannya Apr 26, 2025 am 12:11 AM

Redis adalah sistem penyimpanan struktur data memori, terutamanya digunakan sebagai pangkalan data, cache dan broker mesej. Ciri-ciri terasnya termasuk model tunggal, multiplexing I/O, mekanisme ketekunan, replikasi dan fungsi clustering. Redis biasanya digunakan dalam aplikasi praktikal untuk caching, penyimpanan sesi, dan beratur mesej. Ia dapat meningkatkan prestasinya dengan memilih struktur data yang betul, menggunakan saluran paip dan urus niaga, dan pemantauan dan penalaan.

Langkah -langkah untuk menambah dan memadam medan ke jadual mysql Langkah -langkah untuk menambah dan memadam medan ke jadual mysql Apr 29, 2025 pm 04:15 PM

Di MySQL, tambah medan menggunakan alterTabletable_nameaddcolumnnew_columnvarchar (255) afterexisting_column, memadam medan menggunakan altertabletable_namedropcolumncolumn_to_drop. Apabila menambah medan, anda perlu menentukan lokasi untuk mengoptimumkan prestasi pertanyaan dan struktur data; Sebelum memadam medan, anda perlu mengesahkan bahawa operasi itu tidak dapat dipulihkan; Mengubah struktur jadual menggunakan DDL dalam talian, data sandaran, persekitaran ujian, dan tempoh masa beban rendah adalah pengoptimuman prestasi dan amalan terbaik.

See all articles