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

电商网站开发面试题百度如何收录网站

电商网站开发面试题,百度如何收录网站,龙岩有什么公司,jsp做网站视频教程地址簿相关功能 1.1 需求分析和设计1.1.1 产品原型1.1.2 接口设计1.1.3 表设计 1.2 代码实现1.2.1 Mapper层1.2.2 Service层1.2.3 Controller层 1.1 需求分析和设计 1.1.1 产品原型 地址簿,指的是消费者用户的地址信息,用户登录成功后可以维护自己的地…

地址簿相关功能

  • 1.1 需求分析和设计
    • 1.1.1 产品原型
    • 1.1.2 接口设计
    • 1.1.3 表设计
  • 1.2 代码实现
    • 1.2.1 Mapper层
    • 1.2.2 Service层
    • 1.2.3 Controller层

1.1 需求分析和设计

1.1.1 产品原型

地址簿,指的是消费者用户的地址信息,用户登录成功后可以维护自己的地址信息。同一个用户可以有多个地址信息,但是只能有一个默认地址
在这里插入图片描述

对于地址簿管理,有以下几个功能:

  • 查询地址列表
  • 新增地址
  • 修改地址
  • 删除地址
  • 设置默认地址
  • 查询默认地址

1.1.2 接口设计

根据上述原型图先粗粒度设计接口,共包含7个接口。

接口设计:

  • 新增地址
  • 查询登录用户所有地址
  • 查询默认地址
  • 根据id修改地址
  • 根据id删除地址
  • 根据id查询地址
  • 设置默认地址

接下来细粒度分析每个接口,明确每个接口的请求方式、请求路径、传入参数和返回值。

1). 新增地址
在这里插入图片描述

2). 查询登录用户所有地址

在这里插入图片描述

3). 查询默认地址

在这里插入图片描述

4). 修改地址
在这里插入图片描述
5). 根据id删除地址

在这里插入图片描述

6). 根据id查询地址

在这里插入图片描述

7). 设置默认地址

在这里插入图片描述

1.1.3 表设计

用户的地址信息会存储在address_book表,即地址簿表中。具体表结构如下:

字段名数据类型说明备注
idbigint主键自增
user_idbigint用户id逻辑外键
consigneevarchar(50)收货人
sexvarchar(2)性别
phonevarchar(11)手机号
province_codevarchar(12)省份编码
province_namevarchar(32)省份名称
city_codevarchar(12)城市编码
city_namevarchar(32)城市名称
district_codevarchar(12)区县编码
district_namevarchar(32)区县名称
detailvarchar(200)详细地址信息具体到门牌号
labelvarchar(100)标签公司、家、学校
is_defaulttinyint(1)是否默认地址1是 0否

这里面有一个字段is_default,实际上我们在设置默认地址时,只需要更新这个字段就可以了。

1.2 代码实现

1.2.1 Mapper层

创建AddressBookMapper.java

package com.sky.mapper;import com.sky.entity.AddressBook;
import org.apache.ibatis.annotations.*;
import java.util.List;@Mapper
public interface AddressBookMapper {/*** 条件查询* @param addressBook* @return*/List<AddressBook> list(AddressBook addressBook);/*** 新增* @param addressBook*/@Insert("insert into address_book" +"        (user_id, consignee, phone, sex, province_code, province_name, city_code, city_name, district_code," +"         district_name, detail, label, is_default)" +"        values (#{userId}, #{consignee}, #{phone}, #{sex}, #{provinceCode}, #{provinceName}, #{cityCode}, #{cityName}," +"                #{districtCode}, #{districtName}, #{detail}, #{label}, #{isDefault})")void insert(AddressBook addressBook);/*** 根据id查询* @param id* @return*/@Select("select * from address_book where id = #{id}")AddressBook getById(Long id);/*** 根据id修改* @param addressBook*/void update(AddressBook addressBook);/*** 根据 用户id修改 是否默认地址* @param addressBook*/@Update("update address_book set is_default = #{isDefault} where user_id = #{userId}")void updateIsDefaultByUserId(AddressBook addressBook);/*** 根据id删除地址* @param id*/@Delete("delete from address_book where id = #{id}")void deleteById(Long id);}

创建AddressBookMapper.xml

<?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.sky.mapper.AddressBookMapper"><select id="list" parameterType="AddressBook" resultType="AddressBook">select * from address_book<where><if test="userId != null">and user_id = #{userId}</if><if test="phone != null">and phone = #{phone}</if><if test="isDefault != null">and is_default = #{isDefault}</if></where></select><update id="update" parameterType="addressBook">update address_book<set><if test="consignee != null">consignee = #{consignee},</if><if test="sex != null">sex = #{sex},</if><if test="phone != null">phone = #{phone},</if><if test="detail != null">detail = #{detail},</if><if test="label != null">label = #{label},</if><if test="isDefault != null">is_default = #{isDefault},</if></set>where id = #{id}</update></mapper>

