From 7f66dd2dee66a81df6ab999fc9daea3ac60a3642 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期一, 20 一月 2025 13:52:44 +0800
Subject: [PATCH] 优化代码
---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserMapper.xml |  121 ++++++++++++++++++++++++++++++----------
 1 files changed, 90 insertions(+), 31 deletions(-)
diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserMapper.xml
index 00deab6..0e5f33e 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/BaUserMapper.xml
@@ -6,21 +6,23 @@
     <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoBa.BaUser">
         <!--@mbg.generated-->
         <!--@Table ba_user-->
-        <id property="userId" column="id" />
+        <id property="id" column="id" />
         <result property="blockId" column="blockId"/>
         <result property="userName" column="name"/>
         <result property="phone" column="phone"/>
         <result property="password" column="password"/>
         <result property="orgTag" column="orgTag"/>
         <result property="supperAdmin" column="supperAdmin"/>
-        <result property="disabled" column="disabled" typeHandler="com.dy.common.mybatis.envm.EnumCodeTypeHandler" javaType="com.dy.common.mybatis.envm.Disabled"/>
-        <result property="deleted" column="deleted" typeHandler="com.dy.common.mybatis.envm.EnumCodeTypeHandler" javaType="com.dy.common.mybatis.envm.Deleted"/>
+        <result property="disabled" column="disabled" typeHandler="com.dy.common.mybatis.envm.EnumCodeTypeHandler"
+                javaType="com.dy.common.mybatis.envm.Disabled"/>
+        <result property="deleted" column="deleted" typeHandler="com.dy.common.mybatis.envm.EnumCodeTypeHandler"
+                javaType="com.dy.common.mybatis.envm.Deleted"/>
     </resultMap>
 
     <resultMap id="partResultMap" type="com.dy.pipIrrGlobal.pojoBa.BaUser">
         <!--@mbg.generated-->
         <!--@Table ba_user-->
-        <id property="userId" column="id" />
+        <id property="id" column="id" />
         <result property="userName" column="name"/>
         <result property="phone" column="phone"/>
         <result property="orgTag" column="orgTag"/>
@@ -29,7 +31,7 @@
     </resultMap>
 
     <resultMap id="loginResultMap" type="com.dy.pipIrrGlobal.pojoBa.BaUser">
-        <id property="userId" column="id" />
+        <id property="id" column="id" />
         <result property="blockId" column="blockId"/>
         <result property="userName" column="name"/>
         <result property="phone" column="phone"/>
@@ -46,7 +48,7 @@
     </sql>
 
     <sql id="part_Column_List">
-        ${alias}.id, ${alias}.name, ${alias}.phone, ${alias}.disabled
+        #{alias}.id, #{alias}.name, #{alias}.phone, #{alias}.disabled
     </sql>
 
     <sql id="Login_Column_List">
@@ -99,8 +101,9 @@
         </trim>
     </select>
     <insert id="putin" parameterType="com.dy.pipIrrGlobal.pojoBa.BaUser">
