| <?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.dsh.course.mapper.DeptMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="com.dsh.guns.modular.system.model.Dept"> | 
|         <id column="id" property="id"/> | 
|         <result column="num" property="num"/> | 
|         <result column="pid" property="pid"/> | 
|         <result column="pids" property="pids"/> | 
|         <result column="simplename" property="simplename"/> | 
|         <result column="fullname" property="fullname"/> | 
|         <result column="tips" property="tips"/> | 
|         <result column="version" property="version"/> | 
|     </resultMap> | 
|   | 
|     <select id="tree" resultType="com.dsh.course.model.node.ZTreeNode"> | 
|         select id,pid as pId,simplename as name, | 
|         ( | 
|         CASE | 
|         WHEN (pId = 0 OR pId IS NULL) THEN | 
|         'true' | 
|         ELSE | 
|         'false' | 
|         END | 
|         ) as isOpen from sys_dept where 1=1 | 
|         <if test="type == 3"> | 
|             and  objectType = 3 and objectId =#{id} | 
|         </if> | 
|         <if test="type == 2"> | 
|             and (objectType = 2 and objectId =#{id} | 
|             or | 
|             <if test="storeIds != null and storeIds.size()>0"> | 
|                 objectId IN | 
|                 <foreach collection="storeIds" separator="," item="id" open="(" close=")"> | 
|                     #{id} | 
|                 </foreach> | 
|             </if> | 
|             ) | 
|         </if> | 
|     </select> | 
|     <select id="list" resultType="java.util.Map"> | 
|             select * from sys_dept where 1=1 | 
|             <if test="condition != null and condition != ''"> | 
|                 and  simplename like CONCAT('%',#{condition},'%') or fullname like CONCAT('%',#{condition},'%') | 
|             </if> | 
|             <if test="objectType == 3"> | 
|                 and  objectType = 3 and objectId =#{objectId} | 
|             </if> | 
|             <if test="objectType == 2"> | 
|                 and (objectType = 2 and objectId =#{objectId} | 
|                 or | 
|                 <if test="storeIds != null and storeIds.size()>0"> | 
|                     objectId IN | 
|                     <foreach collection="storeIds" separator="," item="id" open="(" close=")"> | 
|                         #{id} | 
|                     </foreach> | 
|                 </if> | 
|                 ) | 
|             </if> | 
|   | 
|   | 
|             order by num ASC | 
|     </select> | 
|   | 
|   | 
| </mapper> |