地址簿增删改
This commit is contained in:
parent
4cda885a01
commit
2089cf6b07
|
@ -0,0 +1,113 @@
|
|||
package com.sky.controller.user;
|
||||
|
||||
import com.sky.context.BaseContext;
|
||||
import com.sky.entity.AddressBook;
|
||||
import com.sky.result.Result;
|
||||
import com.sky.service.AddressBookService;
|
||||
import io.swagger.annotations.Api;
|
||||
import io.swagger.annotations.ApiOperation;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.List;
|
||||
|
||||
@RestController
|
||||
@RequestMapping("/user/addressBook")
|
||||
@Api(tags = "C端地址簿接口")
|
||||
public class AddressBookController {
|
||||
|
||||
@Resource
|
||||
private AddressBookService addressBookService;
|
||||
|
||||
/**
|
||||
* 查询当前登录用户的所有地址信息
|
||||
*
|
||||
* @return Result<List < AddressBook>>
|
||||
*/
|
||||
@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 AddressBook
|
||||
* @return Result
|
||||
*/
|
||||
@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 AddressBook
|
||||
* @return Result
|
||||
*/
|
||||
@PutMapping
|
||||
@ApiOperation("根据id修改地址")
|
||||
public Result update(@RequestBody AddressBook addressBook) {
|
||||
addressBookService.update(addressBook);
|
||||
return Result.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置默认地址
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
* @return Result
|
||||
*/
|
||||
@PutMapping("/default")
|
||||
@ApiOperation("设置默认地址")
|
||||
public Result setDefault(@RequestBody AddressBook addressBook) {
|
||||
addressBookService.setDefault(addressBook);
|
||||
return Result.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 根据id删除地址
|
||||
*
|
||||
* @param id Long
|
||||
* @return Result
|
||||
*/
|
||||
@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 = 1
|
||||
AddressBook 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("没有查询到默认地址");
|
||||
}
|
||||
}
|
|
@ -0,0 +1,55 @@
|
|||
package com.sky.mapper;
|
||||
|
||||
import com.sky.entity.AddressBook;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Mapper
|
||||
public interface AddressBookMapper {
|
||||
|
||||
/**
|
||||
* 条件查询
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
* @return List<AddressBook>
|
||||
*/
|
||||
List<AddressBook> list(AddressBook addressBook);
|
||||
|
||||
/**
|
||||
* 新增
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
*/
|
||||
void insert(AddressBook addressBook);
|
||||
|
||||
/**
|
||||
* 根据id查询
|
||||
*
|
||||
* @param id Long
|
||||
* @return AddressBook
|
||||
*/
|
||||
AddressBook getById(Long id);
|
||||
|
||||
/**
|
||||
* 根据id修改
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
*/
|
||||
void update(AddressBook addressBook);
|
||||
|
||||
/**
|
||||
* 根据 用户id修改 是否默认地址
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
*/
|
||||
void updateIsDefaultByUserId(AddressBook addressBook);
|
||||
|
||||
/**
|
||||
* 根据id删除地址
|
||||
*
|
||||
* @param id
|
||||
*/
|
||||
void deleteById(Long id);
|
||||
|
||||
}
|
|
@ -0,0 +1,20 @@
|
|||
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);
|
||||
|
||||
}
|
|
@ -0,0 +1,86 @@
|
|||
package com.sky.service.impl;
|
||||
|
||||
import com.sky.context.BaseContext;
|
||||
import com.sky.entity.AddressBook;
|
||||
import com.sky.mapper.AddressBookMapper;
|
||||
import com.sky.service.AddressBookService;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.List;
|
||||
|
||||
@Service
|
||||
@Slf4j
|
||||
public class AddressBookServiceImpl implements AddressBookService {
|
||||
@Resource
|
||||
private AddressBookMapper addressBookMapper;
|
||||
|
||||
/**
|
||||
* 条件查询
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
* @return List<AddressBook>
|
||||
*/
|
||||
public List<AddressBook> list(AddressBook addressBook) {
|
||||
return addressBookMapper.list(addressBook);
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增地址
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
*/
|
||||
public void save(AddressBook addressBook) {
|
||||
addressBook.setUserId(BaseContext.getCurrentId());
|
||||
addressBook.setIsDefault(0);
|
||||
addressBookMapper.insert(addressBook);
|
||||
}
|
||||
|
||||
/**
|
||||
* 根据id查询
|
||||
*
|
||||
* @param id Long
|
||||
* @return AddressBook
|
||||
*/
|
||||
public AddressBook getById(Long id) {
|
||||
return addressBookMapper.getById(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* 根据id修改地址
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
*/
|
||||
public void update(AddressBook addressBook) {
|
||||
addressBookMapper.update(addressBook);
|
||||
}
|
||||
|
||||
/**
|
||||
* 设置默认地址
|
||||
*
|
||||
* @param addressBook AddressBook
|
||||
*/
|
||||
@Transactional
|
||||
public 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 Long
|
||||
*/
|
||||
public void deleteById(Long id) {
|
||||
addressBookMapper.deleteById(id);
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,77 @@
|
|||
<?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">
|
||||
|
||||
<!-- 新增 -->
|
||||
<insert id="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})
|
||||
</insert>
|
||||
|
||||
<!-- 根据id删除地址 -->
|
||||
<delete id="deleteById">
|
||||
delete
|
||||
from address_book
|
||||
where id = #{id}
|
||||
</delete>
|
||||
|
||||
<!-- 条件查询 -->
|
||||
<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>
|
||||
|
||||
<!-- 根据id查询 -->
|
||||
<select id="getById" resultType="com.sky.entity.AddressBook">
|
||||
select *
|
||||
from address_book
|
||||
where id = #{id}
|
||||
</select>
|
||||
|
||||
<!-- 根据id修改 -->
|
||||
<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>
|
||||
|
||||
<!-- 根据 用户id修改 是否默认地址 -->
|
||||
<update id="updateIsDefaultByUserId">
|
||||
update address_book
|
||||
set is_default = #{isDefault}
|
||||
where user_id = #{userId}
|
||||
</update>
|
||||
|
||||
</mapper>
|
Loading…
Reference in New Issue