У меня проблема, когда @Table (name = "tableName") игнорируется, а вместо этого используется имя класса.
В приведенном ниже примере он игнорирует tb_users и пытается найти таблицу с именем «user». Почему это происходит?
Изменить: Итак, я предоставил недостаточно информации. Вот мой код:
Entity
@Builder
@Getter
@Setter
@Entity
@Table(name = "tb_users")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id", nullable = false)
private Long id;
@Column(name = "username", length = 127, nullable = false)
private String username;
@Column(name = "password", length = 127, nullable = false)
private String password;
@Column(name = "balance", nullable = false)
private double balance;
}
Конфигурация базы данных
@Configuration
@EnableJpaRepositories("com.uci.bank.repository")
public class DatabaseConfig {
@Value("${database.url}")
String url;
@Value("${database.user}")
String user;
@Value("${database.password}")
String password;
@Value("${database.driver}")
String driver;
@Value("${database.persistenceUnit}")
String persistenceUnit;
@Value("${hibernate.dialect}")
String dialect;
@Value("${hibernate.showSql}")
String showSql;
@Value("${hibernate.formatSql}")
String formatSql;
@Value("${hibernate.hbm2ddl}")
String hbm2ddl;
public String getUrl() {
return url;
}
public String getUser() {
return user;
}
public String getPassword() {
return password;
}
public String getDriver() {
return driver;
}
public String getPersistenceUnit() {
return persistenceUnit;
}
public String getDialect() {
return dialect;
}
public String getShowSql() {
return showSql;
}
public String getFormatSql() {
return formatSql;
}
public String getHbm2ddl() {
return hbm2ddl;
}
@Bean
public org.springframework.jdbc.datasource.DriverManagerDataSource dataSource() {
org.springframework.jdbc.datasource.DriverManagerDataSource ds = new org.springframework.jdbc.datasource.DriverManagerDataSource();
ds.setDriverClassName(this.driver);
ds.setUrl(this.url);
ds.setUsername(this.user);
ds.setPassword(this.password);
return ds;
}
@Bean
public org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean entityManagerFactory() {
org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean entityManagerFactory = new org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean();
entityManagerFactory.setDataSource(this.dataSource());
entityManagerFactory.setPersistenceUnitName(this.persistenceUnit);
entityManagerFactory.setJpaVendorAdapter(new org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter());
Map<String, String> jpaProperties = new HashMap<>();
jpaProperties.put("hibernate.dialect", this.dialect);
jpaProperties.put("hibernate.show_sql", this.showSql);
jpaProperties.put("hibernate.format_sql", this.formatSql);
jpaProperties.put("hibernate.hbm2ddl.auto", this.hbm2ddl);
entityManagerFactory.setJpaPropertyMap(jpaProperties);
return entityManagerFactory;
}
@Bean
public org.springframework.orm.jpa.JpaTransactionManager transactionManager() {
org.springframework.orm.jpa.JpaTransactionManager tm = new org.springframework.orm.jpa.JpaTransactionManager();
tm.setEntityManagerFactory(this.entityManagerFactory().getNativeEntityManagerFactory());
return tm;
}
}
Свойства приложения
database.driver=org.sqlite.JDBC
database.url=jdbc:sqlite:bank.db
database.user=USERNAME
database.password=PASSWORD
database.persistenceUnit=jpaData
hibernate.dialect=com.uci.bank.dialect.SQLiteDialect
hibernate.showSql=true
hibernate.formatSql=true
hibernate.hbm2ddl=validate
Когда я пытаюсь вставить, используя метод сохранения JpaRepository передается пользователю, я получаю следующее сообщение об ошибке:
[SQLITE_ERROR] SQL ошибка или отсутствует база данных (такой таблицы нет: пользователь)
Я использую SQLite и мне пришлось создать диалект:
public class SQLiteIdentityColumnSupport extends IdentityColumnSupportImpl {
@Override
public boolean supportsIdentityColumns() {
return true;
}
@Override
public String getIdentitySelectString(String table, String column, int type) throws MappingException {
return "select last_insert_rowid()";
}
@Override
public String getIdentityColumnString(int type) throws MappingException {
return "integer";
}
}
publi c class SQLiteDialect extends Dialect {
public SQLiteDialect() {
registerColumnType(Types.BIT, "integer");
registerColumnType(Types.TINYINT, "tinyint");
registerColumnType(Types.SMALLINT, "smallint");
registerColumnType(Types.INTEGER, "integer");
registerColumnType(Types.BIGINT, "bigint");
registerColumnType(Types.FLOAT, "float");
registerColumnType(Types.REAL, "real");
registerColumnType(Types.DOUBLE, "double");
registerColumnType(Types.NUMERIC, "numeric");
registerColumnType(Types.DECIMAL, "decimal");
registerColumnType(Types.CHAR, "char");
registerColumnType(Types.VARCHAR, "varchar");
registerColumnType(Types.LONGVARCHAR, "longvarchar");
registerColumnType(Types.DATE, "date");
registerColumnType(Types.TIME, "time");
registerColumnType(Types.TIMESTAMP, "timestamp");
registerColumnType(Types.BINARY, "blob");
registerColumnType(Types.VARBINARY, "blob");
registerColumnType(Types.LONGVARBINARY, "blob");
registerColumnType(Types.BLOB, "blob");
registerColumnType(Types.CLOB, "clob");
registerColumnType(Types.BOOLEAN, "integer");
}
public IdentityColumnSupport getIdentityColumnSupport() {
return new SQLiteIdentityColumnSupport();
}
public boolean hasAlterTable() {
return false;
}
public boolean dropConstraints() {
return false;
}
public String getDropForeignKeyString() {
return "";
}
public String getAddForeignKeyConstraintString(String constraintName, String[] foreignKey, String referencedTable, String[] primaryKey, boolean referencesPrimaryKey) {
return "";
}
public String getAddPrimaryKeyConstraintString(String constraintName) {
return "";
}
public String getForUpdateString() {
return "";
}
public String getAddColumnString() {
return "add column";
}
public boolean supportsOuterJoinForUpdate() {
return false;
}
public boolean supportsIfExistsBeforeTableName() {
return true;
}
public boolean supportsCascadeDelete() {
return false;
}
}