Step 1. Add the JitPack repository to your build file
Add it in your root settings.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
Add it in your settings.gradle.kts at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url = uri("https://jitpack.io") }
}
}
Add to pom.xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.yu000hong:db-compare-plugin:1.0.5'
}
dependencies {
implementation("com.github.yu000hong:db-compare-plugin:1.0.5")
}
<dependency>
<groupId>com.github.yu000hong</groupId>
<artifactId>db-compare-plugin</artifactId>
<version>1.0.5</version>
</dependency>
libraryDependencies += "com.github.yu000hong" % "db-compare-plugin" % "1.0.5"
:dependencies [[com.github.yu000hong/db-compare-plugin "1.0.5"]]
db-compare-plugin is a gradle plugin for database comparison. Because it compares database metadata through JDBC, so it can compare different databases. However, it can only compare the common parts of these databases.
build.gradle
buildscript {
repositories {
mavenCentral()
maven {
url 'https://jitpack.io'
}
}
dependencies {
classpath 'com.github.yu000hong:db-compare-plugin:1.0.5'
classpath 'mysql:mysql-connector-java:5.1.18'
}
}
apply plugin: 'com.github.yu000hong.dbcompare'
dbCompareConfig{
testUrl = 'jdbc:mysql://localhost:3306/test'
testUser = 'root'
testPasswd = 'root'
prodUrl = 'jdbc:mysql://localhost:3306/prod'
prodUser = 'root'
prodPasswd = 'root'
driver = 'com.mysql.jdbc.Driver'
tables = '*'
}
Execute
$> gradle dbCompare
If there is no difference between two databases, then no output. Or, the output will look like as follow:
--------------------------------------------------------------------------
TABLE TEST PROD
--------------------------------------------------------------------------
account - +
--------------------------------------------------------------------------
article - +
--------------------------------------------------------------------------
comment + -
--------------------------------------------------------------------------
message
F:XCID + -
F:COMMENT_ID VARCHAR(30) NOT NULL VARCHAR(30) NULL
I:INDEX_XCID_ARTICLEID - +
--------------------------------------------------------------------------