From bfc1c1abd1d1deab45740806ce984b6774a319bd Mon Sep 17 00:00:00 2001
From: 13693261870 <252740454@qq.com>
Date: 星期一, 05 二月 2024 11:01:13 +0800
Subject: [PATCH] 修改目录编码过滤功能

---
 src/main/java/com/lf/server/service/show/DataLibService.java       |   21 ++++++++++++++-------
 src/main/resources/mapper/all/BaseQueryMapper.xml                  |   25 +++++++++++++------------
 src/main/java/com/lf/server/controller/show/DataLibController.java |    1 -
 3 files changed, 27 insertions(+), 20 deletions(-)

diff --git a/src/main/java/com/lf/server/controller/show/DataLibController.java b/src/main/java/com/lf/server/controller/show/DataLibController.java
index 4e7ee50..e15d9c8 100644
--- a/src/main/java/com/lf/server/controller/show/DataLibController.java
+++ b/src/main/java/com/lf/server/controller/show/DataLibController.java
@@ -101,7 +101,6 @@
             // dirs = DataLibService.copeCodes(dirs, "dircode")
             dirs = dataLibService.getDirsByTypes(types, dirs, "dircode");
 
-
             int count = metaService.selectMetasForCount(depcode, dirs, name);
             if (count == 0) {
                 return success(0, null);
diff --git a/src/main/java/com/lf/server/service/show/DataLibService.java b/src/main/java/com/lf/server/service/show/DataLibService.java
index e6f839b..7815f85 100644
--- a/src/main/java/com/lf/server/service/show/DataLibService.java
+++ b/src/main/java/com/lf/server/service/show/DataLibService.java
@@ -287,12 +287,19 @@
             return null;
         }
 
-        List<String> list = Arrays.asList(codes.split(","));
+        //List<String> list = Arrays.asList(codes.split(","));
         //List<String> list = codesAsList(codes);
         //list = copeDirCodes(list);
-        setRightLike(list, field);
+        //setRightLike(list, field);
 
-        return "(" + StringHelper.join(list, " or ") + ")";
+        //return "(" + StringHelper.join(list, " or ") + ")";
+
+        List<String> list = new ArrayList<>();
+        for (String dir : codes.split(",")) {
+            list.add("^" + dir);
+        }
+
+        return field + " ~ '" + StringHelper.join(list, "|") + "'";
     }
 
     /**
@@ -370,13 +377,13 @@
     }
 
     /**
-     * 璁剧疆 鍙砽ike
+     * 璁剧疆 鍙砽ike *
      */
     private static void setRightLike(List<String> list, String field) {
-        /*if (list.isEmpty()) {
+        if (list.isEmpty()) {
             list.add("1 = 2");
             return;
-        }*/
+        }
 
         for (int i = 0, c = list.size(); i < c; i++) {
             String str = String.format("%s like '%s%%'", field, list.get(i));
@@ -393,7 +400,7 @@
         }
 
         if (!StringUtils.isEmpty(types)) {
-            List<KeyValueEntity> list = baseQueryService.selectDirsByTypes(types.split(","), dirs);
+            List<KeyValueEntity> list = baseQueryService.selectDirsByTypes(types.split(","), copeCodes(dirs, "code"));
             if (null == list || list.isEmpty()) {
                 return null;
             }
diff --git a/src/main/resources/mapper/all/BaseQueryMapper.xml b/src/main/resources/mapper/all/BaseQueryMapper.xml
index c1b9ef0..2e85d14 100644
--- a/src/main/resources/mapper/all/BaseQueryMapper.xml
+++ b/src/main/resources/mapper/all/BaseQueryMapper.xml
@@ -87,22 +87,23 @@
     </select>
 
     <select id="selectDirsByTypes" resultType="com.lf.server.entity.ctrl.KeyValueEntity">
-        select name "key", (select string_agg(code, ',') from lf.sys_dir where name = a.name) "value"
-        from lf.sys_dir a
-        <where>
-            1 = 1
-            <if test="types != null">
-                and name in
+        with rs as (
+            select name, code
+            from lf.sys_dir
+            <where>
+                name in
                 <foreach item="type" collection="types" open="(" separator="," close=")">
                     #{type}
                 </foreach>
-            </if>
-            <if test="dirs != null">
-                and ${dirs}
-            </if>
-        </where>
+                <if test="dirs != null">
+                    and ${dirs}
+                </if>
+            </where>
+        )
+        select name "key", (select string_agg(code, ',') from rs where name = a.name) "value"
+        from rs a
         group by name
-        order by key
+        order by value;
     </select>
 
     <select id="selectAnnexByTab" resultType="com.lf.server.entity.sys.AttachEntity">

--
Gitblit v1.9.3