李林
2023-10-07 658d4927d468c47208fd012d9128b09249c07eff
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<?xml version="1.0" encoding="UTF-8"?>
 
<!--
  ~
  ~      Copyright (c) 2018-2025, ztt All rights reserved.
  ~
  ~  Redistribution and use in source and binary forms, with or without
  ~  modification, are permitted provided that the following conditions are met:
  ~
  ~ Redistributions of source code must retain the above copyright notice,
  ~  this list of conditions and the following disclaimer.
  ~  Redistributions in binary form must reproduce the above copyright
  ~  notice, this list of conditions and the following disclaimer in the
  ~  documentation and/or other materials provided with the distribution.
  ~  Neither the name of the pig4cloud.com developer nor the names of its
  ~  contributors may be used to endorse or promote products derived from
  ~  this software without specific prior written permission.
  ~  Author: ztt
  ~
  -->
 
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 
<mapper namespace="com.chinaztt.mes.basic.mapper.CompanyMapper">
 
    <resultMap id="companyMap" type="com.chinaztt.mes.basic.entity.Company">
        <id property="id" column="id"/>
        <result property="companyNo" column="company_no"/>
        <result property="companyName" column="company_name"/>
        <result property="language" column="language"/>
        <result property="createUser" column="create_user"/>
        <result property="createTime" column="create_time"/>
        <result property="country" column="country"/>
        <result property="iconName" column="icon_name"/>
        <result property="iconNameCn" column="icon_name_cn"/>
        <result property="iconNameEn" column="icon_name_en"/>
        <result property="fileAddress" column="file_address"/>
 
        <collection property="addresses" ofType="com.chinaztt.mes.basic.entity.CompanyAddress">
            <id property="id" column="aid"/>
            <result property="companyId" column="acompany_id"/>
            <result property="address" column="address"/>
            <result property="addressType" column="address_type"/>
            <result property="country" column="acountry"/>
        </collection>
 
        <collection property="contacts" ofType="com.chinaztt.mes.basic.entity.CompanyContact">
            <id property="id" column="cid"/>
            <result property="companyId" column="ccompany_id"/>
            <result property="phone" column="phone"/>
            <result property="contactPerson" column="contact_person"/>
        </collection>
    </resultMap>
 
    <select id="getFullById" resultMap="companyMap">
        SELECT
            co."id",
            co.company_no,
            co.company_name,
            co."language",
            co.create_user,
            co.create_time,
            co.country,
            co.icon_name_cn,
            co.icon_name_en,
            CASE
                WHEN co.icon_name IS NOT NULL THEN
                    '/mes/company/preview/' || co.ID
                ELSE NULL
                END AS     file_address,
            bca.ID         aid,
            bca.company_id acompany_id,
            bca.address,
            bca.address_type,
            bca.country    acountry,
            bcc.ID         cid,
            bcc.company_id ccompany_id,
            bcc.phone,
            bcc.contact_person
        FROM
            basic_company co
                LEFT JOIN basic_company_address bca ON co.ID = bca.company_id
                LEFT JOIN basic_company_contact bcc ON co.ID = bcc.company_id
        WHERE
            co.id = #{id}
    </select>
 
    <select id="getByStaffId" resultType="com.chinaztt.mes.basic.entity.Company">
        SELECT
            bc."id",
            bc.company_no,
            bc.company_name,
            bc."language",
            bc.create_user,
            bc.create_time,
            bc.country,
            bc.icon_name_cn,
            bc.icon_name_en,
            CASE
                WHEN bc.icon_name IS NOT NULL THEN
                    '/mes/company/preview/' || bc.ID
                ELSE NULL
                END AS file_address
        FROM
            basic_staff bs
                LEFT JOIN basic_division bd ON bd."id" = bs.division_id
                LEFT JOIN basic_company bc ON bc."id" = bd.company_id
        WHERE bs."id" = #{staffId}
    </select>
 
    <update id="clearIconName">
        UPDATE basic_company
        SET icon_name = null
        WHERE "id" = #{id}
    </update>
 
 
</mapper>