5023225026e06a67fa891b7ec64f05b736a91f99.svn-base 3.48 KB
<?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.thinkgem.jeesite.modules.xuygtest.dao.TestDataDao">
    
	<sql id="testDataColumns">
		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",
		u2.name AS "user.name",
		o3.name AS "office.name",
		a4.name AS "area.name"
	</sql>
	
	<sql id="testDataJoins">
		LEFT JOIN sys_user u2 ON u2.id = a.user_id
		LEFT JOIN sys_office o3 ON o3.id = a.office_id
		LEFT JOIN sys_area a4 ON a4.id = a.area_id
	</sql>
    
	<select id="get" resultType="TestData">
		SELECT 
			<include refid="testDataColumns"/>
		FROM test_data a
		<include refid="testDataJoins"/>
		WHERE a.id = #{id}
	</select>
	
	<select id="findList" resultType="TestData">
		SELECT 
			<include refid="testDataColumns"/>
		FROM test_data a
		<include refid="testDataJoins"/>
		<where>
			a.del_flag = #{DEL_FLAG_NORMAL}
			<if test="user != null and user.id != null and user.id != ''">
				AND a.user_id = #{user.id}
			</if>
			<if test="office != null and office.id != null and office.id != ''">
				AND a.office_id = #{office.id}
			</if>
			<if test="area != null and area.id != null and area.id != ''">
				AND a.area_id = #{area.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="TestData">
		SELECT 
			<include refid="testDataColumns"/>
		FROM test_data a
		<include refid="testDataJoins"/>
		<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(
			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 SET 	
			user_id = #{user.id},
			office_id = #{office.id},
			area_id = #{area.id},
			name = #{name},
			sex = #{sex},
			in_date = #{inDate},
			update_by = #{updateBy.id},
			update_date = #{updateDate},
			remarks = #{remarks}
		WHERE id = #{id}
	</update>
	
	<update id="delete">
		UPDATE test_data SET 
			del_flag = #{DEL_FLAG_DELETE}
		WHERE id = #{id}
	</update>
	
</mapper>