cari
Rumahpangkalan datatutorial mysqlMySql数据库查询多级部门及其下的所有用户信息

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

Jun 07, 2016 pm 02:50 PM
mysqlmaklumatpangkalan dataPertanyaanpenggunajabatan

关于多级别菜单栏或者权限系统中部门上下级的树形遍历,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
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
Apakah batasan menggunakan pandangan di MySQL?Apakah batasan menggunakan pandangan di MySQL?May 14, 2025 am 12:10 AM

Mysqlviewshavelimitations: 1) theDon'tsupportallsqloperations, bintikDatamanipulationThroughviewswithjoinsorsubqueries.2) merekacanimpactperformance, terutamanya dengan komplekssum

Faktor apa yang mempengaruhi bilangan pencetus yang boleh saya gunakan di MySQL?Faktor apa yang mempengaruhi bilangan pencetus yang boleh saya gunakan di MySQL?May 14, 2025 am 12:08 AM

Mysqldoes'timposeahardlimitontriggers, butpracticalfactorsDeterminetheirefectiveus

MySQL: Adakah selamat untuk menyimpan gumpalan?MySQL: Adakah selamat untuk menyimpan gumpalan?May 14, 2025 am 12:07 AM

Ya, It'sSsafetostoreBlobDatainMysql, ButConserthySefactors: 1) Storagespace: BlobScanconsumesignificantspace, PotensiCreaseScostSandSlowingPerformance.2)

MySQL: Menambah pengguna melalui antara muka web PHPMySQL: Menambah pengguna melalui antara muka web PHPMay 14, 2025 am 12:04 AM

Menambah pengguna MySQL melalui antara muka web PHP boleh menggunakan sambungan MySQLI. Langkah -langkah adalah seperti berikut: 1. Sambungkan ke pangkalan data MySQL dan gunakan sambungan MySQLI. 2. Buat pengguna, gunakan pernyataan CreateUser, dan gunakan fungsi kata laluan () untuk menyulitkan kata laluan. 3. Mencegah suntikan SQL dan gunakan fungsi mysqli_real_escape_string () untuk memproses input pengguna. 4. Berikan kebenaran kepada pengguna baru dan gunakan pernyataan geran.

MySQL: Blob dan penyimpanan No-SQL yang lain, apakah perbezaannya?MySQL: Blob dan penyimpanan No-SQL yang lain, apakah perbezaannya?May 13, 2025 am 12:14 AM

Mysql'sblobissusuipableforstoringbinarydatawithinarelationaldatabase, sementara

MySQL Tambah Pengguna: Sintaks, Pilihan, dan Amalan Terbaik KeselamatanMySQL Tambah Pengguna: Sintaks, Pilihan, dan Amalan Terbaik KeselamatanMay 13, 2025 am 12:12 AM

Toaddauserinmysql, gunakan: createuser'username '@' host'identifiedby'password '; here'showtodoitsecurely: 1) choosethehostcareflelytocon trolaccess.2) SetResourcelImitSwithOptionsLikeMax_queries_per_hour.3) USESTRONG, UNIQUEPASSWORDS.4) Enforcessl/TLSConnectionswith

MySQL: Bagaimana untuk mengelakkan jenis data rentetan kesilapan biasa?MySQL: Bagaimana untuk mengelakkan jenis data rentetan kesilapan biasa?May 13, 2025 am 12:09 AM

Toavoidcommonmistakeswithstringdatatypesinmysql, fahamistringtypenuances, choosetherighttype, danManageencodingandcollationsettingsefectively.1) usecharfarfixed-lengthstrings, varcharforvariable-length, andtext/blobforlargerdata.2)

See all articles

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

Nordhold: Sistem Fusion, dijelaskan
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual