说明:案例使用的是ssm+springBoot+springCloud+redis
通过用户id和商品id构建关系,所以一个user_id在表中会有多条。
思路很简单,就是把用户id从前端传入进来后端,接收用户id,用此id去表里查数据,然后返回一个储存购物车对象的list给前端就可以。
controller层代码:
//根据userId查询用户的购物车list
@RequestMapping("query")
public List<Cart> queryMyCarts(String userId){
return cartService.queryMyCarts(userId);
}
service层代码:
//使用用户id查找用户加入购物车的商品
public List<Cart> queryMyCarts(String userId) {
return cartMapper.selectCartByUserid(userId);
}
mapper和mappers:
List<Cart> selectCartByUserid(String userId);
-------------------------------------------------
<!--select查询我的购物车-->
<select id="selectCartByUserid" resultType="Cart">
select * from t_cart where user_id=#{userId};
</select>
当你在浏览某件商品,需要把他加入购物车,这时就会有两种情况:
1.这个商品之前你已经把他添加到过购物车,所以这一次的添加,实际上是对一个数量的修改,属于update操作。我们需要更新表中对应商品的num值即可
2.此商品在购物车中没有,所以这个操作属于insert操作。我们需要对表进行一次插入操作。
因为这一次使用了微服务之间的调用,所以使用到了ribbon
启动类中:
@Bean
@LoadBalanced
public RestTemplate init(){
return new RestTemplate();
}
controller层:
//新增商品到我的购物车
@RequestMapping("save")
public SysResult addCart(Cart cart){
try{
cartService.addCart(cart);
return SysResult.ok();
}catch (Exception e){
e.printStackTrace();
return SysResult.build(201,"新增购物车失败",null);
}
}
service层:
@Autowired
private RestTemplate template;
public void addCart(Cart cart) {//这次从前端获取到的数据只有userId 和productId
//通过数据查询从数据库查询已有,所以执行的是update操作
Cart existCart=cartMapper.selectCartByUseridAndProductid(cart);
if(existCart!=null){
//说明购物车商品在表格中已存在的
//把已存在的商品num+新增商品num
//update t_cart set num=num+#{num} 更新num功能中重新写sql
//update t_cart set num=#{num} 更新num可以直接调用
cart.setNum(cart.getNum()+existCart.getNum());
cartMapper.updateNumByUseridAndProductid(cart);
}else{//需要新增一个cart对象到数据库
//cart对象中只有userId productId num 没有productName productPrice productImage
//RestTemplate 发送微服务调用 请求商品系统的单个商品查询功能
String url="http://productservice/product/manage/item/"+cart.getProductId();
Product p=template.getForObject(url, Product.class);
if(p!=null){//说明商品系统查到了数据
cart.setProductName(p.getProductName());
cart.setProductPrice(p.getProductPrice());
cart.setProductImage(p.getProductImgurl());
cartMapper.insertCart(cart);
}else{
throw new RuntimeException("从商品系统根本没查到商品数据");
}
}
}
mapper和mappers:
Cart selectCartByUseridAndProductid(Cart cart);
void updateNumByUseridAndProductid(Cart cart);
void insertCart(Cart cart);
--------------------------------------------------
<!--查询已存在-->
<select id="selectCartByUseridAndProductid" resultType="Cart">
select * from t_cart where user_id=#{userId}
and product_id=#{productId};
</select>
<!--更新num-->
<update id="updateNumByUseridAndProductid">
update t_cart set num=#{num} where user_id=#{userId}
and product_id=#{productId};
</update>
<!--新增购物车-->
<insert id="insertCart">
insert into t_cart (
user_id,product_id,num,
product_name,product_price,product_image) values (
#{userId},#{productId},#{num},
#{productName},#{productPrice},#{productImage}
)
</insert>
这里做的很简单了,就是去修改表里的num值。(后面这个是我的猜想,我也没有做过,大家可以看看对不对)还可以把它做到缓存里,当你每次修改完购物车信息,就可以把user_id+uuid+product_id生成一个key,把商品信息转换成一个json作为value,存入redis缓存中,同时把user_id+uuid+product_id存入cookie的value中,当用户下次再点击购物车,如果没有正在修改,则从缓存中查询数据。也可以做数据一致性。
controller层:
//购物车商品的更新
//接收到的num数量就是更新的最终数量 不要和旧数据相加
@RequestMapping("update")
public SysResult updateNum(Cart cart){
//cart参数包含了 productId userId num
try{
cartService.updateNum(cart);
return SysResult.ok();
}catch (Exception e){
e.printStackTrace();
return SysResult.build(201,"更新num失败",null);
}
}
service层:
public void updateNum(Cart cart) {
//持久层在新增购物车时完成了更新num的功能
cartMapper.updateNumByUseridAndProductid(cart);
}
mapper和mappers:
void updateNumByUseridAndProductid(Cart cart);
-----------------------------------------------
<!--更新num-->
<update id="updateNumByUseridAndProductid">
update t_cart set num=#{num} where user_id=#{userId}
and product_id=#{productId};
</update>
这个更简单,就是删除数据库一条记录,如果再redis中做了缓存,把缓存也一起删了就可以。
controller层:
@RequestMapping("delete")
public SysResult deleteCart(Cart cart){
//cart中只包含2个数据 userId productId
try{
cartService.deleteCart(cart);
return SysResult.ok();
}catch (Exception e){
e.printStackTrace();
return SysResult.build(201,"删除购物车失败",null);
}
}
service层:
public void deleteCart(Cart cart) {
cartMapper.deleteCartByUseridAndProductid(cart);
}
mapper和mappers:
void deleteCartByUseridAndProductid(Cart cart);
--------------------------------------------------
<delete id="deleteCartByUseridAndProductid">
delete from t_cart where user_id=#{userId}
and product_id=#{productId};
</delete>