Экспорт объектов в схему базы данных через код java - PullRequest
0 голосов
/ 21 апреля 2020

Долгое время go, я делал это с помощью такого кода:

Configuration config = new Configuration();

Properties props = new Properties();
FileInputStream fos = = new FileInputStream( file_name );
props.load(fos);
fos.close();
config.setProperties(props);

config.addAnnotatedClass(...);

Connection conn = DriverManager.getConnection(url,usuario,senha);
SchemaExport schema = new SchemaExport();
schema.create(true, true);

Но теперь, если я пытаюсь использовать этот код, я получаю ошибку компиляции. Видя javado c для SchemaExport, я замечаю множество изменений в методах, используемых в этом примере.

Hpw Я мог бы сделать это сейчас?

update

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

  public void criarTabelas(String server, String user, String pass) throws Exception {
    StandardServiceRegistry standardRegistry = new StandardServiceRegistryBuilder().applySetting("hibernate.hbm2ddl.auto", "create").applySetting("hibernate.dialect", dialect).applySetting("hibernate.id.new_generator_mappings", "true").build();

    MetadataSources sources = new MetadataSources(standardRegistry);
    for(Class<?> entity : lista_entidades())
      sources.addAnnotatedClass(entity);

    MetadataImplementor metadata = (MetadataImplementor) sources.getMetadataBuilder().build();

    SchemaExport export = new SchemaExport();
    export.create(EnumSet.of(TargetType.DATABASE), metadata);
  }

  private List<Class<?>> lista_entidades() throws Exception {
      List<Class<?>> lista = new ArrayList<Class<?>>();

      ClassPathScanningCandidateComponentProvider scanner = new ClassPathScanningCandidateComponentProvider(false);
      scanner.addIncludeFilter(new AnnotationTypeFilter(Entity.class));
      for (BeanDefinition bd : scanner.findCandidateComponents("org.loja.model"))
        lista.add(Class.forName(bd.getBeanClassName()));

      return lista;
    }

Теперь мне нужен способ установить sh соединение jdb c и связать его с SchemaExport.

1 Ответ

0 голосов
/ 22 апреля 2020

Я решаю эту проблему с помощью этого кода:

  public void criarTabelas(String server, String user, String pass) throws Exception {
    Connection conn = DriverManager.getConnection(url_prefix+server+"/"+url_suffix, user, pass);
    StandardServiceRegistry standardRegistry = new StandardServiceRegistryBuilder()
    .applySetting("hibernate.hbm2ddl.auto", "create")
    .applySetting("hibernate.dialect", dialect)
    .applySetting("hibernate.id.new_generator_mappings", "true")
    .applySetting("javax.persistence.schema-generation-connection", conn)
    .build();

    MetadataSources sources = new MetadataSources(standardRegistry);
    for(Class<?> entity : lista_entidades())
      sources.addAnnotatedClass(entity);

    MetadataImplementor metadata = (MetadataImplementor) sources.getMetadataBuilder().build();

    SchemaExport export = new SchemaExport();
    export.create(EnumSet.of(TargetType.DATABASE), metadata);
    conn.close();
  }

  private List<Class<?>> lista_entidades() throws Exception {
      List<Class<?>> lista = new ArrayList<Class<?>>();

      ClassPathScanningCandidateComponentProvider scanner = new ClassPathScanningCandidateComponentProvider(false);
      scanner.addIncludeFilter(new AnnotationTypeFilter(Entity.class));
      for (BeanDefinition bd : scanner.findCandidateComponents("org.loja.model"))
        lista.add(Class.forName(bd.getBeanClassName()));

      System.out.println("lista: "+lista);
      return lista;
    }
...