Пытаюсь создать своё первое приложение «Библиотека».
В конечном (промежуточном) итоге хочу получить приложение, которое может по rest-api выполнять crud-операции.
С помощью MySQL создал 3 таблицы — Книги, Клиенты, Заказы. Подключил БД к Intellij Idea.
Прописал классы-сущности.
На сколько я понимаю, далее мне нужно проверить, поднимает ли проект БД, а для этого нужно прописать конфиг.
Его я тоже попытался прописать, но не уверен, что это сделал верно.
package config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.JpaVendorAdapter;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;
import javax.persistence.EntityManagerFactory;
import javax.sql.DataSource;
import java.util.Properties;
@Configuration
@EnableTransactionManagement
@ComponentScan("service")
@EnableJpaRepositories(basePackages = "repository")
public class Config {
private static final String URL = "jdbc:mysql://localhost:3306/library_project?serverTimezone=UTC";
private static final String USER = "root";
private static final String PASSWORD = "root";
@Bean
public DataSource dataSource() {
DriverManagerDataSource dataSource = new DriverManagerDataSource(URL, USER, PASSWORD);
dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
return dataSource;
}
private Properties additionalProperties() {
Properties properties = new Properties();
properties.setProperty("hibernate.dialect", "org.hibernate.dialect.MySQL5Dialect");
return properties;
}
@Bean
public LocalContainerEntityManagerFactoryBean entityManagerFactoryBean() {
LocalContainerEntityManagerFactoryBean managerFactoryBean = new LocalContainerEntityManagerFactoryBean();
managerFactoryBean.setDataSource(dataSource());
managerFactoryBean.setPackagesToScan("model");
JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
managerFactoryBean.setJpaVendorAdapter(vendorAdapter);
managerFactoryBean.setJpaProperties(additionalProperties());
return managerFactoryBean;
}
@Bean
public PlatformTransactionManager transactionManager(EntityManagerFactory emf) {
JpaTransactionManager transactionManager = new JpaTransactionManager();
transactionManager.setEntityManagerFactory(emf);
return transactionManager;
}
@Bean
public PersistenceExceptionTranslationPostProcessor exceptionTranslation() {
return new PersistenceExceptionTranslationPostProcessor();
}
}
Также остаётся загадкой, как запустить проект, чтобы проверить работоспособность хоть чего-нибудь, ведь Main с psvm-ом здесь быть не должно, если я верно всё понимаю. Подскажите, пожалуйста, какие шаги мне следует предпринять, для дальнейшего написания приложения и где должна находиться точка входа в приложение?