Я пытаюсь полностью отказаться от сопоставления на основе xml и написать то же самое, используя конфигурацию на основе java. Он работал совершенно нормально, пока мне не потребовалось использовать сопоставления сущностей. Может ли кто-нибудь помочь мне с тем, как указать сопоставление спящего режима с помощью конфигурации на основе Java?
Ниже приведен пример XML-конфигурации спящего режима.
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-configuration SYSTEM "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.username">myuser</property>
<property name="hibernate.connection.password">mypassword</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/websystique</property>
<property name="show_sql">true</property>
<property name="format_sql">false</property>
<mapping class="com.myapps.testapps.model.Student"/>
<mapping class="com.myapps.testapps.model.University"/>
</session-factory>
</hibernate-configuration>
Я хочу знать, как указать следующие сопоставления в моем HibernateConfig.java
<mapping class="com.myapps.testapps.model.Student"/>
<mapping class="com.myapps.testapps.model.University"/>
Эквивалентная конфигурация на основе Java (HibernateConfig.java). Я пропускаю свой файл свойств, в котором упоминаются все свойства гибернации.
@Configuration
@EnableTransactionManagement
@ComponentScan({"com.myapps.testapps.config"})
@PropertySource(value = ("classpath:application.properties"))
public class HibernateConfig {
@Autowired
private Environment environment;
@Bean
public LocalSessionFactoryBean sessionFactory(){
System.out.println("-----------------------------sessionfactory--------------------------");
LocalSessionFactoryBean sessionFactory = new LocalSessionFactoryBean();
sessionFactory.setDataSource(dataSource());
sessionFactory.setPackagesToScan(new String[]{"com.myapps.testapps.model"});
sessionFactory.setHibernateProperties(hibernateProperties());
return sessionFactory;
}
@Bean
public DataSource dataSource(){
System.out.println("-----------------------------datasource--------------------------");
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName(environment.getRequiredProperty("jdbc.driverClassName"));
dataSource.setUrl(environment.getRequiredProperty("jdbc.url"));
dataSource.setUsername(environment.getRequiredProperty("jdbc.username"));
dataSource.setPassword(environment.getRequiredProperty("jdbc.password"));
return dataSource;
}
private Properties hibernateProperties(){
System.out.println("-----------------------------properties--------------------------");
Properties properties = new Properties();
properties.put("hibernate.dialect", environment.getRequiredProperty("hibernate.dialect"));
properties.put("hibernate.show_sql", environment.getRequiredProperty("hibernate.show_sql"));
properties.put("hibernate.format_sql", environment.getRequiredProperty("hibernate.format_sql"));
return properties;
}
@Bean
@Autowired
public HibernateTransactionManager transactionManager(SessionFactory s){
System.out.println("-----------------------------transaction manager--------------------------");
HibernateTransactionManager txManager = new HibernateTransactionManager();
txManager.setSessionFactory(s);
return txManager;
}
}
Также я использовал аннотации JPA следующим образом
@Entity
@Table(name = "UNIVERSITY")
public class University {
@Id
@GeneratedValue
@Column(name = "UNIVERSITY_ID")
private long id;
@Column(name = "NAME")
private String name;
@Column(name = "COUNTRY")
private String country;
------------------------
а также
@Entity
@Table(name = "STUDENT")
public class Student {
@Id
@GeneratedValue
@Column(name = "STUDENT_ID")
private long id;
@Column(name = "FIRST_NAME")
private String firstName;
@Column(name = "LAST_NAME")
private String lastName;
@Column(name = "SECTION")
private String section;
@ManyToOne(optional = false)
@JoinColumn(name="UNIVERSITY_ID")
private University university;
----------------------
вместе со связанными методами получения и установки.
В статье я прочитал, что альтернативный способ - указать сопоставленный класс и позволить Hibernate найти документ сопоставления:
Configuration cfg = new Configuration()
.addClass(org.hibernate.auction.Item.class)
.addClass(org.hibernate.auction.Bid.class);
Но я действительно не знаю, как добавить это в мой файл HibernateConfig.java. Если я не ошибаюсь, я предполагаю, что это нужно сделать с помощью sessionFactory. Может кто-нибудь, пожалуйста, помогите мне с этим?
Поскольку в ответах упоминается, что setPackagesToScan() эквивалентен для , я получаю следующую ошибку, когда использовал ассоциации Entity с моим существующим кодом, который уже имеет аннотации setPackagesToScan()
и @Entity
.
Invocation of init method failed; nested exception is org.hibernate.AnnotationException: @OneToOne or @ManyToOne on com.myapps.testapps.model.Student.university references an unknown entity: java.lang.String
@OneToOne
или@ManyToOne
на ........... ссылается на неизвестную сущность: java.lang.String. Не могли бы вы поделиться тем, как вы использовали конфигурацию на основе Java в своем коде? - person eccentricCoder   schedule 14.06.2017