Как создать новую базу данных Oracle с помощью Hibernate - PullRequest
0 голосов
/ 27 мая 2018

Я новичок в hibernate и следую учебному пособию по hibernate в приложении Java EE, вот мой файл persistence.xml:

<persistence xmlns="http://xmlns.jcp.org/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence
             http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd"
             version="2.1">

    <persistence-unit name="punit">

    </persistence-unit>
</persistence>

А вот моя конфигурация hibernate находится в файле с именем jpaContext.xml.

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">

    <bean id="entityManagerFactory"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="persistenceUnitName" value="punit" />
        <property name="dataSource" ref="dataSource" />
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                <property name="showSql" value="true" />
            </bean>
        </property>

        <property name="jpaPropertyMap">
            <map>
                <entry key="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" />
                <entry key="hibernate.hbm2ddl.auto" value="create" />
                <entry key="hibernate.format_sql" value="true" />
            </map>
        </property>
    </bean>

    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory" />
    </bean>
    <tx:annotation-driven transaction-manager="transactionManager" />
    <bean id="dataSource"
        class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
        <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl" />
        <property name="username" value="SYS AS SYSDBA" />
        <property name="password" value="password" />
    </bean>

Проблема, с которой я сталкиваюсь, заключается в том, что, когда я запускаю сервер (впервые), не создается новая база данных, а только таблица для объекта, который есть в моем приложении, в схеме SYS, как выможно увидеть на изображении ниже:

enter image description here

Вот сущность, из которой создана таблица:

package com.pluralsight.model;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Table;
import javax.persistence.Id;

import org.hibernate.validator.constraints.Range;

@Entity
@Table(name="goals")
public class Goal {

    @Id 
    @GeneratedValue
    private Long Id;

    @Range(min = 1, max = 120)
    @Column(name="MINUTES")
    private int minutes;

    public int getMinutes() {
        return minutes;
    }

    public void setMinutes(int minutes) {
        this.minutes = minutes;
    }

    public Long getId() {
        return Id;
    }

    public void setId(Long id) {
        Id = id;
    }

}

В то время как янужно создать новый экземпляр базы данных (если он не существует) для приложения, которое я разрабатываю, и передать его (то же, что приложение, например)

Кто-нибудь знает, как мне этого добиться с помощьюспящий режим?

Ответы [ 2 ]

0 голосов
/ 28 мая 2018

мне нужно создать новый экземпляр базы данных

То, что MySQL называет базой данных, Oracle называет схемой.Но если в MySQL база данных отделена от пользователя и отличается от нее, то в Oracle схема в значительной степени является синонимом пользователя.Настолько эффективно, что пользователь / схема должны быть созданы до запуска вашего приложения (или, по крайней мере, Hibernate SessionFactory).К сожалению, драйвер Oracle JDBC не сделает этого за вас.

Вы можете создать пользователя следующим образом:

create user foobar identified by somepass;

, затем дать ему соответствующие права

grant connect to foobar;
grant create sequence to foobar;
grant create session to foobar;
grant create table to foobar;
grant create trigger to foobar;
grant unlimited tablespace to foobar;
...

тогда приложение может подключиться к базе данных, так как этот пользователь и hibernate смогут создавать таблицы в схеме этого пользователя.

В качестве альтернативы, вы можете просто создать пользователя / схему и продолжить подключение как другоепользователь (например, SYS), но задайте схему по умолчанию в Hibernate:

<property name="hibernate.default_schema" value="foobar"/>

, что обеспечит создание всех таблиц в правильной схеме.

0 голосов
/ 27 мая 2018

Я могу предложить вам одну вещь, хотя я не знаю, сработает ли это или нет.Добавить свойство

<entry key="hibernate.default_schema" value="ABC" /> 

и изменить <entry key="hibernate.hbm2ddl.auto" value="create" />

на

<entry key="hibernate.hbm2ddl.auto" value="update" />.

Вы можете проверить эти ссылки!

пружинная загрузка автоматическиОшибка создания схемы базы данных

https://developer.jboss.org/thread/106922]

https://docs.jboss.org/jbossas/jboss4guide/r2/html/ch13.html

...