【发布时间】:2025-12-19 01:10:11
【问题描述】:
我在这个文件中保留了表架构tableaddress.orm.xml
<?xml version="1.0" encoding="UTF-8"?>
<entity-mappings version="2.1"
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/orm"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<entity class="Address">
<attributes>
<basic name="city" attribute-type="String" />
<basic name="country" attribute-type="int" />
<basic name="province" attribute-type="double" />
<basic name="postalCode" attribute-type="boolean">
</basic>
<basic name="street" attribute-type="String" />
</attributes>
</entity>
</entity-mappings>
这是我尝试使用 Hibernate 创建表的方法
public class App
{
public static void main( String[] args )
{
Properties prop= new Properties();
prop.setProperty("hibernate.connection.url", "jdbc:mariadb:......");
prop.setProperty("dialect", "org.hibernate.dialect.MariaDB53Dialect");
prop.setProperty("hibernate.connection.username", "user");
prop.setProperty("hibernate.connection.password", "password");
prop.setProperty("hibernate.connection.driver_class", "org.mariadb.jdbc.Driver");
SessionFactory sessionFactory = new Configuration()
.addResource("tableaddress.orm.xml").addProperties(prop).buildSessionFactory();
Session session = sessionFactory.openSession();
session.beginTransaction();
session.getTransaction().commit();
session.close();
}
}
它应该可以工作,没有编译错误,但由于某种原因没有创建表
错误java.lang.NoClassDefFoundError: javax/transaction/SystemException
【问题讨论】:
-
你不需要在 hibernate.cfg.xml 中设置 hibernate.hbm2ddl.auto 属性吗?见*.com/questions/4507142/…
-
遇到同样的错误 java.lang.NoClassDefFoundError: javax/transaction/SystemException
标签: java hibernate-5.x