我正在使用 Eclipse Juno IDE
在 phpMyAdmin 中,我创建了自己的数据库和表。现在使用 JDBC,我输入了一些记录。
接下来,我尝试使用 JPA 实现一些查询,我创建了一个具有相同列的实体,并将 persistence.xml 连接到我的数据库。但是当我运行程序时,它会删除所有记录并在我的数据库中创建一个新的空表(同名)。所以我的问题是:我如何连接到数据库中的现有表但不创建新表。
另一个问题是:我没有给我的表一个主键,因为我的表是关于司机旅行的,所以每个司机可以旅行很多次......所以如果我使用主键,它不会添加关于司机的新数据. 使用 JDBC 它可以正常工作。但是对于 JPA,实体需要一些字段作为主键.. 那么如何在 JPA 中添加关于同一驱动程序的新数据?
持久性文件:
<?xml version="1.0" encoding="UTF-8"?>
<persistence xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">
<persistence-unit transaction-type="RESOURCE_LOCAL" name="MyJPA">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<class>pack.bl.Travels</class>
<properties> <property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider"/>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/drivers"/>
<property name="javax.persistence.jdbc.password" value=""/>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<property name="javax.persistence.jdbc.user" value="root"/>
</properties>
</persistence-unit>
代码:
EntityManagerFactory emf = Persistence.createEntityManagerFactory("MyJPA");
EntityManager em = emf.createEntityManager();
List<Travels> allTravels = em.createQuery("SELECT t FROM travels t",Travels.class).getResultList();
for (Travels s : allTravels)
System.out.println(s.toString());
em.close();