JPA

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一般用于中小型项目
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值