您的位置:首页 > 健康 > 美食 > 公司内部网站_2023年房地产彻底结束_开发一个app价目表_网络营销seo培训

公司内部网站_2023年房地产彻底结束_开发一个app价目表_网络营销seo培训

2025/1/4 13:49:57 来源:https://blog.csdn.net/2401_84881237/article/details/142165789  浏览:    关键词:公司内部网站_2023年房地产彻底结束_开发一个app价目表_网络营销seo培训
公司内部网站_2023年房地产彻底结束_开发一个app价目表_网络营销seo培训

JPA 相关概念

ORM 框架

(Object Relational Mapping) 建立 Java 程序实体类与数据库表之间的映射关系。使用 ORM 框架进行编程 Java 程序会根据开发者配置,在运行时自动把数据对象持久化到数据库中,比直接使用 JDBC 编程更为方便和强大。

常见的 ORM 框架有 Hibernate, MyBatis 等。

JPA 规范

(Java 持久性 API)Java 程序和数据库连接的 Java EE 标准,本质上是一种 ORM 规范。使用户不必在 Java 程序中书写 SQL 语句就能直接把数据对象持久化到数据库中,由数据库厂商负责具体实现。

JDBC 和 JPA 的区别
  • JDBC 是面向 SQL 的规范和接口,用户仍需要在 java 程序中书写 SQL 语句。
  • JPA 是直接面向数据对象的规范和接口,可以通过直接操作对象来实现持久化,大大简化了操作的繁杂度。

P.S. Hibernate 是符合 JPA 规范的,而 MyBatis 却不符合,因为 MyBatis 还需要书写 SQL 语句。

SpringBoot 中 JPA 的使用 - 简书


Spring JPA

Spring 框架中提供了对数据操作的框架 SpringData ;SpringData 框架下则提供了基于 JPA 标准操作数据的模块 SpringData JPA 。

导入 javax.persistence.Column; 导入 javax.persistence.Entity; 进口 javax.persistence.Id; 导入 javax.persistence.Table;

实体类

@Entity声明实体类,自动对应数据库表(必选)

@Table(name = "AUTH_USER")声明了数据库实体对应的表名,如果没有默认表名和实体名一致。

属性

@Id声明属性对应数据库字段是主键。

@Column(length = 32)用来声明实体属性的表字段的定义。

  1. name - 属性对应数据库字段名,默认和属性名称一致。
  2. length - 属性对应数据库字段长度,默认 255。
  3. 属性对应数据库字段类型会自动推断。
@Entity
@Table(name = "AUTH_USER")
public class UserDO {@Idprivate Long id;@Column(length = 32)private String name;public Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}
}

 

运行时,系统自动将数据表给我们建好了。

我们要实现一个增加、删除、修改、查询功能的持久层服务,那么我只需要声明一个接口,这个接口继承 org.springframework.data.repository.Repository<T, ID> 接口或者他的子接口就行。这里为了功能的完备,我们继承了 org.springframework.data.jpa.repository.JpaRepository<T, ID> 接口。其中 T 是数据库实体类,ID 是数据库实体类的主键。 然后再简单的在这个接口上增加一个 @Repository 注解就结束了。

@Repository
public interface UserDao extends JpaRepository<UserDAO, id> {
}

UserDO userDO = new UserDO(); userDO.setId(1L); userDO.setName(“风清扬”);

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com