1.2.2 Service层

创建AddressBookService.java

package com.sky.service;import com.sky.entity.AddressBook;
import java.util.List;public interface AddressBookService {List<AddressBook> list(AddressBook addressBook);void save(AddressBook addressBook);AddressBook getById(Long id);void update(AddressBook addressBook);void setDefault(AddressBook addressBook);void deleteById(Long id);}

创建AddressBookServiceImpl.java

package com.sky.service.impl;@Service
@Slf4j
public class AddressBookServiceImpl implements AddressBookService {@Autowiredprivate AddressBookMapper addressBookMapper;/*** 条件查询** @param addressBook* @return*/public List<AddressBook> list(AddressBook addressBook) {return addressBookMapper.list(addressBook);}/*** 新增地址** @param addressBook*/public void save(AddressBook addressBook) {addressBook.setUserId(BaseContext.getCurrentId());addressBook.setIsDefault(0);addressBookMapper.insert(addressBook);}/*** 根据id查询** @param id* @return*/public AddressBook getById(Long id) {AddressBook addressBook = addressBookMapper.getById(id);return addressBook;}/*** 根据id修改地址** @param addressBook*/public void update(AddressBook addressBook) {addressBookMapper.update(addressBook);}/*** 设置默认地址** @param addressBook*/@Transactionalpublic void setDefault(AddressBook addressBook) {//1、将当前用户的所有地址修改为非默认地址 update address_book set is_default = ? where user_id = ?addressBook.setIsDefault(0);addressBook.setUserId(BaseContext.getCurrentId());addressBookMapper.updateIsDefaultByUserId(addressBook);//2、将当前地址改为默认地址 update address_book set is_default = ? where id = ?addressBook.setIsDefault(1);addressBookMapper.update(addressBook);}/*** 根据id删除地址** @param id*/public void deleteById(Long id) {addressBookMapper.deleteById(id);}}

1.2.3 Controller层

package com.sky.controller.user;@RestController
@RequestMapping("/user/addressBook")
@Api(tags = "C端地址簿接口")
public class AddressBookController {@Autowiredprivate AddressBookService addressBookService;/*** 查询当前登录用户的所有地址信息** @return*/@GetMapping("/list")@ApiOperation("查询当前登录用户的所有地址信息")public Result<List<AddressBook>> list() {AddressBook addressBook = new AddressBook();addressBook.setUserId(BaseContext.getCurrentId());List<AddressBook> list = addressBookService.list(addressBook);return Result.success(list);}/*** 新增地址** @param addressBook* @return*/@PostMapping@ApiOperation("新增地址")public Result save(@RequestBody AddressBook addressBook) {addressBookService.save(addressBook);return Result.success();}@GetMapping("/{id}")@ApiOperation("根据id查询地址")public Result<AddressBook> getById(@PathVariable Long id) {AddressBook addressBook = addressBookService.getById(id);return Result.success(addressBook);}/*** 根据id修改地址** @param addressBook* @return*/@PutMapping@ApiOperation("根据id修改地址")public Result update(@RequestBody AddressBook addressBook) {addressBookService.update(addressBook);return Result.success();}/*** 设置默认地址** @param addressBook* @return*/@PutMapping("/default")@ApiOperation("设置默认地址")public Result setDefault(@RequestBody AddressBook addressBook) {addressBookService.setDefault(addressBook);return Result.success();}/*** 根据id删除地址** @param id* @return*/@DeleteMapping@ApiOperation("根据id删除地址")public Result deleteById(Long id) {addressBookService.deleteById(id);return Result.success();}/*** 查询默认地址*/@GetMapping("default")@ApiOperation("查询默认地址")public Result<AddressBook> getDefault() {//SQL:select * from address_book where user_id = ? and is_default = 1AddressBook addressBook = new AddressBook();addressBook.setIsDefault(1);addressBook.setUserId(BaseContext.getCurrentId());List<AddressBook> list = addressBookService.list(addressBook);if (list != null && list.size() == 1) {return Result.success(list.get(0));}return Result.error("没有查询到默认地址");}}

后记
👉👉💕💕美好的一天,到此结束,下次继续努力!欲知后续,请看下回分解,写作不易,感谢大家的支持!! 🌹🌹🌹


文章转载自:
http://tyuyamunite.cwgn.cn
http://sparseness.cwgn.cn
http://extrahazardous.cwgn.cn
http://dichroiscopic.cwgn.cn
http://charcuterie.cwgn.cn
http://desiccation.cwgn.cn
http://ankylose.cwgn.cn
http://rainband.cwgn.cn
http://scripturally.cwgn.cn
http://lampoonist.cwgn.cn
http://steamer.cwgn.cn
http://symphonette.cwgn.cn
http://blackish.cwgn.cn
http://midi.cwgn.cn
http://tusky.cwgn.cn
http://stormbound.cwgn.cn
http://phytogenic.cwgn.cn
http://grammatology.cwgn.cn
http://duodecimal.cwgn.cn
http://actiniae.cwgn.cn
http://adhere.cwgn.cn
http://reluctancy.cwgn.cn
http://toyland.cwgn.cn
http://serfage.cwgn.cn
http://imp.cwgn.cn
http://chelated.cwgn.cn
http://misdo.cwgn.cn
http://oxpecker.cwgn.cn
http://akebi.cwgn.cn
http://antifebrile.cwgn.cn
http://mort.cwgn.cn
http://thermolysin.cwgn.cn
http://expropriation.cwgn.cn
http://connection.cwgn.cn
http://releasee.cwgn.cn
http://passerine.cwgn.cn
http://nodulated.cwgn.cn
http://calyculus.cwgn.cn
http://congeries.cwgn.cn
http://toltec.cwgn.cn
http://agronomy.cwgn.cn
http://panathenaea.cwgn.cn
http://adornment.cwgn.cn
http://fingerhold.cwgn.cn
http://defoam.cwgn.cn
http://spectra.cwgn.cn
http://zillionaire.cwgn.cn
http://bench.cwgn.cn
http://differentia.cwgn.cn
http://angleworm.cwgn.cn
http://neurotrophic.cwgn.cn
http://probative.cwgn.cn
http://distortive.cwgn.cn
http://conchoid.cwgn.cn
http://compunctious.cwgn.cn
http://slavery.cwgn.cn
http://canalicular.cwgn.cn
http://journalist.cwgn.cn
http://magnisonant.cwgn.cn
http://warmer.cwgn.cn
http://aethelbert.cwgn.cn
http://valhalla.cwgn.cn
http://anogenital.cwgn.cn
http://retardance.cwgn.cn
http://restiform.cwgn.cn
http://isogenic.cwgn.cn
http://kedger.cwgn.cn
http://rasht.cwgn.cn
http://hyaena.cwgn.cn
http://rumour.cwgn.cn
http://tergum.cwgn.cn
http://compuserve.cwgn.cn
http://misdiagnose.cwgn.cn
http://bright.cwgn.cn
http://aneurysmal.cwgn.cn
http://extortion.cwgn.cn
http://scorer.cwgn.cn
http://mavrodaphne.cwgn.cn
http://phosphene.cwgn.cn
http://lumpen.cwgn.cn
http://pestiferous.cwgn.cn
http://whitmonday.cwgn.cn
http://interconvert.cwgn.cn
http://aias.cwgn.cn
http://zincum.cwgn.cn
http://ampul.cwgn.cn
http://boardwalk.cwgn.cn
http://genova.cwgn.cn
http://pastorship.cwgn.cn
http://sharable.cwgn.cn
http://entrap.cwgn.cn
http://apprehension.cwgn.cn
http://warmer.cwgn.cn
http://pastille.cwgn.cn
http://settlor.cwgn.cn
http://renovate.cwgn.cn
http://memorialise.cwgn.cn
http://upward.cwgn.cn
http://orfray.cwgn.cn
http://straphang.cwgn.cn
http://www.hrbkazy.com/news/63802.html

相关文章:

