Ir al contenido principal

Spring Boot - Migration / Data Source

Implement H2


In this case first will be use H2
  • Add H2 to pom.xml, in the dependencies section.
        <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

        <dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
</dependency>

  • Modify application.properties file adding the following properties:

The files is in scr/main/resources
  • spring.h2.console.enabled=true
  • spring.h2.console.path=/h2

The value in path property is the URL to see H2 database console.
Ex. http://localhost:8080/h2/

Migration

Use Flyway

Add in pom.xaml the dependency

<dependency>
                 <groupId>org.flywaydb</groupId>
                 <artifactId>flyway-core</artifactId>

</dependency>
  • Create the folder in scr/resources
    • db -> 
      • migration

  • Add to the application.properties
    • flyway.baseline-description=true
  • spring.jpa.hibernate.ddl-auto=false;

  • Create file
    • V2_create_db.sql
Always start the file as V2__

Ex.

CREATE TABLE SHIPWRECK(
   ID INT AUTO_INCREMENT,
   NAME VARCHAR(255),
   DESCRIPTION VARCHAR(2000),
   CONDITION VARCHAR(255),
   DEPTH INT,
   LATITUDE DOUBLE,
   LONGITUDE DOUBLE,
   YEAR_DISCOVERED INT

);

Datasource Configuration


Add in application properties:


spring.datasource.url=jdbc:h2:file:~/dasboot
spring.datasource.username=sa
spring.datasource.password=
spring.datasource.driver-class-name=org.h2.Driver

In this case the url is specifying that the db will be stored in a file


Other configurations:

spring.datasource.max-active=10
spring.datasource.max-idle=8
spring.datasource.max-wait=10000
spring.datasource.min-evictable-idle-time-millis=1000
spring.datasource.min-idle=8

spring.datasource.time-between-eviction-runs-millis=1


Datasource for Spring

  • Create a folder for the configuration in
    • scr/main/java
      • <project>
        • config

  • Create a class as <Name>Configuration
  • Add above the class the annotation
    • @Configuration
  • Create a DataSource Bean 
    • @Bean
      @ConfigurationProperties(prefix="spring.datasource")
      @Primary
      public DataSource dataSource(){
      return DataSourceBuilder.create().build();
      }
  • Second Datasource
    • @Bean
      @ConfigurationProperties(prefix="datasource.flyway")
      @Primary
      public DataSource flyWayDataSource(){
      return DataSourceBuilder.create().build();
      }

  • The @Primary annotation is to avoid problems when many datasources are configured
  • The prefix is how is defined in the application.properties






Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...