Maison base de données tutoriel mysql MySql数据库查询多级部门及其下的所有用户信息

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

Jun 07, 2016 pm 02:50 PM
mysql 信息 数据库 查询 用户 département

关于多级别菜单栏或者权限系统中部门上下级的树形遍历,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)

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
<🎜>: Grow A Garden - Guide de mutation complet
3 Il y a quelques semaines By DDD
Nordhold: Système de fusion, expliqué
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel Java
1672
14
Tutoriel PHP
1277
29
Tutoriel C#
1257
24
Mysql et phpmyadmin: fonctionnalités et fonctions de base Mysql et phpmyadmin: fonctionnalités et fonctions de base Apr 22, 2025 am 12:12 AM

MySQL et PHPMyAdmin sont de puissants outils de gestion de la base de données. 1) MySQL est utilisé pour créer des bases de données et des tables et pour exécuter des requêtes DML et SQL. 2) PHPMYADMIN fournit une interface intuitive pour la gestion des bases de données, la gestion de la structure de la table, les opérations de données et la gestion de l'autorisation des utilisateurs.

Le rôle d'Oracle dans le monde des affaires Le rôle d'Oracle dans le monde des affaires Apr 23, 2025 am 12:01 AM

Oracle n'est pas seulement une entreprise de base de données, mais aussi un leader des systèmes de cloud computing et ERP. 1. Oracle fournit des solutions complètes de la base de données aux services cloud et aux systèmes ERP. 2. OracleCloud défie AWS et Azure, fournissant des services IaaS, PaaS et SaaS. 3. Les systèmes ERP d'Oracle tels que E-BusinessSuite et FusionApplications aident les entreprises à optimiser les opérations.

Expliquez le but des clés étrangères dans MySQL. Expliquez le but des clés étrangères dans MySQL. Apr 25, 2025 am 12:17 AM

Dans MySQL, la fonction des clés étrangères est d'établir la relation entre les tables et d'assurer la cohérence et l'intégrité des données. Les clés étrangères maintiennent l'efficacité des données grâce à des contrôles d'intégrité de référence et aux opérations en cascade. Faites attention à l'optimisation des performances et évitez les erreurs courantes lorsque vous les utilisez.

Comparez et contrastez MySQL et Mariadb. Comparez et contrastez MySQL et Mariadb. Apr 26, 2025 am 12:08 AM

La principale différence entre MySQL et MARIADB est les performances, les fonctionnalités et la licence: 1. MySQL est développé par Oracle, et MariADB est sa fourche. 2. MariaDB peut mieux fonctionner dans des environnements à haute charge. 3.MariaDB fournit plus de moteurs et de fonctions de stockage. 4.MySQL adopte une double licence et MariaDB est entièrement open source. L'infrastructure existante, les exigences de performance, les exigences fonctionnelles et les coûts de licence doivent être pris en compte lors du choix.

SQL vs MySQL: clarifier la relation entre les deux SQL vs MySQL: clarifier la relation entre les deux Apr 24, 2025 am 12:02 AM

SQL est un langage standard pour gérer les bases de données relationnelles, tandis que MySQL est un système de gestion de bases de données qui utilise SQL. SQL définit les moyens d'interagir avec une base de données, y compris les opérations CRUD, tandis que MySQL implémente la norme SQL et fournit des fonctionnalités supplémentaires telles que les procédures stockées et les déclencheurs.

MySQL: la base de données, phpmyadmin: l'interface de gestion MySQL: la base de données, phpmyadmin: l'interface de gestion Apr 29, 2025 am 12:44 AM

MySQL et PHPMYADMIN peuvent être gérés efficacement via les étapes suivantes: 1. Créer et supprimer la base de données: cliquez simplement dans phpMyAdmin pour terminer. 2. Gérer les tables: vous pouvez créer des tables, modifier les structures et ajouter des index. 3. Fonctionnement des données: prend en charge l'insertion, la mise à jour, la suppression des données et l'exécution des requêtes SQL. 4. Données d'importation et d'exportation: prend en charge les formats SQL, CSV, XML et autres. 5. Optimisation et surveillance: utilisez la commande Optimizetable pour optimiser les tables et utiliser des analyseurs de requête et des outils de surveillance pour résoudre les problèmes de performances.

Redis: Comprendre son architecture et son objectif Redis: Comprendre son architecture et son objectif Apr 26, 2025 am 12:11 AM

Redis est un système de stockage de structure de données de mémoire, principalement utilisé comme base de données, cache et courtier de messages. Ses caractéristiques principales incluent un modèle unique, un multiplexage d'E / S, un mécanisme de persistance, des fonctions de réplication et de clustering. Redis est couramment utilisé dans les applications pratiques pour la mise en cache, le stockage de session et les files d'attente de messages. Il peut améliorer considérablement ses performances en sélectionnant la bonne structure de données, en utilisant des pipelines et des transactions, et en surveillant et en réglage.

Étapes pour ajouter et supprimer les champs aux tables MySQL Étapes pour ajouter et supprimer les champs aux tables MySQL Apr 29, 2025 pm 04:15 PM

Dans MySQL, ajoutez des champs en utilisant alterTableTable_namEaddColumnNew_Columnvarchar (255) AfterExist_Column, supprimez les champs en utilisant alterTableTable_NamedRopColumnColumn_to_drop. Lorsque vous ajoutez des champs, vous devez spécifier un emplacement pour optimiser les performances de la requête et la structure des données; Avant de supprimer les champs, vous devez confirmer que l'opération est irréversible; La modification de la structure de la table à l'aide du DDL en ligne, des données de sauvegarde, de l'environnement de test et des périodes de faible charge est l'optimisation des performances et les meilleures pratiques.

See all articles