<?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.jy.repository.order.CartDao">
<resultMap id="base" type="Cart">
<id column="id" jdbcType="INTEGER" property="id"/>
</resultMap>
<!-- 分页查询List -->
<select id="findByPage" resultMap="base" parameterType="Cart">
SELECT s.* FROM
sc_cart s
where 1=1
and s.userId = #{param.userId}
and s.rentType = #{param.rentType}
<if test="param.selected == 1">
and s.selected = #{param.selected}
</if>
ORDER BY id desc
</select>
<!-- 查询单个对象 -->
<select id="findById" resultMap="base" parameterType="Cart">
SELECT s.* FROM
sc_cart s
where s.id = #{id}
</select>
<select id="find" resultMap="base" parameterType="Cart">
SELECT s.* FROM
sc_cart s
WHERE 1 = 1
and s.goodsId = #{goodsId}
and s.userId = #{userId}
</select>
<select id="count" resultType="int" parameterType="Cart">
SELECT count(*) FROM sc_cart s where s.userId = #{userId}
</select>
<insert id="insert" parameterType="Cart">
INSERT INTO sc_cart(
goodsId,
num,
money,
userId,
goodsName,
goodsImg,
state,
createTime,
firstWeekPrice,
subsequentPrice,
rentType
) VALUES (
#{goodsId},
#{num},
#{money},
#{userId},
#{goodsName},
#{goodsImg},
#{state},
now(),
#{firstWeekPrice},
#{subsequentPrice},
#{rentType}
)
</insert>
<delete id="delete" parameterType="Cart">
delete from sc_cart where 1=1
<if test='id!="" and id != null'>
and id = #{id} and userId=#{userId}
</if>
<if test='goodsId !="" and goodsId != null'>
and goodsId = #{goodsId} AND userId=#{userId}
</if>
</delete>
<update id="update">
UPDATE sc_cart s set s.selected = #{selected} where s.id = #{id}
</update>
<update id="updateAll">
UPDATE sc_cart s set s.selected = #{selected} WHERE s.userId = #{userId}
</update>
<select flushCache="true" id="select_ids" parameterType="Map" resultType="Cart">
SELECT s.*, c.attchentUrl img,a.goodsType goodsType,a.goodsSubType goodsSubType, b.userId agencyUserId,b.account agencyAccount,b.agencyName FROM
sc_cart s
LEFT JOIN cxy_attachment c on s.goodsId = c.goodsId and c.goodType=1 and attchentName='small1'
LEFT JOIN sc_goods a on s.goodsId=a.id
LEFT JOIN sc_service_info b on a.userId=b.userId
where s.id in
<foreach item="item" index="index" collection="ids" open="(" separator="," close=")">
#{item}
</foreach>
and s.userId = #{userId} order by s.id desc
</select>
</mapper>