<?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.jeeplus.modules.test.dao.onetomany.TestDataMainDao">
|
|
<sql id="testDataMainColumns">
|
a.id AS "id",
|
a.user_id AS "user.id",
|
a.office_id AS "office.id",
|
a.area_id AS "area.id",
|
a.name AS "name",
|
a.sex AS "sex",
|
a.in_date AS "inDate",
|
a.create_by AS "createBy.id",
|
a.create_date AS "createDate",
|
a.update_by AS "updateBy.id",
|
a.update_date AS "updateDate",
|
a.remarks AS "remarks",
|
a.del_flag AS "delFlag",
|
user.name AS "user.name",
|
office.name AS "office.name",
|
area.name AS "area.name"
|
</sql>
|
|
<sql id="testDataMainJoins">
|
LEFT JOIN sys_user user ON user.id = a.user_id
|
LEFT JOIN sys_office office ON office.id = a.office_id
|
LEFT JOIN sys_area area ON area.id = a.area_id
|
</sql>
|
|
<select id="get" resultType="TestDataMain">
|
SELECT
|
<include refid="testDataMainColumns"/>
|
FROM test_data_main a
|
<include refid="testDataMainJoins"/>
|
WHERE a.id = #{id}
|
</select>
|
|
<select id="findList" resultType="TestDataMain">
|
SELECT
|
<include refid="testDataMainColumns"/>
|
FROM test_data_main a
|
<include refid="testDataMainJoins"/>
|
<where>
|
a.del_flag = #{DEL_FLAG_NORMAL}
|
<if test="name != null and name != ''">
|
AND a.name LIKE
|
<if test="dbName == 'oracle'">'%'||#{name}||'%'</if>
|
<if test="dbName == 'mssql'">'%'+#{name}+'%'</if>
|
<if test="dbName == 'mysql'">concat('%',#{name},'%')</if>
|
</if>
|
<if test="sex != null and sex != ''">
|
AND a.sex = #{sex}
|
</if>
|
<if test="beginInDate != null and endInDate != null and beginInDate != '' and endInDate != ''">
|
AND a.in_date BETWEEN #{beginInDate} AND #{endInDate}
|
</if>
|
<if test="updateDate != null and updateDate != ''">
|
AND a.update_date = #{updateDate}
|
</if>
|
</where>
|
<choose>
|
<when test="page !=null and page.orderBy != null and page.orderBy != ''">
|
ORDER BY ${page.orderBy}
|
</when>
|
<otherwise>
|
ORDER BY a.update_date DESC
|
</otherwise>
|
</choose>
|
</select>
|
|
<select id="findAllList" resultType="TestDataMain">
|
SELECT
|
<include refid="testDataMainColumns"/>
|
FROM test_data_main a
|
<include refid="testDataMainJoins"/>
|
<where>
|
a.del_flag = #{DEL_FLAG_NORMAL}
|
</where>
|
<choose>
|
<when test="page !=null and page.orderBy != null and page.orderBy != ''">
|
ORDER BY ${page.orderBy}
|
</when>
|
<otherwise>
|
ORDER BY a.update_date DESC
|
</otherwise>
|
</choose>
|
</select>
|
|
<insert id="insert">
|
INSERT INTO test_data_main(
|
id,
|
user_id,
|
office_id,
|
area_id,
|
name,
|
sex,
|
in_date,
|
create_by,
|
create_date,
|
update_by,
|
update_date,
|
remarks,
|
del_flag
|
) VALUES (
|
#{id},
|
#{user.id},
|
#{office.id},
|
#{area.id},
|
#{name},
|
#{sex},
|
#{inDate},
|
#{createBy.id},
|
#{createDate},
|
#{updateBy.id},
|
#{updateDate},
|
#{remarks},
|
#{delFlag}
|
)
|
</insert>
|
|
<update id="update">
|
UPDATE test_data_main SET
|
user_id = #{user.id},
|
office_id = #{office.id},
|
area_id = #{area.id},
|
name = #{name},
|
sex = #{sex},
|
in_date = #{inDate},
|
create_date = #{createDate},
|
update_by = #{updateBy.id},
|
update_date = #{updateDate},
|
remarks = #{remarks}
|
WHERE id = #{id}
|
</update>
|
|
|
<!--物理删除-->
|
<update id="delete">
|
DELETE FROM test_data_main
|
WHERE id = #{id}
|
</update>
|
|
<!--逻辑删除-->
|
<update id="deleteByLogic">
|
UPDATE test_data_main SET
|
del_flag = #{DEL_FLAG_DELETE}
|
WHERE id = #{id}
|
</update>
|
|
|
<!-- 根据实体名称和字段名称和字段值获取唯一记录 -->
|
<select id="findUniqueByProperty" resultType="TestDataMain" statementType="STATEMENT">
|
select * FROM test_data_main where ${propertyName} = '${value}'
|
</select>
|
</mapper>
|