bkjxxxw/build/classes/mappings/modules/test/onetomany/TestDataMainDao.xml

157 lines
3.8 KiB
XML

<?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 "tuser.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",
tuser.name AS "tuser.name",
office.name AS "office.name",
area.name AS "area.name"
</sql>
<sql id="testDataMainJoins">
LEFT JOIN sys_user tuser ON tuser.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="tuser != null and tuser.id != null and tuser.id != ''">
AND a.user_id = #{tuser.id}
</if>
<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>
</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},
#{tuser.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 = #{tuser.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>