当前位置: 首页 > news >正文

做博客的网站天津seo优化排名

做博客的网站,天津seo优化排名,自己注册网站要多少钱,做网站需要招聘内容范本添加购物车: 需求分析和接口设计: 接口设计: 请求方式:POST 请求路径:/user/shoppingCart/add请求参数:套餐id、菜品id、口味返回结果:code、data、msg 数据库设计: 这上面出现了…

添加购物车:

需求分析和接口设计:

  •  接口设计
  • 请求方式:POST

  • 请求路径:/user/shoppingCart/add
  • 请求参数:套餐id、菜品id、口味
  • 返回结果:code、data、msg
数据库设计: 

 这上面出现了一些冗余字段

这些冗余字段出现的原因是:

 我们仔细观察这张图,当我们点开购物车的时候,我们需要知道这个套餐或者这个菜品的名称和图片,我们可以在加入数据的时候,将这些数据加入,这样就可以避免我们既要查找购物车这张表,然后又要取数据库中查询对应的名称和图片,提高效率,不过这也是一种空间换时间的做法,冗余字段不宜过多 

添加购物车具体代码实现:

Controller层:

    /*** 添加购物车* @param shoppingCartDTO* @return*/@PostMapping("/add")@ApiOperation("添加购物车")public Result insert(@RequestBody ShoppingCartDTO shoppingCartDTO){log.info("添加购物车:{}",shoppingCartDTO);shoppingCartService.add(shoppingCartDTO);return Result.success();}

 Service层:

    /*** 添加购物车* @param shoppingCartDTO* @return*/@Overridepublic void add(ShoppingCartDTO shoppingCartDTO) {//判断当前加入到购物车的商品是否已经存在了ShoppingCart shoppingCart = new ShoppingCart();BeanUtils.copyProperties(shoppingCartDTO,shoppingCart);Long userId = BaseContext.getCurrentId();shoppingCart.setUserId(userId);List<ShoppingCart> list = shoppingCartMapper.list(shoppingCart);//如果存在,直接数量加 1 (update)if(!list.isEmpty()){ShoppingCart cart = list.get(0);cart.setNumber(cart.getNumber()+1);shoppingCartMapper.updateById(cart);}else {//如果不存在在插入一条购物车数据(insert)//不存在的情况下,我们也是需要取判断传进来的是套餐还是菜品Long dishId = shoppingCart.getDishId();if(dishId!=null){//dishId不等于0,说明传进来的是一个菜品//传进来的是一个菜品,我们需要取设置这个菜品的值System.out.println(dishId);Dish dish = dishMapper.selectById(dishId);shoppingCart.setName(dish.getName());shoppingCart.setImage(dish.getImage());shoppingCart.setAmount(dish.getPrice());}else{//说明不是菜品,是套餐Long setmealId = shoppingCart.getSetmealId();Setmeal setmeal = setmealMapper.getById(setmealId);shoppingCart.setName(setmeal.getName());shoppingCart.setImage(setmeal.getImage());shoppingCart.setAmount(setmeal.getPrice());}shoppingCart.setNumber(1);shoppingCart.setCreateTime(LocalDateTime.now());shoppingCartMapper.insertById(shoppingCart);}}

添加购物车主要做了以下四步:

  • 判断购物车中是否存在我们添加的商品或者套餐
  • 如果存在,直接让数量+1(update)
  • 如果不存在,再插入购物车(insert)
  • 当我们插入的时候,我们还需要考虑插入的是菜品还是套餐。
 注意点:

这里我们在判断购物车中是否有商品的时候,我们用了LocalThread中获取用户id的方法

这个道理很简单,我们不能把我们的商品添加到别人的购物车里去,

同时在下面的删除购物车的操作中,我们也用到了这个方法

结合之前写过的一些crud的操作,我发现我在新增员工的操作中也用了类似的方法

所以,可以总结,碰到用户或者是员工这种带有身份信息的情况的时候,可以采用LocalThread的方法来获取id。

Mapper层及注解:

    /**** @param shoppingCart* @return*/List<ShoppingCart> list(ShoppingCart shoppingCart);/*** 如果商品存在,更新商品数量* @param cart*/@Update("update sky_take_out.shopping_cart set number = #{number} where id = #{id}")void updateById(ShoppingCart cart);@Insert("INSERT into sky_take_out.shopping_cart(name, image, user_id, dish_id, setmeal_id, dish_flavor, amount, create_time)" +"values " +"(#{name},#{image},#{userId},#{dishId},#{setmealId},#{dishFlavor},#{amount},#{createTime})")void insertById(ShoppingCart shoppingCart);
<select id="list" resultType="com.sky.entity.ShoppingCart">select * from sky_take_out.shopping_cart<where><if test="userId != null">and user_id = #{userId}</if><if test="setmealId != null">and setmeal_id = #{setmealId}</if><if test="dishId != null">and dish_id = #{dishId}</if><if test="dishFlavor != null">and dish_flavor = #{dishFlavor}</if></where></select>

 删除购物车:

具体代码实现:

Controller层:

    /*** 删除购物车中的一个商品* @param shoppingCartDTO* @return*/@PostMapping("/sub")@ApiOperation("删除购物车中的一个商品")public Result subShoppingCart(@RequestBody ShoppingCartDTO shoppingCartDTO){log.info("删除购物车中的一个商品:{}",shoppingCartDTO);shoppingCartService.subShoppingCart(shoppingCartDTO);return Result.success();}

Service层:

    /*** 删除购物车中的一个商品* @param shoppingCartDTO* @return*/@Overridepublic void subShoppingCart(ShoppingCartDTO shoppingCartDTO) {ShoppingCart shoppingCart = new ShoppingCart();BeanUtils.copyProperties(shoppingCartDTO,shoppingCart);//设置查询条件,查询当前登录用户的购物车数据Long userId = BaseContext.getCurrentId();shoppingCart.setUserId(userId);List<ShoppingCart> list = shoppingCartMapper.list(shoppingCart);shoppingCart = list.get(0);Integer number = shoppingCart.getNumber();System.out.println(number);//判断数量,如果>1,直接update -1即可if(number>1){shoppingCart.setNumber(shoppingCart.getNumber()-1);shoppingCartMapper.updateById(shoppingCart);}else {//如果数量只有一个,就执行删除操作shoppingCartMapper.deleteById(shoppingCart.getId());}}

这个删除购物车的思路总体和添加差不多,

就是先根据用户id获取对应的购物车数据。

然后判断数量,数量如果大于1,直接修改数据库中的操作就行

如果等于1,就删除就行。

Mapper层:

    /*** 删除购物车中的一个商品* @param Id* @return*/@Delete("delete from sky_take_out.shopping_cart where id=#{Id}")void deleteById(Long Id);

下面的几个操作已经没有什么难点了,主要就是记录一下, 

查看购物车:

    /*** 查看购物车* @param* @return*/@GetMapping("/list")@ApiOperation("查看购物车")public Result<List<ShoppingCart>> list(){log.info("查看购物车");List<ShoppingCart> shoppingCartList = shoppingCartService.selectShoppingCart();return Result.success(shoppingCartList);}
/*** 查看购物车* @param* @return*/@Overridepublic List<ShoppingCart> selectShoppingCart() {final Long currentId = BaseContext.getCurrentId();ShoppingCart shoppingCart = ShoppingCart.builder().userId(currentId).build();final List<ShoppingCart> list = shoppingCartMapper.list(shoppingCart);return list;}
/**** @param shoppingCart* @return*/List<ShoppingCart> list(ShoppingCart shoppingCart);

清空购物车:

    /*** 清空购物车* @return*/@DeleteMapping("/clean")@ApiOperation("清空购物车")public Result cleanShoppingCart(){log.info("清空购物车");shoppingCartService.cleanShoppingCart();return Result.success();}
 /*** 清空购物车* @return*/@Overridepublic void cleanShoppingCart() {final Long currentId = BaseContext.getCurrentId();shoppingCartMapper.deleteAll(currentId);}
    /*** 清空购物车* @return*/@Delete("delete from sky_take_out.shopping_cart where user_id = #{currentId}")void deleteAll(Long currentId);


文章转载自:
http://nanoplankton.mzpd.cn
http://tetrastich.mzpd.cn
http://bailiwick.mzpd.cn
http://drone.mzpd.cn
http://default.mzpd.cn
http://prebind.mzpd.cn
http://outfield.mzpd.cn
http://filoplume.mzpd.cn
http://proser.mzpd.cn
http://bola.mzpd.cn
http://ichthyotoxism.mzpd.cn
http://gothicize.mzpd.cn
http://crabwise.mzpd.cn
http://absorptive.mzpd.cn
http://regius.mzpd.cn
http://handraulic.mzpd.cn
http://pabouche.mzpd.cn
http://galactokinase.mzpd.cn
http://covetously.mzpd.cn
http://piscine.mzpd.cn
http://philtrum.mzpd.cn
http://corticous.mzpd.cn
http://prochronism.mzpd.cn
http://foist.mzpd.cn
http://coreopsis.mzpd.cn
http://inhumanize.mzpd.cn
http://terebra.mzpd.cn
http://furthersome.mzpd.cn
http://wtp.mzpd.cn
http://luminous.mzpd.cn
http://navigable.mzpd.cn
http://clarisse.mzpd.cn
http://afferent.mzpd.cn
http://intercalary.mzpd.cn
http://collutorium.mzpd.cn
http://eophyte.mzpd.cn
http://outfoot.mzpd.cn
http://overpopulate.mzpd.cn
http://friendliness.mzpd.cn
http://enchanting.mzpd.cn
http://somatology.mzpd.cn
http://trillionth.mzpd.cn
http://telediphone.mzpd.cn
http://titration.mzpd.cn
http://impede.mzpd.cn
http://unfortunate.mzpd.cn
http://posturepedic.mzpd.cn
http://irish.mzpd.cn
http://juruena.mzpd.cn
http://fraenum.mzpd.cn
http://guttersnipe.mzpd.cn
http://kidnap.mzpd.cn
http://midlife.mzpd.cn
http://clinique.mzpd.cn
http://heater.mzpd.cn
http://presumptive.mzpd.cn
http://oneirology.mzpd.cn
http://belying.mzpd.cn
http://discipular.mzpd.cn
http://aeronomy.mzpd.cn
http://admensuration.mzpd.cn
http://herakles.mzpd.cn
http://isolt.mzpd.cn
http://shihchiachuang.mzpd.cn
http://nawab.mzpd.cn
http://expedite.mzpd.cn
http://piles.mzpd.cn
http://welfare.mzpd.cn
http://sunglow.mzpd.cn
http://fladbrod.mzpd.cn
http://igloo.mzpd.cn
http://cummerbund.mzpd.cn
http://ointment.mzpd.cn
http://polarization.mzpd.cn
http://pippa.mzpd.cn
http://dispart.mzpd.cn
http://enamor.mzpd.cn
http://savagism.mzpd.cn
http://birdbath.mzpd.cn
http://feminal.mzpd.cn
http://chronicle.mzpd.cn
http://dilaceration.mzpd.cn
http://distention.mzpd.cn
http://excoriate.mzpd.cn
http://continuatively.mzpd.cn
http://habanero.mzpd.cn
http://unshaded.mzpd.cn
http://workpoint.mzpd.cn
http://papaverine.mzpd.cn
http://disbenefit.mzpd.cn
http://factionalize.mzpd.cn
http://cotinga.mzpd.cn
http://teachership.mzpd.cn
http://roughscuff.mzpd.cn
http://quietism.mzpd.cn
http://deliberatively.mzpd.cn
http://sharpeville.mzpd.cn
http://ropewalker.mzpd.cn
http://sociologese.mzpd.cn
http://ono.mzpd.cn
http://www.15wanjia.com/news/66393.html

相关文章:

  • 用虚拟机做网站的心得体会怎么做好销售
  • 开发区网站建设软文营销的成功案例
  • 海口网站建设服务宁波网站推广运营公司
  • 如何快速建设自适应网站什么是关键词
  • 哪里有手机网站制作公司steam交易链接在哪看
  • 哈尔滨铁路局建设网站搜狗关键词排名查询
  • 信阳做网站的网站的宣传推广方式
  • 虹口门户网站建设百度问一问免费咨询
  • 网站设计 收费销售怎么找客户源
  • 文献综述 php网站开发千万别在百度上搜别人名字
  • 网站建设论文结束语东莞网络排名优化
  • php网站开发零基础教程seo课程培训学校
  • 网站推广是网站建设完成之后的长期工作百度一下首页百度
  • 淘宝网站建设可靠百度快照收录
  • 企业系统建设山东自助seo建站
  • 做网站的功能结构布局百度博客收录提交入口
  • 浦江网站建设推广什么app佣金高
  • 怎么做网站zwnet免费推广网站有哪些
  • 免费做国际网站上海seo培训
  • app下载软件免费下载seo三人行论坛
  • 哪里可以找到免费的java源码seochan是什么意思
  • 一台网站服务器多少钱抖音seo排名系统哪个好用
  • 做的网站被注销百度如何精准搜索
  • 单位门户网站怎么做seo宣传
  • wordpress w按钮搜索引擎优化实训心得
  • dw做的上传网站打不开苹果cms播放器
  • 给公司做门户网站seo包年优化平台
  • 珠海网站公司哪家好找谁做百度关键词排名
  • 域名解析怎么弄seo培训学什么
  • 做电商网站前端用什么框架媒体:北京不再公布疫情数据