IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SpringBoot JPA 的自我总结 -> 正文阅读

[Java知识库]SpringBoot JPA 的自我总结

序。

从名称见名思意,使用的springboot写的,创建框架省略,主要是探讨JPA的一对多和多对一

いち.老规矩导入依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.75</version>
        </dependency>
        <!--jpa 核心依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
            <version>2.6.5</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.28</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

に.目录结构

?

?san.application.properties配置datasource

#自动生成数据库表(关键)
spring.jpa.hibernate.ddl-auto=update
#mysql数据库连接配置(非常重要)版本大于5的可以不用设置时区
spring.datasource.url=jdbc:mysql://localhost:3306/****?serverTimezone=Asia/Shanghai
#数据库用户名
spring.datasource.username=自己的用户名
#数据库密码
spring.datasource.password=自己的密码
#mysql数据库驱动程序(重要)
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#jpa配置:在控制台显示Hibernate的sql(可选)
spring.jpa.show-sql=true
#其他配置:关闭Thymeleaf 的缓存 如果使用了前端框架thymeleaf,那请关掉,不然你的样式处于刚开始的阶段
spring.thymeleaf.cache=false

よん。探讨多对一所以就需要两个实体类Album和Photo

Album表

@Entity
@Table(name = "t_album")
@Data
public class Album {
    @Id
   /* @GeneratedValue(strategy = GenerationType.IDENTITY)*/
    private Integer id;
    @Column
    private String name;
    @JsonManagedReference
    @OneToMany(cascade = CascadeType.ALL,fetch = FetchType.EAGER,mappedBy = "album")
    //一这一方应该是容器
    private List<Photo> photo;
}

Photo表


@Entity
@Table(schema = "springbootjpa" ,name= "t_Photo")
@Data
public class Photo {
    @Id
    //@GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    @Column
    private  String name;
    @JsonBackReference
    @ManyToOne(cascade = CascadeType.REFRESH)
    @JoinColumn(name = "album_id",referencedColumnName = "id")
    private Album album;
}

这里Photo为多的一方,

注解为? ?@ManyToOne(cascade = CascadeType.REFRESH),

Album为单一的一方,

注解为?@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER, mappedBy = "album")

在这我里会在photo中创建一列album_id

(这里会出现一个问题,这一列,你在手动加入的时候,怎么都没有值,问了很多,看了很多,两个解决办法!

解决办法一,眼不见心不烦,也是跟着时代走,把这一列索引取消,方法我没写,因为有强迫症,我都写完了,为什么没有值。这也就第二个方法

解决办法二

了解一下问啥没有值

此时其对应的外联实体对象可能直接保存在该实体类对象中,就像买一把玩具手枪会带一包枪子一样,不是从库中获取的。此时外联对象中的外键也为null,所以在调用save方法时,外联对象进行添加时会出现为外键null的情况,如果设置了外键不为null就会报错,解决的一个方法是:将外键字段设为可以为null,在主键实体对象调用save方法后获取该主键实体对象的所有外键实体对象,遍历所有对象,将其对应的属性设置为主键实体对象(一定要在主键实体对象调用了save方法之后,此时主键实体对象中的id属性就被赋值了),然后逐个调用save方法进行update

所以在方法中加入这一列就属于不可能了,所以只有强行了

)

?在service中加入这个方法

  public Photo addPhoto( Photo photo) {
        Album album=new Album();
        album.setId(2);
        photo.setId(1);
        photo.setName("photo");
        photo.setAlbum(album);
        return  photoRepository.save(photo);
    }

service层?

这里了看出来他没有impl,也就是和其他框架不一样了

//AlbumService
@RestController
public class PhotoService {
    @Autowired
    PhotoRepository photoRepository;
    @RequestMapping(value = "/photo", method = RequestMethod.POST)
    public Photo addPhoto( Photo photo) {
        Album album=new Album();
        album.setId(2);
        photo.setId(1);
        photo.setName("photo");
        photo.setAlbum(album);
        return  photoRepository.save(photo);
    }

    @RequestMapping(value = "/photo/all", method = RequestMethod.GET)
    public List<Photo> getAllPhotos() {
        return photoRepository.findAll();
    }

    @RequestMapping(value = "/photo/album", method = RequestMethod.GET)
    public List<Photo> getAlbumPhotos(@RequestBody Album album) {
        return photoRepository.findByAlbum(album);
    }

}
//PhotoService
@RestController
public class PhotoService {
    @Autowired
    PhotoRepository photoRepository;
    @RequestMapping(value = "/photo", method = RequestMethod.POST)
    public Photo addPhoto( Photo photo) {
        Album album=new Album();
        album.setId(2);
        photo.setId(1);
        photo.setName("photo");
        photo.setAlbum(album);
        return  photoRepository.save(photo);
    }

    @RequestMapping(value = "/photo/all", method = RequestMethod.GET)
    public List<Photo> getAllPhotos() {
        return photoRepository.findAll();
    }

    @RequestMapping(value = "/photo/album", method = RequestMethod.GET)
    public List<Photo> getAlbumPhotos(@RequestBody Album album) {
        return photoRepository.findByAlbum(album);
    }

}

?但是他多了一个Repository仓库也就是dao层,继承了一个类JpaRepository,这个类封装了很多方法,一般的CRUD都有

?

也可以自己写sql,自己写方法,但是如果自己写了,那想放当于回到了最初,方法步骤都一样

总结到此结束!很多注解没解释,但是都不难

又是美好得一天

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-05-01 15:33:33  更:2022-05-01 15:36:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 2:06:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码