-        insert into ba_user (<include refid="Base_Column_List" />)
-        values (#{userId,jdbcType=BIGINT},
+<!--        insert into ba_user (<include refid="Base_Column_List" />)-->
+        insert into ba_user(id, blockId, name, phone, password, orgTag, supperAdmin, disabled, deleted)
+        values (#{id,jdbcType=BIGINT},
         #{blockId,jdbcType=BIGINT},
         #{userName,jdbcType=VARCHAR},
         #{phone,jdbcType=VARCHAR},
@@ -114,7 +117,7 @@
     <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoBa.BaUser">
         insert into ba_user
         <trim prefix="(" suffix=")" suffixOverrides=",">
-            <if test="userId != null">
+            <if test="id != null">
                 id,
             </if>
             <if test="blockId != null">
@@ -143,8 +146,8 @@
             </if>
         </trim>
         <trim prefix="values (" suffix=")" suffixOverrides=",">
-            <if test="userId != null">
-                #{userId,jdbcType=BIGINT},
+            <if test="id != null">
+                #{id,jdbcType=BIGINT},
             </if>
             <if test="blockId != null">
                 #{blockId,jdbcType=BIGINT},
@@ -195,7 +198,7 @@
                 deleted = #{deleted,typeHandler=com.dy.common.mybatis.envm.EnumCodeTypeHandler, jdbcType=TINYINT},
             </if>
         </set>
-        where id = #{userId, jdbcType=BIGINT}
+        where id = #{id, jdbcType=BIGINT}
     </update>
     <update id="updateByPrimaryKey" parameterType="com.dy.pipIrrGlobal.pojoBa.BaUser">
         update ba_user
@@ -205,7 +208,7 @@
         password = #{password,jdbcType=VARCHAR},
         disabled = #{disabled,typeHandler=com.dy.common.mybatis.envm.EnumCodeTypeHandler, jdbcType=TINYINT},
         deleted = #{deleted,typeHandler=com.dy.common.mybatis.envm.EnumCodeTypeHandler, jdbcType=TINYINT}
-        where id = #{userId,jdbcType=BIGINT}
+        where id = #{id,jdbcType=BIGINT}
     </update>
     <update id="changePassword" >
         update ba_user
@@ -237,7 +240,7 @@
             INNER JOIN ba_role_permissions per ON per.roleId = rol.id
         <where>
             <if test = "userId != null and userId > 0">
-                AND user.id = ${userId}
+                AND user.id = #{userId}
             </if>
         </where>
     </select>
@@ -256,7 +259,7 @@
             AND us.disabled = 0
             AND us.deleted = 0
             <if test = "userId != null and userId > 0">
-                AND us.id = ${userId}
+                AND us.id = #{userId}
             </if>
         </where>
     </select>
@@ -265,14 +268,27 @@
     <select id="getRecordCount" parameterType="java.util.Map" resultType="java.lang.Long">
         SELECT
             COUNT(*) AS recordCount
+        FROM
+        (
+        SELECT
+        CAST(id AS char) AS id,
+        phone,
+        name AS userName,
+        disabled AS stateId,
+        (CASE
+        WHEN disabled = 0 THEN '姝e父'
+        WHEN disabled = 1 THEN '宸茬鐢�'
+        END) AS stateName,
+        CAST(blockId AS char) AS blockId,
+        (SELECT name FROM ba_block WHERE id = user.blockId) AS blockName
         FROM ba_user user
-            INNER JOIN ba_user_role usro ON usro.userId = user.id
+        LEFT JOIN ba_user_role usro ON usro.userId = user.id
         <where>
             AND user.supperAdmin != 1
             AND user.deleted = 0
 
-            <if test = "name != null and name !=''">
-                AND user.name like CONCAT('%',#{name},'%')
+            <if test = "userName != null and userName !=''">
+                AND user.name like CONCAT('%',#{userName},'%')
             </if>
 
             <if test = "phone != null and phone !=''">
@@ -280,32 +296,33 @@
             </if>
 
             <if test = "roleId != null and roleId > 0">
-                AND usro.roleId = ${roleId}
+                AND usro.roleId = #{roleId}
             </if>
         </where>
+        GROUP BY user.id) c
     </select>
 
     <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鐢ㄦ埛鍒楄〃-->
     <select id="getUsers" resultType="com.dy.pipIrrGlobal.voBa.VoUserInfo">
         SELECT
-            CAST(id AS char) AS userId,
+            CAST(id AS char) AS id,
             phone,
             name AS userName,
             disabled AS stateId,
             (CASE
-                 WHEN disabled = 0 THEN "姝e父"
-                 WHEN disabled = 1 THEN "宸茬鐢�"
+                 WHEN disabled = 0 THEN '姝e父'
+                 WHEN disabled = 1 THEN '宸茬鐢�'
                 END) AS stateName,
             CAST(blockId AS char) AS blockId,
             (SELECT name FROM ba_block WHERE id = user.blockId) AS blockName
         FROM ba_user user
-            INNER JOIN ba_user_role usro ON usro.userId = user.id
+            LEFT JOIN ba_user_role usro ON usro.userId = user.id
         <where>
             AND user.supperAdmin != 1
             AND user.deleted = 0
 
-            <if test = "name != null and name !=''">
-                AND user.name like CONCAT('%',#{name},'%')
+            <if test = "userName != null and userName !=''">
+                AND user.name like CONCAT('%',#{userName},'%')
             </if>
 
             <if test = "phone != null and phone !=''">
@@ -313,13 +330,16 @@
             </if>
 
             <if test = "roleId != null and roleId > 0">
-                AND usro.roleId = ${roleId}
+                AND usro.roleId = #{roleId}
             </if>
         </where>
+        GROUP BY user.id
         ORDER BY user.id DESC
-        <if test="pageCurr != null and pageSize != null">
-            LIMIT ${pageCurr}, ${pageSize}
-        </if>
+        <trim prefix="limit " >
+            <if test="start != null and count != null">
+                #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+            </if>
+        </trim>
     </select>
 
     <!--鏍规嵁鐢ㄦ埛缂栧彿鑾峰彇瑙掕壊ID鍒楄〃-->
@@ -327,7 +347,7 @@
         SELECT
             roleId
         FROM ba_user_role
-        WHERE userId = ${userId}
+        WHERE userId = #{userId}
     </select>
 
     <select id="getRoleNamesByUserId" resultType="java.util.HashMap">
@@ -335,7 +355,46 @@
             ro.name AS roleName
         FROM ba_user_role usro
                  INNER JOIN ba_role ro ON usro.roleId = ro.id
-        WHERE userId = ${userId}
+        WHERE userId = #{userId}
 
     </select>
+
+    <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
+        <!--@mbg.generated-->
+        select
+        <include refid="Base_Column_List" />
+        from ba_user
+        where id = #{id,jdbcType=BIGINT}
+    </select>
+
+    <select id="getPhones" resultType="java.lang.String">
+        SELECT phone FROM ba_user WHERE deleted = 0 and disabled = 0
+    </select>
+
+    <!--鑾峰彇绠�鍗曠敤鎴锋暟鎹垪琛�-->
+    <select id="getSimpleUsers" resultType="com.dy.pipIrrGlobal.voBa.VoSimpleUser">
+        SELECT
+            id AS userId,
+            name AS userName
+        FROM  ba_user
+        WHERE disabled = 0 AND deleted = 0
+    </select>
+
+    <!--鑾峰彇宸℃鍛樺垪琛�-->
+    <select id="getInspectors" resultType="com.dy.pipIrrGlobal.voBa.VoRoleSimple">
+        SELECT
+            us.id AS inspectorId,
+            us.name AS inspector
+        FROM ba_user us
+            INNER JOIN ba_user_role ur ON ur.userId = us.id
+            INNER JOIN ba_role rol ON rol.id = ur.roleId
+        <where>
+            AND us.disabled = 0
+            AND us.deleted = 0
+            AND rol.`name` = '宸℃鍛�'
+            <if test = "inspector != null and inspector !=''">
+                AND us.name LIKE CONCAT('%',#{inspector},'%')
+            </if>
+        </where>
+    </select>
 </mapper>
\ No newline at end of file
--
Gitblit v1.8.0