当前位置:   article > 正文

java连接数据库的操作(2):jpa_java 程序 如何使用jpa连接数据库

java 程序 如何使用jpa连接数据库

什么是jpa

jpa(Java Persistence API) ,Java持久化API是Sun公司在Java EE 5规范中提出的Java持久化接口。旨在规范、简化Java对象的持久化工作。JPA不是一种新的ORM框架,他的出现只是用于规范现有的ORM技术。JPA的主要API都定义在javax.persistence包中。

jpa的主要特征

1. ORM映射元数据,JPA支持XML和JDK 5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中; 
2. JPA的API,用来操作实体对象,执行CRUD操作,框架在后台替我们完成所有的事情,开发者从繁琐的JDBC和SQL代码中解脱出来。 
3. 查询语言,这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言查询数据,避免程序的SQL语句紧密耦合。

demo示例

整个项目是一个maven project


实体类:User.java

  1. package simple.entity;
  2. import java.io.Serializable;
  3. import javax.persistence.Entity;
  4. import javax.persistence.Id;
  5. import javax.persistence.Table;
  6. @Entity
  7. @Table(name = "user")
  8. public class User implements Serializable{
  9. private int id;
  10. private String name;
  11. @Id
  12. public int getId() {
  13. return id;
  14. }
  15. public void setId(int id) {
  16. this.id = id;
  17. }
  18. public String getName() {
  19. return name;
  20. }
  21. public void setName(String name) {
  22. this.name = name;
  23. }
  24. }

dao层:

  1. public interface UserDao {
  2. public void saveUser(User user);
  3. }
  1. public class UserDaoImpl implements UserDao{
  2. @Override
  3. public void saveUser(User user) {
  4. // 对应persistence.xml中的persistence-unit
  5. EntityManagerFactory emf =Persistence.createEntityManagerFactory("demo");
  6. // 得到 EntityManager
  7. EntityManager em = emf.createEntityManager();
  8. em.getTransaction().begin();
  9. em.persist(user);
  10. em.getTransaction().commit();
  11. emf.close();
  12. }
  13. }

service层:

  1. public interface UserService {
  2. public void saveUser(User user);
  3. }
  1. public class UserServiceImpl implements UserService{
  2. private UserDao userDao = new UserDaoImpl();
  3. @Override
  4. public void saveUser(User user) {
  5. userDao.saveUser(user);
  6. }
  7. }

jpa配置文件,默认是在src下面的META-INF下面 persistence.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">
  3. <persistence-unit name="demo" transaction-type="RESOURCE_LOCAL">
  4. <provider>org.hibernate.ejb.HibernatePersistence</provider>
  5. <class>simple.entity.User</class>
  6. <properties>
  7. <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
  8. <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/test"/>
  9. <property name="hibernate.connection.username" value="root"/>
  10. <property name="hibernate.connection.password" value="abc12345"/>
  11. <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
  12. <property name="hibernate.show_sql" value="true"/>
  13. <property name="hibernate.format_sql" value="true"/>
  14. <property name="hibernate.use_sql_comments" value="false"/>
  15. <property name="hibernate.hbm2ddl.auto" value="update"/>
  16. </properties>
  17. </persistence-unit>
  18. </persistence>

测试类:

  1. public class Test {
  2. public static void main(String[] args) {
  3. User user = new User();
  4. user.setId(1);
  5. user.setName("demo");
  6. new UserServiceImpl().saveUser(user);;
  7. }
  8. }
上面就是一个简单利用jpa向数据库中插入数据的demo



声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号