JPA的API认识
EntityManager
他是实体管理的类,可以管理实体(crud),它是轻量级的类,可以频繁的创建和销毁,它是线程不安全,但是在设计,多个线程来访问的时候,尽量保证线程安全,如果没有线程安全,出现事务并发带来的问题;
EntityManager里面有一个一级缓存
EntityTransaction
实体事务对象
现在EntityTransaction–都是本地事务。同一个库里的事务
查询一条数据
jpql写法
select 别名 from 类名
@Column(name=“xx”,length=xx):修改字段名和字段长度(如果该字段已经存在修改将没有效果)
四种策略
ddl数据定义语言
dml数据操作语言
dql数据查询语言
tcl事务控制语言
@Entity:表示这个类就是一个实体
@Id:表示这是一个主键
@GeneratedValue:自增长
@Table(name=“xx”):自定义表名
@Clumn(name=“xx”):自定义字段名
得到ENtityManagerFactory
JPA配置文件
<persistence-unit name="cn.itsource.jpa" transaction-type="RESOURCE_LOCAL">
<properties>
<!-- 必须配置4个连接数据库属性 -->
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver" />
<property name="hibernate.connection.url" value="jdbc:mysql:///jpa" />
<property name="hibernate.connection.username" value="root" />
<property name="hibernate.connection.password" value="admin" />
<!-- 必须配置1个方言属性 -->
<!-- 实现跨数据库关键类 :查询MySQLDialect的getLimitString方法 -->
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
<!-- 可选配置 -->
<!-- 是否自动生成表 ddl数据定义语言 -->
<property name="hibernate.hbm2ddl.auto" value="create" />
<!-- 是否显示sql -->
<property name="hibernate.show_sql" value="true" />
<!-- 格式化sql sql -->
<!-- <property name="hibernate.format_sql" value="true" /> -->
</properties>
</persistence-unit>
maven导入JPA的包
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.itsource</groupId>
<artifactId>jpa-demo</artifactId>
<packaging>pom</packaging>
<version>1.0-SNAPSHOT</version>
<modules>
<module>jpaday01</module>
</modules>
<dependencies>
<!-- hibernate的包 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.3.8.Final</version>
</dependency>
<!-- hibernate对于jpa的支持包 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>4.3.8.Final</version>
</dependency>
<!-- mysql的驱动包 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
<!-- junit的测试包 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
<build>
<finalName>pss</finalName>
<plugins>
<plugin>
<!-- Maven的编译插件-->
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
repositroy 仓库
persistence 持久性
什么是jpa:
java持久层api
它是对象映射框架(ORM)的规范
ORM:对象关系映射(Object Relational Mapping)
hibernate和JPA的关系
JPA:是一种ORM的规范
hibernate:他是ORM实现的一种框架
JPA的优缺点
jdbc优缺点:
jdbc操作数据库底层
jdbc转换对象麻烦
重复性代码比较多
移植数据库比较麻烦
操作数据库的时候如果使用jdbc,可能要写两套代码
jdbc没有缓存(Cach),如果性能上面需要控制的话就需要写缓存的代码
jdbc不是面向对象思维来操作的,他是面向sql的
JPA的优缺点:
面向对象操作,操作对象就相当于操作数据库,比如:entityManager.perisit
移植数据库比较方便,以后如果想换数据库,只需要换一个数据库方言就可以
JPA有缓存,效率高(一级缓存,二级缓存,查询缓存)
不能干预sql的生成
有些优化JPA做不了,比如特别大的数据量的时候,JPA不适合
JPA一般用于中小型项目