马程序员2024最新SpringCloud微服务开发与实战 个人学习心得、踩坑、与bug记录Day1最快 最全(1):https://developer.aliyun.com/article/1548596
代码生成工具 MybatisPlus
讲师推荐的插件安装后 导航栏没有出现Other
- 这是因为你的idea版本比较新
- 新版集成到这里了
- 这里存在的问题,我也不知道怎么办 给项目加了JDBC的依赖也不行
- 我的解决方法是换成下面这个小蓝鸟
小蓝鸟怎么用 看我的另一篇文章
- 选择路径和其他配置项
静态工具
静态工具使用报错 The server time zone value ‘�й���ʱ��’ is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.
问题描述
- 数据库连接没有问题,JDBC依赖也导入了
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.28</version> <!-- JDBC依赖 --> </dependency
- 但显示
解决办法
- 这是你没有设置时区 下面设置的是中国的时区 这里时区要设置成自己国家的 不然生成不出来
jdbc:mysql://localhost:3306/mp?serverTimezone=Asia/Shanghai
静态Db
依赖注入的核心思想是将类的依赖关系从类本身解耦,使得类更加灵活、可测试和可维护。
两个类相互注入可能会导致循环依赖的问题。循环依赖指的是两个或多个类之间存在直接或间接的依赖关系,使得它们无法被实例化。例如,类 A 依赖于类 B,而类 B 又依赖于类 A,这样的情况就会导致循环依赖。
循环依赖可能会导致以下问题:
- 编译错误或运行时异常:在解析类之间的依赖关系时,编译器或运行时容器可能会无法确定类的实例化顺序,导致编译错误或运行时异常。
- 性能问题:循环依赖可能导致对象的创建和初始化过程变得复杂,影响程序的性能。
- 可维护性问题:循环依赖会增加代码的复杂性,降低代码的可读性和可维护性。
为了避免循环依赖,可以考虑以下几种方法:
- 重构类设计:尽量避免直接相互依赖,可以考虑通过接口、抽象类或事件总线等方式来解耦类之间的关系。
- 使用延迟初始化:在需要时才初始化对象,避免在类的构造函数中直接注入其他类的实例。
- 使用依赖注入容器:一些依赖注入容器(如Spring)提供了解决循环依赖的机制,可以通过配置或注解来处理循环依赖的情况。
为什么要在DTO中加上VO
- 数据传输的灵活性:通过将地址信息作为 AddressVO 类独立出来,使得在用户表单实体 UserFormDTO 中可以通过引用 AddressVO 类来包含多个收货地址。这样设计使得用户表单实体可以轻松地与收货地址相关联,同时避免了将地址信息直接嵌入到用户表单实体中的复杂性。
- 代码复用性:通过将收货地址信息抽象为 AddressVO 类,可以在系统的其他地方复用这个类,例如在订单模块中也可能需要使用收货地址信息。这样可以避免代码重复,并提高了系统的可维护性。
- 可扩展性:由于地址信息被抽象成了单独的类,如果将来需要添加更多与收货地址相关的字段或功能,可以直接在 AddressVO 类中进行扩展,而不需要修改用户表单实体 UserFormDTO。这样可以减少对现有代码的影响,降低了系统的耦合度。
- 清晰的数据结构:将用户表单实体和收货地址实体分开设计,使得数据结构更加清晰明了,易于理解和维护。同时,使用
根据用户查询id处爆红
- 加上上面这个即可
public void setAddresses(List<AddressVO> addressVOList) { // 在这里将收货地址列表设置到用户VO中 // 例如,可以直接将地址列表赋值给用户VO中的地址属性 this.addressVOList = addressVOList; }
- 这样就避免了相互依赖
- 互相依赖有不少点可以说的 等过些时候我开篇文详细说说
批量查询
@Override public List<UserVO> queryUserAndAddressByIds(List<Long> ids) { return List.of(); }
@Override public List<UserVO> queryUserAndAddressByIds(List<Long> ids) { // 1 查询用户 List<User> users = listByIds(ids); if (CollUtil.isEmpty(users)) { return Collections.emptyList(); } // 2 查询地址 获取用户集合 List<Long> userIds = users.stream().map(User::getId).collect(Collectors.toList()); // 2.2 根据用户id查询地址 List<Address> addresses = Db.lambdaQuery(Address.class).in(Address::getUserId, userIds).list(); // 3 处理vo List<UserVO> userVOS = BeanUtil.copyToList(users, UserVO.class); userVOS.forEach(userVO -> { List<AddressVO> addressVOS = BeanUtil.copyToList( addresses.stream() .filter(address -> address.getUserId().equals(userVO.getId())) .collect(Collectors.toList()), AddressVO.class); userVO.setAddresses(addressVOS); }); return userVOS; }
- 这是我写的 和老师有所出入 uu们可以自己看看
逻辑删除
枚举处理器
- mybatis实现了类型的int枚举类型转换
- MP的扩展
报错ava.lang.IllegalArgumentException: Could not find @EnumValue in Class: com.itheima.mp.enums.UserStatus. at com.baomidou.mybatisplus.core.handlers.MybatisEnumTypeHandler.lambda$new$0(MybatisEnumTypeHandler.java:65) ~[mybatis-plus-core-3.5.3.1.jar:3.5.3.1]
- 这里官方文档给的代码有错
package com.itheima.mp.enums; import com.baomidou.mybatisplus.annotation.EnumValue; import lombok.Getter; @Getter public enum UserStatus { NORMAL(1, "正常"), FREEZE(2, "冻结") ; @EnumValue private final int value; private final String desc; UserStatus(int value, String desc) { this.value = value; this.desc = desc; } }
@EnumValue
和 @JsonValue
是两个注解,通常用于在 Java 枚举类中定义枚举值的序列化和反序列化方式。
- @EnumValue:
- 用于标识枚举类中表示数据库存储值的字段。
- 在 MyBatis Plus 中,当将枚举值持久化到数据库时,会使用被
@EnumValue
注解标记的字段的值。这个值应该是枚举类中定义的一个整数字段,通常用来表示数据库中的实际存储值。
- @JsonValue:
- 用于标识枚举类中表示枚举值描述的字段。
- 在序列化枚举值时,会使用被
@JsonValue
注解标记的字段的值作为 JSON 字符串的值。
JSON处理器
- 这里在官方文档中记载的很详细
- 因为数据库中的数据是json格式的数据而在实体类中确实String类型 为了解决这件事,所以使用JSON处理器
- 使用TableField
MybatisPlus 内部拦截器
实现分页查询
通用分页实体
- 这里因为分页查询是通用的 因此封装起来
通用分页实体和MP转换
从PageQuery
到MybatisPlus
的Page
之间转换的过程比较麻烦的