<?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.zcloud.mapper.datasource.operatingvehicles.OperatingVehiclesMapper">

	<!--表名 -->
	<sql id="tableName">
		BUS_TRAFFIC_OPERATINGVEHICLE
	</sql>

	<!--数据字典表名 -->
	<sql id="dicTableName">
		SYS_DICTIONARIES
	</sql>

	<!-- 字段 -->
	<sql id="Field">
		f.OPERATING_ID,
		f.GOODSSELFNUMBER,
		f.CORPINFO_ID,
		f.PLATE_NUMBER,
		f.VEHICLE_COLOR,
		f.FRAMES_NUMBER,
		f.CONTACT,
		f.CONTACT_NUMBER,
		f.VEHICLE_TYPE,
		f.FIRSTSHOW_DATE,
		f.EXPIRE_DATE,
		f.VEHICLE_EQUIPMENT,
		f.BELONGING_DEPARTMENT,
		f.TRANSPORT_ENTERPRISES,
		f.TRANSPORT_TYPE,
		f.NETWORK_STATUS,
		f.DYNAMIC_SUPERVISION,
		f.ACTIVE_SAFETY,
		f.DRIVINGPREMIT_STATUS,
		f.ENGINE_NUMBER,
		f.OPERATING_CERTIFICATE,
		f.VEHICLEOWNER,
		f.VEHICLEOWNER_NUMBER,
		f.VEHICLEOWNER_ADDRESS,
		f.HOME_ADDRESS,
		f.PHYSICAL_ADDRESS,
		f.CERTIFICATE_DATE,
		f.GOVERNMENT_OVERSIGHT,
		f.VEHICLE_BRAND,
		f.VEHICLE_MODEL,
		f.FUEL_TYPE,
		f.EMISSION_STANDARD,
		f.VOUCH_TOTALMASS,
		f.VOUCH_NUMBERLOAD,
		f.VOUCH_PAYLOAD,
		f.RACTIONMASS_QUALITY,
		f.HOME_TERRITORY,
		f.REMARK,
		f.HEADSTOCK_PHOTO,
		f.DRIVINGLICENSE_PHOTO,
		f.OPERATING_CERTIFICATE_PHOTO,
		f.VEHICLE_MATERIAL,
		f.FREIGHT_TYPE,
		f.TRANSPORT_CATEGORY,
		f.ISDELETE,
		f.CREATOR,
		f.CREATORNAME,
		f.CREATTIME,
		f.OPERATOR,
		f.OPERATORNAME,
		f.OPERATTIME,
		f.DELETOR,
		f.DELETORNAME,
		f.DELETTIME,
		f.ISSCRAP,
		f.ISASSIGNED
	</sql>

	<!-- 字段用于新增 -->
	<sql id="Field2">
		OPERATING_ID,
		GOODSSELFNUMBER,
		CORPINFO_ID,
		PLATE_NUMBER,
		VEHICLE_COLOR,
		FRAMES_NUMBER,
		CONTACT,
		CONTACT_NUMBER,
		VEHICLE_TYPE,
		FIRSTSHOW_DATE,
		EXPIRE_DATE,
		VEHICLE_EQUIPMENT,
		BELONGING_DEPARTMENT,
		TRANSPORT_ENTERPRISES,
		TRANSPORT_TYPE,
		NETWORK_STATUS,
		DYNAMIC_SUPERVISION,
		ACTIVE_SAFETY,
		DRIVINGPREMIT_STATUS,
		ENGINE_NUMBER,
		OPERATING_CERTIFICATE,
		VEHICLEOWNER,
		VEHICLEOWNER_NUMBER,
		VEHICLEOWNER_ADDRESS,
		HOME_ADDRESS,
		PHYSICAL_ADDRESS,
		CERTIFICATE_DATE,
		GOVERNMENT_OVERSIGHT,
		VEHICLE_BRAND,
		VEHICLE_MODEL,
		FUEL_TYPE,
		EMISSION_STANDARD,
		VOUCH_TOTALMASS,
		VOUCH_NUMBERLOAD,
		VOUCH_PAYLOAD,
		RACTIONMASS_QUALITY,
		HOME_TERRITORY,
		REMARK,
		HEADSTOCK_PHOTO,
		DRIVINGLICENSE_PHOTO,
		OPERATING_CERTIFICATE_PHOTO,
		VEHICLE_MATERIAL,
		FREIGHT_TYPE,
		TRANSPORT_CATEGORY,
		ISDELETE,
		CREATOR,
		CREATORNAME,
		CREATTIME,
		OPERATOR,
		OPERATORNAME,
		OPERATTIME,
		DELETOR,
		DELETORNAME,
		DELETTIME,
		ISSCRAP,
		ISASSIGNED
	</sql>

	<!-- 字段值 -->
	<sql id="FieldValue">
		#{OPERATING_ID},
		#{GOODSSELFNUMBER},
		#{CORPINFO_ID},
		#{PLATE_NUMBER},
		#{VEHICLE_COLOR},
		#{FRAMES_NUMBER},
		#{CONTACT},
		#{CONTACT_NUMBER},
		#{VEHICLE_TYPE},
		#{FIRSTSHOW_DATE},
		#{EXPIRE_DATE},
		#{VEHICLE_EQUIPMENT},
		#{BELONGING_DEPARTMENT},
		#{TRANSPORT_ENTERPRISES},
		#{TRANSPORT_TYPE},
		#{NETWORK_STATUS},
		#{DYNAMIC_SUPERVISION},
		#{ACTIVE_SAFETY},
		#{DRIVINGPREMIT_STATUS},
		#{ENGINE_NUMBER},
		#{OPERATING_CERTIFICATE},
		#{VEHICLEOWNER},
		#{VEHICLEOWNER_NUMBER},
		#{VEHICLEOWNER_ADDRESS},
		#{HOME_ADDRESS},
		#{PHYSICAL_ADDRESS},
		#{CERTIFICATE_DATE},
		#{GOVERNMENT_OVERSIGHT},
		#{VEHICLE_BRAND},
		#{VEHICLE_MODEL},
		#{FUEL_TYPE},
		#{EMISSION_STANDARD},
		#{VOUCH_TOTALMASS},
		#{VOUCH_NUMBERLOAD},
		#{VOUCH_PAYLOAD},
		#{RACTIONMASS_QUALITY},
		#{HOME_TERRITORY},
		#{REMARK},
		#{HEADSTOCK_PHOTO},
		#{DRIVINGLICENSE_PHOTO},
		#{OPERATING_CERTIFICATE_PHOTO},
		#{VEHICLE_MATERIAL},
		#{FREIGHT_TYPE},
		#{TRANSPORT_CATEGORY},
		#{ISDELETE},
		#{CREATOR},
		#{CREATORNAME},
		#{CREATTIME},
		#{OPERATOR},
		#{OPERATORNAME},
		#{OPERATTIME},
		#{DELETOR},
		#{DELETORNAME},
		#{DELETTIME},
		#{ISSCRAP},
		#{ISASSIGNED}
	</sql>

	<!-- 新增-->
	<insert id="save" parameterType="pd">
		insert into
	<include refid="tableName"></include>
		(
	<include refid="Field2"></include>
		) values (
	<include refid="FieldValue"></include>
		)
	</insert>

	<!-- 删除-->
	<delete id="delete" parameterType="pd">
		update
		<include refid="tableName"></include>
		set
			ISDELETE = '1',ISSCRAP = '1'
		where
			OPERATING_ID = #{OPERATING_ID}
	</delete>

	<!-- 修改 -->
	<update id="edit" parameterType="pd">
		update
		<include refid="tableName"></include>
		set
		OPERATING_ID = #{OPERATING_ID},
		GOODSSELFNUMBER = #{GOODSSELFNUMBER},
		PLATE_NUMBER = #{PLATE_NUMBER},
		VEHICLE_COLOR = #{VEHICLE_COLOR},
		FRAMES_NUMBER = #{FRAMES_NUMBER},
		CONTACT = #{CONTACT},
		CONTACT_NUMBER = #{CONTACT_NUMBER},
		VEHICLE_TYPE = #{VEHICLE_TYPE},
		FIRSTSHOW_DATE = #{FIRSTSHOW_DATE},
		EXPIRE_DATE = #{EXPIRE_DATE},
		VEHICLE_EQUIPMENT = #{VEHICLE_EQUIPMENT},
		BELONGING_DEPARTMENT = #{BELONGING_DEPARTMENT},
		TRANSPORT_ENTERPRISES = #{TRANSPORT_ENTERPRISES},
		TRANSPORT_TYPE = #{TRANSPORT_TYPE},
		NETWORK_STATUS = #{NETWORK_STATUS},
		DYNAMIC_SUPERVISION = #{DYNAMIC_SUPERVISION},
		ACTIVE_SAFETY = #{ACTIVE_SAFETY},
		DRIVINGPREMIT_STATUS = #{DRIVINGPREMIT_STATUS},
		ENGINE_NUMBER = #{ENGINE_NUMBER},
		OPERATING_CERTIFICATE = #{OPERATING_CERTIFICATE},
		VEHICLEOWNER = #{VEHICLEOWNER},
		VEHICLEOWNER_NUMBER = #{VEHICLEOWNER_NUMBER},
		VEHICLEOWNER_ADDRESS = #{VEHICLEOWNER_ADDRESS},
		HOME_ADDRESS = #{HOME_ADDRESS},
		PHYSICAL_ADDRESS = #{PHYSICAL_ADDRESS},
		CERTIFICATE_DATE = #{CERTIFICATE_DATE},
		GOVERNMENT_OVERSIGHT = #{GOVERNMENT_OVERSIGHT},
		VEHICLE_BRAND = #{VEHICLE_BRAND},
		VEHICLE_MODEL = #{VEHICLE_MODEL},
		FUEL_TYPE = #{FUEL_TYPE},
		EMISSION_STANDARD = #{EMISSION_STANDARD},
		VOUCH_TOTALMASS = #{VOUCH_TOTALMASS},
		VOUCH_NUMBERLOAD = #{VOUCH_NUMBERLOAD},
		VOUCH_PAYLOAD = #{VOUCH_PAYLOAD},
		HOME_TERRITORY = #{HOME_TERRITORY},
		RACTIONMASS_QUALITY = #{RACTIONMASS_QUALITY},
		REMARK = #{REMARK},
		HEADSTOCK_PHOTO = #{HEADSTOCK_PHOTO},
		DRIVINGLICENSE_PHOTO = #{DRIVINGLICENSE_PHOTO},
		OPERATING_CERTIFICATE_PHOTO = #{OPERATING_CERTIFICATE_PHOTO},
		VEHICLE_MATERIAL = #{VEHICLE_MATERIAL},
		FREIGHT_TYPE = #{FREIGHT_TYPE},
		TRANSPORT_CATEGORY = #{TRANSPORT_CATEGORY},
		ISDELETE = #{ISDELETE},
		CREATOR = #{CREATOR},
		CREATORNAME = #{CREATORNAME},
		CREATTIME = #{CREATTIME},
		OPERATOR = #{OPERATOR},
		OPERATORNAME = #{OPERATORNAME},
		OPERATTIME = #{OPERATTIME},
		DELETOR = #{DELETOR},
		DELETORNAME = #{DELETORNAME},
		DELETTIME = #{DELETTIME},
		CORPINFO_ID = #{CORPINFO_ID},
		ISSCRAP = #{ISSCRAP},
		ISASSIGNED = #{ISASSIGNED}
		where
			OPERATING_ID = #{OPERATING_ID}
	</update>

	<!-- 通过ID获取数据 -->
	<select id="findById" parameterType="pd" resultType="pd">
		select
		<include refid="Field"></include>
		from
		<include refid="tableName"></include> f
		where
		f.OPERATING_ID = #{OPERATING_ID} AND
		f.ISDELETE = '0' AND
		f.CORPINFO_ID = #{CORPINFO_ID}
	</select>

	<update id="setScrapStatus" parameterType="pd">
		update
		<include refid="tableName"></include>
		set
		ISSCRAP = '1'
		where
		OPERATING_ID = #{OPERATING_ID}
		and
		CORPINFO_ID = #{CORPINFO_ID}
	</update>


	<!-- 通过ID获取数据 -->
	<select id="findByfindByPlateNumber" parameterType="pd" resultType="pd">
		select
		<include refid="Field"></include>
		from
		<include refid="tableName"></include> f
		where
		f.PLATE_NUMBER = #{PLATE_NUMBER} AND
		f.CORPINFO_ID = #{CORPINFO_ID}
	</select>

	<!-- 列表 -->
	<!--<select id="datalistPage" parameterType="page" resultType="pd">
		select
		<include refid="Field"></include>
		from
		<include refid="tableName"></include> f
		left join sys_user u on u.USER_ID = f.USER_ID
		left join oa_department d on d.DEPARTMENT_ID = u.DEPARTMENT_ID
		left join sys_post p on p.POST_ID = u.POST_ID
		left join sys_user ru on ru.USER_ID = f.REVIEW_USER_ID
		left join oa_department rd on rd.DEPARTMENT_ID = ru.DEPARTMENT_ID
		where (f.ISDELETE = '0' or (f.ISDELETE = '1' and f.REVIEW_STATUS = '-1'))
		and f.CORPINFO_ID = #{pd.CORPINFO_ID}
		<if test="pd.KEYWORDS != null and pd.KEYWORDS != ''">&lt;!&ndash; 关键词检索 &ndash;&gt;
			and
				(
					u.NAME LIKE CONCAT(CONCAT('%', #{pd.KEYWORDS}),'%')
				)
		</if>
		<if test="pd.REVIEW_STATUS != null and pd.REVIEW_STATUS != ''">&lt;!&ndash; 关键词检索 &ndash;&gt;
			<choose>
				<when test="pd.REVIEW_STATUS == 0">
					and f.REVIEW_STATUS = '0'
				</when>
				<when test="pd.REVIEW_STATUS == 1">
					and f.REVIEW_STATUS = '1'
				</when>
				<when test="pd.REVIEW_STATUS == 2">
					and f.REVIEW_STATUS = '2'
				</when>
				<when test="pd.REVIEW_STATUS == -1">
					and f.ISDELETE = '0' and f.REVIEW_STATUS = '-1'
				</when>
				<when test="pd.REVIEW_STATUS == 3">
					and f.CREATOR = f.OPERATOR and f.ISDELETE = '1' and f.REVIEW_STATUS = '-1'
				</when>
				<when test="pd.REVIEW_STATUS == 4">
					and f.CREATOR != f.OPERATOR and f.ISDELETE = '1' and f.REVIEW_STATUS = '-1'
				</when>
			</choose>
		</if>
		<if test="pd.REVIEW_USER_NAME != null and pd.REVIEW_USER_NAME != ''">&lt;!&ndash; 关键词检索 &ndash;&gt;
			and ru.NAME LIKE CONCAT(CONCAT('%', #{pd.REVIEW_USER_NAME}),'%')
		</if>
		<if test="pd.DEPT_DOWN_ARR != null and pd.DEPT_DOWN_ARR.size() > 0">
			AND d.DEPARTMENT_ID IN
			<foreach item="item" collection="pd.DEPT_DOWN_ARR" open="(" separator="," close=")">
				'${item}'
			</foreach>
		</if>
&lt;!&ndash; 		<if test="pd.DEPARTMENT_ID != null and pd.DEPARTMENT_ID != ''">关键词检索
			and d.DEPARTMENT_ID = #{pd.DEPARTMENT_ID}
		</if>
		 &ndash;&gt;

		<choose>
			<when test='pd.ISMAIN != null and pd.ISMAIN != "" and pd.ISMAIN == "1"'>
				<if test="pd.DEPT_IDS != null and pd.DEPT_IDS != ''">
	                and
					d.DEPARTMENT_ID in
					<foreach item="item" index="index"
						collection="pd.DEPT_IDS" open="(" separator="," close=")">
						'${item}'
					</foreach>
	            </if>
			</when>
			<otherwise>
				<choose>
		            <when test='pd.ISSUPERVISE != null and pd.ISSUPERVISE != "" and pd.ISSUPERVISE == "1"'>
						<choose>
							<when test='pd.ISLEADER != null and pd.ISLEADER != "" and pd.ISLEADER == "1"'>
								<choose>
									<when test="pd.DEPT_IDS != null and pd.DEPT_IDS != ''">
										and
										d.DEPARTMENT_ID in
										<foreach item="item" index="index"
												 collection="pd.DEPT_IDS" open="(" separator="," close=")">
											'${item}'
										</foreach>
									</when>
									<otherwise>
										and
										((d.DEPARTMENT_ID in (
										select
										SUB_DEPARTMENT_ID
										from
										oa_supervision_department osd
										where
										osd.SUP_DEPARTMENT_ID = #{pd.DEPARTMENT_ID}
										and osd.ISDELETE = '0'
										and osd.CORPINFO_ID  = #{pd.CORPINFO_ID}
										)) or (
										d.DEPARTMENT_ID in
										<foreach item="item" index="index"
												 collection="pd.DEPARTMENT_IDS" open="(" separator="," close=")">
											'${item}'
										</foreach>
										))
									</otherwise>
								</choose>
							</when>
							<when test="pd.DEPT_IDS != null and pd.DEPT_IDS != ''">
								or f.REVIEW_USER_ID = #{pd.USER_ID}
								and
								d.DEPARTMENT_ID in
								<foreach item="item" index="index"
										 collection="pd.DEPT_IDS" open="(" separator="," close=")">
									'${item}'
								</foreach>
							</when>
							<otherwise>

								and
								d.DEPARTMENT_ID in (
								select
								SUB_DEPARTMENT_ID
								from
								oa_supervision_department osd
								where
								osd.SUP_DEPARTMENT_ID = #{pd.DEPARTMENT_ID}
								and osd.ISDELETE = '0'
								and osd.CORPINFO_ID  = #{pd.CORPINFO_ID})
								or f.REVIEW_USER_ID = #{pd.USER_ID}
							</otherwise>
						</choose>
					</when>
					<when test='pd.ISLEADER != null and pd.ISLEADER != "" and pd.ISLEADER == "1"'>
						<choose>
							<when test="pd.DEPT_IDS != null and pd.DEPT_IDS != ''">
								and
								d.DEPARTMENT_ID in
								<foreach item="item" index="index"
										 collection="pd.DEPT_IDS" open="(" separator="," close=")">
									'${item}'
								</foreach>
							</when>
							<otherwise>
								and
								d.DEPARTMENT_ID in
								<foreach item="item" index="index"
										 collection="pd.DEPARTMENT_IDS" open="(" separator="," close=")">
									'${item}'
								</foreach>
							</otherwise>
						</choose>
					</when>
		            <when test="pd.DEPARTMENT_ID != null and pd.DEPARTMENT_ID != ''">
		                and d.DEPARTMENT_ID=#{pd.DEPARTMENT_ID}
		                and f.REVIEW_USER_ID = #{pd.USER_ID}
		            </when>
		            <otherwise>
		            </otherwise>
		        </choose>
			</otherwise>
		</choose>
		<choose>
			<when test="pd.STARTTIME != null and pd.STARTTIME != '' and pd.ENDTIME != null and pd.ENDTIME != ''">
				and DATE_FORMAT(#{pd.STARTTIME},'%Y-%m-%d %H:%i:%s') &lt;= DATE_FORMAT(f.STARTTIME,'%Y-%m-%d %H:%i:%s')
				and DATE_FORMAT(#{pd.ENDTIME},'%Y-%m-%d %H:%i:%s') &gt;= DATE_FORMAT(f.ENDTIME,'%Y-%m-%d %H:%i:%s')
			</when>
			<otherwise>
				<if test="pd.STARTTIME != null and pd.STARTTIME != ''">
					and DATE_FORMAT(#{pd.STARTTIME},'%Y-%m-%d %H:%i:%s') &lt;= DATE_FORMAT(f.ENDTIME,'%Y-%m-%d %H:%i:%s')
				</if>
				<if test="pd.ENDTIME != null and pd.ENDTIME != ''">
					and DATE_FORMAT(#{pd.ENDTIME},'%Y-%m-%d %H:%i:%s') &gt;= DATE_FORMAT(f.STARTTIME,'%Y-%m-%d %H:%i:%s')
				</if>
			</otherwise>
		</choose>
		order by f.OPERATTIME desc
	</select>-->

	<!-- 列表(全部) -->
	<select id="datalistPage" parameterType="page" resultType="pd">
		select
		<include refid="Field"></include>
		from
		<include refid="tableName"></include> f
		where f.ISDELETE = '0' and f.CORPINFO_ID = #{pd.CORPINFO_ID}
		<if test="pd.PLATE_NUMBER != null and pd.PLATE_NUMBER != ''"><!-- 关键词检索 -->
			and f.PLATE_NUMBER LIKE CONCAT(CONCAT('%', #{pd.PLATE_NUMBER}),'%')
		</if>
		<if test="pd.VEHICLE_COLOR != null and pd.VEHICLE_COLOR != ''"><!-- 关键词检索 -->
			and f.VEHICLE_COLOR LIKE CONCAT(CONCAT('%', #{pd.VEHICLE_COLOR}),'%')
		</if>
		<if test="pd.FRAMES_NUMBER != null and pd.FRAMES_NUMBER != ''"><!-- 关键词检索 -->
			and f.FRAMES_NUMBER LIKE CONCAT(CONCAT('%', #{pd.FRAMES_NUMBER}),'%')
		</if>
		<if test="pd.GOODSSELFNUMBER != null and pd.GOODSSELFNUMBER != ''"><!-- 关键词检索 -->
			and f.GOODSSELFNUMBER LIKE CONCAT(CONCAT('%', #{pd.GOODSSELFNUMBER}),'%')
		</if>
		<if test="pd.BELONGING_DEPARTMENT != null and pd.BELONGING_DEPARTMENT != ''"><!-- 关键词检索 -->
			and f.BELONGING_DEPARTMENT LIKE CONCAT(CONCAT('%', #{pd.BELONGING_DEPARTMENT}),'%')
		</if>
		<if test="pd.TRANSPORT_TYPE != null and pd.TRANSPORT_TYPE != ''"><!-- 关键词检索 -->
			and f.TRANSPORT_TYPE = #{pd.TRANSPORT_TYPE}
		</if>
		<if test="pd.NETWORK_STATUS != null and pd.NETWORK_STATUS != ''"><!-- 关键词检索 -->
			and f.NETWORK_STATUS = #{pd.NETWORK_STATUS}
		</if>
		<if test="pd.DYNAMIC_SUPERVISION != null and pd.DYNAMIC_SUPERVISION != ''"><!-- 关键词检索 -->
			and f.DYNAMIC_SUPERVISION = #{pd.DYNAMIC_SUPERVISION}
		</if>
		<if test="pd.ACTIVE_SAFETY != null and pd.ACTIVE_SAFETY != ''"><!-- 关键词检索 -->
			and f.ACTIVE_SAFETY = #{pd.ACTIVE_SAFETY}
		</if>
		<if test="pd.DRIVINGPREMIT_STATUS != null and pd.DRIVINGPREMIT_STATUS != ''"><!-- 关键词检索 -->
			and f.DRIVINGPREMIT_STATUS = #{pd.DRIVINGPREMIT_STATUS}
		</if>
		order by f.OPERATTIME DESC
	</select>

	<select id="listAll" parameterType="pd" resultType="pd">
		select
		<include refid="Field"></include>
		from
		<include refid="tableName"></include> f
		where f.ISDELETE = '0'
	</select>

	<select id="operationVehicleList" parameterType="page" resultType="pd">
		select
		*
		from
		<include refid="tableName"></include>
		f
		where f.CORPINFO_ID = #{corpId}
		and f.ISDELETE = '0'
		and f.ISSCRAP = '0'
	</select>

	<!-- 所属企业列表 -->
	<select id="corpList" parameterType="page" resultType="pd">
		select
			*
		from
			bus_corp_info f
		where f.ISDELETE = '0' and f.CORPINFO_ID = #{corpId}
	</select>


</mapper>