首页 > 编程知识 正文

Spring全家桶(java jpa)

时间:2023-05-06 11:12:17 阅读:87350 作者:4702

什么是JPA?

一个规范不是ORM框架,也就是ORM上的统一规范

用了能做什么,为什么要用?

代码解释:

实体类别

包com.example.spring redis .实体;

导入lombok .数据;

导入javax .持久性.实体;

导入javax .持久性.生成值;

导入javax .持久性.生成类型;

导入Javax .持久性.标识;

import Java.io .序列化;

@Entity

@Data

publicclassuserimplementsserializable {

@Id

@生成值(strategy=生成类型.自动) )。

私有长期身份;

私有字符串名称;

私有字符串帐户;

私有字符串pwd;

}

dao层

@存储库

publicinterfaceuserdaoextendsjparepositoryuser,长{长}

}

测试类

@自动无线

私人使用者密码;

公共语音查找全部测试(

系统输出(用户查找);

}

我相信上面的操作已经完成了一个查询的全部,不用做额外的说明

JPA的优点:主要是使用方便,集成方便,不用写SQL语句

准备工作

这里的环境

JDK 1.8或更高版本的IDEA 2018.2Gradle 4或Maven 3.2使用https://start.spring.io/初始化项目

这里使用的是Gradle

下载后,请使用IDEA导入项目

设置build.gradle

构建脚本{2}

ext {2}

springbootversion='2.1.0.版本'

}

存储库{

mavenCentral ()

}

从属关系{

类路径(org.spring框架. boot : spring-boot-grad le-plugin : $ { springbootversion } ) )

}

}

应用程序插件: ' Java -库'

苹果插件: ' idea '

应用程序插件: ' org.spring框架.引导'

应用插件: ' io.spring .从属-管理'

组=' com.example '

版本=' 0.0.1 -快照'

源兼容性=1.8

存储库{

maven ' http://maven.a liyun.com /下一个/内容/组/公共/'

}

//Gradle3.4添加了使用新的依赖关系实施和api的Java-library插件。 旧的依赖关系配置compile将被放弃

从属关系{

实施(org.spring框架. boot : spring-boot -启动数据- JPA ) )

实施(MySQL : MySQL -连接器- Java ) )

compile only (' org.project lombok : lombok ) )

测试模板(' org.spring框架. boot : spring-boot -启动程序-测试' )

}

开始定义简单的实体

package com.example.springbootjpademo .实体;

导入lombok .数据;

导入javax .持久性.实体;

导入javax .持久性.生成值;

导入javax .持久性.生成类型;

导入Javax .持久性.标识;

@Entity

@Data

公共类用户

@Id

@生成值(strategy=生成类型. identity ) )。

私有身份

te Long id; private String name; private String ename; protected User() { } public User(String name, String ename) { this.name = name; this.ename = ename; } @Override public String toString() { /* JAVA字符串格式化-String.format() %s 字符串类型 %d 整数类型(十进制) */ return String.format("Customer[id=%d, name='%s', ename='%s']", id, name, ename); } } 这里有一个User类,它有三个属性,id,name和ename。你还有两个构造函数。默认构造函数仅为JPA而存在。您不会直接使用它,因此它被指定为 protected 。另一个构造函数是您将用于创建要保存到数据库的user实例的构造函数。在User类上加 @Entity 注解,表示这个是一个 JPA 的实体,如果在 User 类上没有加 @Table 注解,表明该实体将映射到名为user的表,如果要加上 @Table ,可以在其 name 属性里写入表名,如: @Table(name = "t_user")User的id属性使用@Id注释,以便JPA将其识别为对象的ID。id属性也使用@GeneratedValue注释@GeneratedValue(strategy = GenerationType.IDENTITY) 自增长ID策略其他两个属性name和ename未注释。表明它们将映射到与属性本身相同一名称的列,比如,User实体中的name属性映射user表中的name列。toString() 方便将打印出实体的属性

创建一个 UserRepository 接口

这里很简单,直接继承核心接口JpaRepository

src/main/java/com/example/springbootjpademo/repository/UserRepository.java

package com.example.springbootjpademo.repository; import com.example.springbootjpademo.entity.User; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.stereotype.Repository; @Repository public interface UserRepository extends JpaRepository<User, Long> { }

配置文件application.yml

修改application.properties 为 application.yml

src/main/resources/application.yml

spring: # 数据源配置 datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://127.0.0.1:3306/test?调皮的大象=utf-8&useSSL=false username: root password: 123456 jpa: # 在 SrpingBoot 2.0 版本中,Hibernate 创建数据表的时候,默认的数据库存储引擎选择的是 MyISAM #(之前好像是 InnoDB,这点比较诡异)。这个参数是在建表的时候,将默认的存储引擎切换为 InnoDB 用的。 database-platform: org.hibernate.dialect.MySQL5InnoDBDialect # spring.jpa.show-sql=true 配置在日志中打印出执行的 SQL 语句信息。 show-sql: true # 配置指明在程序启动的时候要删除并且创建实体类对应的表。 # create 这个参数很危险,因为他会把对应的表删除掉然后重建。所以千万不要在生成环境中使用。只有在测试环境中,一开始初始化数据库结构的时候才能使用一次。 # ddl-auto:create----每次运行该程序,没有表格会新建表格,表内有数据会清空 # ddl-auto:create-drop----每次程序结束的时候会清空表 # ddl-auto:update----每次运行程序,没有表格会新建表格,表内有数据不会清空,只会更新(推荐) # ddl-auto:validate----运行程序会校验数据与数据库的字段类型是否相同,不同会报错 hibernate.ddl-auto: update

建立测试类进行查询

src/test/java/com/example/springbootjpademo/SpringbootJpaDemoApplicationTests.java

package com.example.springbootjpademo; import com.example.springbootjpademo.repository.UserRepository; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith(SpringRunner.class) @SpringBootTest public class SpringbootJpaDemoApplicationTests { @Autowired private UserRepository userRepository; @Test public void contextLoads() { System.out.println(userRepository.findAll().toString()); } }

输出

注意

如果出现下列等错误:

Error:(41, 13) java: 找不到符号 符号: 方法 setName(java.lang.String) 位置: 类型为com.example.springbootjpademo.entity.User的变量 user

请注意下面的设置是否正确:

其他操作

src/test/java/com/example/springbootjpademo/SpringbootJpaDemoApplicationTests.java

package com.example.springbootjpademo; import com.example.springbootjpademo.entity.User; import com.example.springbootjpademo.repository.UserRepository; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith(SpringRunner.class) @SpringBootTest public class SpringbootJpaDemoApplicationTests { @Autowired private UserRepository userRepository; @Test public void contextLoads() { System.out.println(userRepository.findAll().toString()); } @Before public void add() { userRepository.save(new User("英雄联盟", "lol")); } //修改操作 @After public void update() { // ifPresent 如果存在值,则使用值调用指定的使用者,否则不执行任何操作。 userRepository.findById(1L).ifPresent(user -> { user.setName("xiugaihou"); userRepository.save(user); System.out.println(user.toString()); }); } //删除 @After public void del() { userRepository.findById(2L).ifPresent(user -> userRepository.delete(user)); } }

最后数据库的值:

码云代码地址

https://gitee.com/cuifuan/SpringBoot

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。