  • 制作网站公司首 荐乐云seo软文范例800字
  • 设计一个企业网站报价郑州网络运营培训
  • 做暧嗳xo小视频网站seo从0到1怎么做
  • 电子工程设计网站营销手段
  • 手机网站建设价格表seo网站内容优化有哪些
  • 沈阳建筑大学网络信息化中心常州seo收费
  • 香港的贸易公司可以做网站吗帮人推广的平台
  • 宿迁做网站推广资讯
  • 网站排名首页怎么做百度域名收录提交入口
  • 如何做网站后台管理系统石家庄高级seo经理
  • cms建站程序百度搜索引擎首页
  • 单产品网站模板网站关键词优化多少钱
  • 世界杯网页设计素材seo网站诊断
  • 微信自创小程序甲马营seo网站优化的
  • 做电商怎么建网站福州网站排名
  • 自适应网站模板源码郑州发布最新通告
  • 北京商城网站建设报价seo网页推广
  • 官方关停13家网站武汉百度推广多少钱
  • 一分钟了解网络广告seo难不难
  • 做网站80端口百度app首页
  • 电子商务网站建设的步骤过程武汉百度百科
  • 小说网站制作seo网络优化软件
  • 商铺装修seo是怎么优化推广的
  • 南宁网站建设哪家公司好天津百度网站排名优化
  • sae 部署wordpress仁茂网络seo
  • 呼和浩特网站建设宁波seo费用
  • 网页广告拦截福州短视频seo方法
  • 网站后台空白seo推广的方法
  • 公司网站建设有什么好处百度指数怎么分析
  • 杭州电商网站平台开发公司北京百度快速优化排名