admin
2025-02-10 110d303eb11f26382ebaf00aff060a97e5f779c8
billion-generator/src/main/resources/mapper/generator/GenTableColumnMapper.xml
@@ -40,9 +40,35 @@
    </select>
    <select id="selectDbTableColumnsByName" parameterType="String" resultMap="GenTableColumnResult">
      select column_name, (case when (is_nullable = 'no' <![CDATA[ && ]]> column_key != 'PRI') then '1' else '0' end) as is_required, (case when column_key = 'PRI' then '1' else '0' end) as is_pk, ordinal_position as sort, column_comment, (case when extra = 'auto_increment' then '1' else '0' end) as is_increment, column_type
      from information_schema.columns where table_schema = (select database()) and table_name = (#{tableName})
      order by ordinal_position
        SELECT a.name                                                                       AS column_name,
               (CASE WHEN a.isnullable = 1 THEN 0 ELSE 1 END)                               AS is_required,
               (CASE WHEN (
                              SELECT COUNT(*) FROM sysobjects
                              WHERE (name IN (
                                  SELECT name FROM sysindexes
                                  WHERE (id = a.id)
                                    AND (indid IN (
                                      SELECT indid FROM sysindexkeys
                                      WHERE (id = a.id)
                                        AND (colid IN (SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name)))
                                  ))))
                                AND (xtype = 'PK')
                          ) > 0 THEN 1
                     ELSE 0 END)                                                             AS is_pk,
               a.colorder                                                                   AS sort,
               isnull(g.[value], ' ')                                                       AS column_comment,
               (CASE WHEN COLUMNPROPERTY(a.id, a.name, 'IsIdentity') = 1 THEN 1 ELSE 0 END) AS is_increment,
               b.name                                                                       AS column_type
        FROM syscolumns as a
                 LEFT JOIN systypes b ON a.xtype = b.xusertype
                 INNER JOIN sysobjects d ON a.id = d.id AND d.xtype = 'U' AND d.name <![CDATA[<>]]> 'dtproperties'
                 LEFT JOIN syscomments e ON a.cdefault = e.id
                 LEFT JOIN sys.extended_properties g ON a.id = g.major_id AND a.colid = g.minor_id
                 LEFT JOIN sys.extended_properties f ON d.id = f.class AND f.minor_id = 0
                 LEFT JOIN sys.objects h ON a.id = h.object_id
                 LEFT JOIN sys.schemas i ON h.schema_id = i.schema_id
        WHERE d.name = #{tableName}
        ORDER BY a.colorder
   </select>
    <insert id="insertGenTableColumn" parameterType="GenTableColumn" useGeneratedKeys="true" keyProperty="columnId">
@@ -85,27 +111,27 @@
         <if test="dictType != null and dictType != ''">#{dictType},</if>
         <if test="sort != null">#{sort},</if>
         <if test="createBy != null and createBy != ''">#{createBy},</if>
         sysdate()
        getdate()
         )
    </insert>
    <update id="updateGenTableColumn" parameterType="GenTableColumn">
        update gen_table_column
        <set>
            is_insert = #{isInsert},
            is_edit = #{isEdit},
            is_list = #{isList},
            is_query = #{isQuery},
            is_required = #{isRequired},
            <if test="columnComment != null">column_comment = #{columnComment},</if>
            <if test="javaType != null">java_type = #{javaType},</if>
            <if test="javaField != null">java_field = #{javaField},</if>
            <if test="isInsert != null">is_insert = #{isInsert},</if>
            <if test="isEdit != null">is_edit = #{isEdit},</if>
            <if test="isList != null">is_list = #{isList},</if>
            <if test="isQuery != null">is_query = #{isQuery},</if>
            <if test="isRequired != null">is_required = #{isRequired},</if>
            <if test="queryType != null">query_type = #{queryType},</if>
            <if test="htmlType != null">html_type = #{htmlType},</if>
            <if test="dictType != null">dict_type = #{dictType},</if>
            <if test="sort != null">sort = #{sort},</if>
            <if test="updateBy != null">update_by = #{updateBy},</if>
            update_time = sysdate()
            update_time = getdate()
        </set>
        where column_id = #{columnId}
    </update>