diff --git a/.gitignore b/.gitignore index 05cec9c..6dd4cc3 100644 --- a/.gitignore +++ b/.gitignore @@ -80,4 +80,4 @@ crashlytics.properties crashlytics-build.properties fabric.properties .idea/httpRequests -.idea/caches/build_file_checksums.ser +.idea/caches/build_file_checksums.ser \ No newline at end of file diff --git a/.gitignore-back b/.gitignore-back new file mode 100644 index 0000000..05cec9c --- /dev/null +++ b/.gitignore-back @@ -0,0 +1,83 @@ +HELP.md +target/ +!.mvn/wrapper/maven-wrapper.jar +!**/src/main/**/target/ +!**/src/test/**/target/ + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + +### NetBeans ### +/nbproject/private/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ +build/ +!**/src/main/**/build/ +!**/src/test/**/build/ + +### VS Code ### +.vscode/ +target/ +pom.xml.tag +pom.xml.releaseBackup +pom.xml.versionsBackup +pom.xml.next +release.properties +dependency-reduced-pom.xml +buildNumber.properties +.mvn/timing.properties +.mvn/wrapper/maven-wrapper.jar +*.class +*.log +*.ctxt +.mtj.tmp/ +*.jar +*.war +*.nar +*.ear +*.zip +*.tar.gz +*.rar +hs_err_pid* +.idea/**/workspace.xml +.idea/**/tasks.xml +.idea/**/usage.statistics.xml +.idea/**/dictionaries +.idea/**/shelf +.idea/**/contentModel.xml +.idea/**/dataSources/ +.idea/**/dataSources.ids +.idea/**/dataSources.local.xml +.idea/**/sqlDataSources.xml +.idea/**/dynamic.xml +.idea/**/uiDesigner.xml +.idea/**/dbnavigator.xml +.idea/**/gradle.xml +.idea/**/libraries +cmake-build-*/ +.idea/**/mongoSettings.xml +*.iws +out/ +.idea_modules/ +atlassian-ide-plugin.xml +.idea/replstate.xml +com_crashlytics_export_strings.xml +crashlytics.properties +crashlytics-build.properties +fabric.properties +.idea/httpRequests +.idea/caches/build_file_checksums.ser diff --git a/.gitignore-tree b/.gitignore-tree new file mode 100644 index 0000000..e790b31 --- /dev/null +++ b/.gitignore-tree @@ -0,0 +1,10 @@ +src +liquibase-4.9.1/*.txt +liquibase-4.9.1/examples +liquibase-4.9.1/licenses +liquibase-4.9.1/lib/liquibase_autocomplete.sh +liquibase-4.9.1/lib/liquibase_autocomplete_mac.bash +liquibase.iml +mvnw +mvnw.cmd +pom.xml \ No newline at end of file diff --git a/README.md b/README.md new file mode 100644 index 0000000..ee5d415 --- /dev/null +++ b/README.md @@ -0,0 +1,5 @@ +# Liquibase Example + +Это демо проект для моей статье об использовании Liquibase в качестве системы миграции БД. + +https://struchkov.dev/blog/get-started-liquibase \ No newline at end of file diff --git a/docker.sh b/docker.sh new file mode 100644 index 0000000..ab7c350 --- /dev/null +++ b/docker.sh @@ -0,0 +1,3 @@ +#!/bin/sh +docker run --name liquibase --network host -v YOUR_PATH_TO_db/changelog:/liquibase/db/changelog liquibase/liquibase:4.9.1 --defaultsFile=/liquibase/db/changelog/liquibase.properties update +docker rm liquibase \ No newline at end of file diff --git a/liquibase-4.9.1/ABOUT.txt b/liquibase-4.9.1/ABOUT.txt new file mode 100644 index 0000000..ed52948 --- /dev/null +++ b/liquibase-4.9.1/ABOUT.txt @@ -0,0 +1 @@ +LIQUIBASE is a registered trademark of Liquibase. diff --git a/liquibase-4.9.1/GETTING_STARTED.txt b/liquibase-4.9.1/GETTING_STARTED.txt new file mode 100644 index 0000000..0e0e345 --- /dev/null +++ b/liquibase-4.9.1/GETTING_STARTED.txt @@ -0,0 +1,258 @@ +Liquibase Version 4.9.1 + + +Getting Started +-------------------------------------------- +Thanks for downloading and installing Liquibase 4.9.1 from Liquibase. + +By using the installer, you already have all the dependencies, directories, config, +and properties files to get started exploring the Liquibase examples provided, which +is a great way to understand the core concepts with a direct command-line introductory +experience. + + +Adding Liquibase to Your Path +-------------------------------------------- +If you do not want always to provide an absolute path to the liquibase command, +add `/path/to/installed/liquibase` to your PATH. If you selected this option +during the installation process, this should have been done for you. + + +EXAMPLE PROJECTS +-------------------------------------------- +This installation contains an "examples" directory, which includes everything +required to use Liquibase against a sample in-memory database. + +There are two projects under the examples directory: + * "examples/sql" directory shows how to use a SQL formatted changelog + * "examples/xml" directory shows how to use an XML formatted changelog + +Both projects utilize the same setup & examples and only differ in the changelog type. + + +Setting Up Your Workspace +------------------------- +Copy the "examples" directory to another location on your machine. + * Installed location: "/liquibase/examples" + * Example new location: "/apps/liquibase-projects/examples" + +What got copied? + +In both ".../examples/sql" and "example/xml" there is a liquibase.properties file, +which provides default values that allow you to run command-line (CLI) commands +immediately with Liquibase. This file is pre-configured to point to the changelog +you copied and the `start-h2` developer database. + +In both ".../examples/sql" and "example/xml" there is a sample changelogfile. + +While not required, it is a best practice to keep your changelogs in a unique and +descriptive directory structure. Changelogs are normally stored in your version +control system along with your application code and match the directory structures +you use there. + + +Configuring your liquibase.properties file +-------------------------------------------- +*** NOTE: You do not need to change any settings to be able to run liquibase examples *** + +In your command line or Terminal app, navigate to the sql or xml sub-directory in +the example directory to examine your pre-configured liquibase.properties files. + +The liquibase.properties file stores properties which rarely change, such as +database connection information. Properties stored here save time and reduce the +risk of mistyped command line arguments. Any parameter that could be specified on +the command line can also be specified in the properties file. If a parameter is +specified in both the properties file and the command line, the command line value +will override the value in the file. + +Learn more: https://www.liquibase.org/documentation/config_properties.html + + +Starting the Example H2 Database +-------------------------------------------- +USING H2 + +H2 is a standard SQL database and can be used to simulate working in a more +complex database. + +To start the example database: + * open your command line or Terminal app + * navigate to the directory where you placed "examples" directory + * run `examples/start-h2`. + +To stop the example database: + * run `ctrl-c' in the terminal running examples/start-h2 + +Notes + +Running `examples/start-h2` starts local H2 databases that listen on port 9090, and +it opens a browser to the database console on the same port. + * The Example h2 databases do not store data and will reset when the start-h2 + process ends via "ctrl-c". + +The start-h2 script starts two databases: + 1. A Developer Database: Corresponds to what you may use as a local database. + 2. An Integration Database: Corresponds to another database in your pipeline. + +About the console: + * The web-based console allows you to see all objects in your database in the + left navigation and run SQL statements on the right side. + * Along the top is a toolbar that includes a Refresh button which can be used + to reload the left-side object view if changes are made to your database + outside of the console (like with Liquibase). + * The Integration database can be viewed with the link provided to you from + the Developer database browser. You can also see which database you are + connected to by looking at the URL at the top of the object view. + * As a test, try entering `create table test_table (id int)` in the text area + and hit "Run". After, you should see "TEST_TABLE" appear in the object view. + +NOTE: If you run formatted SQL or XML on the H2 database, and then want to attempt +using the other method, you must restart the H2 database before running it again +or you will receive an update failure due to objects already existing on the database. + + +Running Your First Update +------------------------- +The main Liquibase command you will use is "update", which applies any changes not +yet run in your changelog to your database. + +First, +1. Open a different command-line or Terminal app. +2. Navigate to your ...examples/sql directory (or xml) + + +To run the update command: +1. In your command prompt run: `liquibase update` + +You should see a message saying: "Update has been successful." + +2. Refresh your developer database console page. + +You should now see the following tables added to the object view: + - COMPANY + - DATABASECHANGELOG + - DATABASECHANGELOGLOCK + - PERSON + +By running `liquibase update`, your database now matches the desired database state +as defined by the changelog script. + +The DATABASECHANGELOG and DATABASECHANGELOGLOCK tables are liquibase-metadata tables. +Also, the changelog created the COMPANY and PERSON tables. + +Now, open the sample.changelog.xml or samplechangelog.h2.sql file in your favorite +text editor. + +In each file, you can see how changes were defined as a series of changeSets. Each +changeSet is uniquely identified by the "id" and "author" fields. Liquibase uses +these fields to track what changes have been run and what has not. + +When you ran the "update" command, Liquibase evaluated which changeSets had not +been run against your target database, then ran them. + + +Adding New ChangeSets +--------------------- +Running the update command allowed your developer database to match the defined +state. Now that they match, you can start adding additional changes you need. If +you have not run your first update, please follow the instructions in the previous +section before completing this section. + +In this example, we will add a new changeSet to create a "works for" column in the +persons table with a foreign key to the company table. + +To add this changeSet, open the sample changelog file in your existing editor, and +copy + paste one of the following changeSet examples: + + XML changelog example code + --------------------------- + + + + + + + + + + SQL changelog example code + --------------------------- +--changeset your.name:4 +ALTER TABLE person ADD worksfor_company_id INT; +--changeset your.name:5 +ALTER TABLE person ADD CONSTRAINT fk_person_worksfor FOREIGN KEY (worksfor_company_id) REFERENCES company(id); + + +NOTE: It's best practice to wrap every statement in its own changeSet block. + +Now, run `liquibase update` again & refresh your database console. + +You will see the new column on the person table and the new constraint. + +NOTE: If you run formatted SQL or XML on the H2 database, then want to attempt using +the other method, you must restart the H2 database before running it again or you +will receive an update failure due to objects already existing on the database. + + +Promoting Changes +----------------- +Now that we added a new changeSet and the database structure is what we want, we +are ready to apply those changes to our integration database. + +At this time in the workflow, you should commit your changelog to version control +and/or build an artifact containing it. However, for this tutorial, we will run +it directly against our other database. + +To apply the changes to the integration database run: +`liquibase --url=jdbc:h2:tcp://localhost:9090/mem:integration update` + +By passing the --url parameter, you override the URL value specified in the +liquibase.properties file, but still use all the other parameters in the file. + +After running "update" against the integration database, you should now see the +COMPANY and PERSON tables in your integration web console. + + +Standard Development Workflow +----------------------------- +For more information on the Standard Development Workflow you just completed, see: +https://www.liquibase.org/documentation/workflows/lb-developer-workflow.html + + +Next Steps +---------- +Now that you have a feel for Liquibase against your sample database, you can try +it against your standard databases. + +Just add your database's jdbc drivers to the "lib" directory in the Liquibase +install directory and update the URL, username, and password in the +liquibase.properties file. + +Also, check the documentation associated with your specific database to locate +the correct url format and download the driver jar. Then use the Standard +Development Workflow to make changes against your database. + + +Help & Support +---------------------------------------- +For questions regarding Liquibase, you can submit an email to support@liquibase.org +or submit a post on stack overflow and use the #liquibase tag here: +https://stackoverflow.com/questions/tagged/liquibase + +You can also post questions to these Liquibase forums: +Liquibase User Forum: https://forum.liquibase.org/#Forum/liquibase-users +Liquibase Developer Forum: https://forum.liquibase.org/#Forum/liquibase-development. + +Liquibase Documentation: www.liquibase.org/documentation/index.html + +Need Liquibase Support? Get customer support by upgrading to Liquibase Pro here: +https://support.liquibase.org/ + + +Copyright 2021 Liquibase, Inc. All rights reserved. The program is subject to the +license agreement, copyright, trademark, patent, and other laws. diff --git a/liquibase-4.9.1/LICENSE.txt b/liquibase-4.9.1/LICENSE.txt new file mode 100644 index 0000000..d645695 --- /dev/null +++ b/liquibase-4.9.1/LICENSE.txt @@ -0,0 +1,202 @@ + + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/liquibase-4.9.1/README.txt b/liquibase-4.9.1/README.txt new file mode 100644 index 0000000..b1da230 --- /dev/null +++ b/liquibase-4.9.1/README.txt @@ -0,0 +1,81 @@ +Liquibase Version 4.9.1 + +Introduction +-------------------------------------------- +Thanks for downloading and installing Liquibase 4.9.1 from Liquibase. +By using the installer, you already have all the dependencies, directories, config, +and properties files to get started exploring the Liquibase examples provided. + +This is a great way to understand the core concepts with direct command-line experience. + + +What was Installed +-------------------------------------------- +The default install location on Windows is "\Program Files\liquibase" + +The default install location on Mac is "/usr/local/opt/liquibase" + +The following software was installed: + * Liquibase ( http://liquibase.org ) + * H2 Database ( https://www.h2database.com ) + * AdoptOpenJDK 13 ( https://adoptopenjdk.net ) + +This installer creates the following directories: + * liquibase/lib + * liquibase/licenses + * liquibase/jre + * liquibase/examples/sql + * liquibase/examples/xml + +**NOTE: JRE Install location for mac users is: liquibase/.install4j/jre.bundle/Contents/Home/bin/java** + +Files are: + * liquibase/ABOUT.txt + * liquibase/LICENSE.txt + * liquibase/liquibase.sh + * liquibase/liquibase.bat + * liquibase/liquibase.jar + * liquibase/README.txt + * liquibase/GETTING_STARTED.txt + * liquibase/examples/start-h2 + * liquibase/examples/start-h2.bat + +H2 Database Program +---------------------------------------- +As Liquibase ships with an h2 database example, the h2 jdbc driver was placed into +your chosen installation directory. + +For information on using and configuring the h2 database see: +https://www.liquibase.org/documentation/tutorials/h2.html + + +Open JDK +---------------------------------------- +We placed AdoptOpenJDK ( https://adoptopenjdk.net ) in your chosen installation +directory. + +All AdoptOpenJDK binaries and scripts are open-source licensed and available for +free. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or +its affiliates. Other names may be trademarks of their respective owners. + + +Help & Support +---------------------------------------- +For questions regarding Liquibase, you can submit an email to support@liquibase.org +or submit a post on stack overflow and use the #liquibase tag: +https://stackoverflow.com/questions/tagged/liquibase + +You can also post questions to these Liquibase forums: +Liquibase User Forum: https://forum.liquibase.org/#Forum/liquibase-users +Liquibase Developer Forum: https://forum.liquibase.org/#Forum/liquibase-development + +Liquibase Documentation: http://liquibase.org/documentation + +Need Liquibase Support? Get customer support by upgrading to Liquibase Pro here: https://support.liquibase.org + + +---------------------------------------- +The program is subject to the license agreement, copyright, trademark, patent, and other laws. +Copyright 2021 Liquibase, Inc. All rights reserved. + + diff --git a/liquibase-4.9.1/UNINSTALL.txt b/liquibase-4.9.1/UNINSTALL.txt new file mode 100644 index 0000000..13b93c9 --- /dev/null +++ b/liquibase-4.9.1/UNINSTALL.txt @@ -0,0 +1,17 @@ + +Uninstalling Liquibase +-------------------------------------------- +To uninstall Liquibase, delete the directory where it was installed. +If you used the installer you can also use the uninstall.exe (Windows) or Liquibase Uninstaller (Mac) to remove these files. + +Help & Support +---------------------------------------- +For questions regarding Liquibase, you can submit an email to answers@liquibase.org or submit a post on stack overflow and use the #liquibase tag: https://stackoverflow.com/questions/tagged/liquibase + +You can also post questions to these Liquibase forums: +Liquibase User Forum: https://forum.liquibase.org/#Forum/liquibase-users +Liquibase Developer Forum: https://forum.liquibase.org/#Forum/liquibase-development. + +Liquibase Documentation: http://liquibase.org/documentation + +Need Liquibase Support? Get customer support by upgrading to Liquibase Pro here: https://support.liquibase.org/ diff --git a/liquibase-4.9.1/changelog.txt b/liquibase-4.9.1/changelog.txt new file mode 100644 index 0000000..55e93cf --- /dev/null +++ b/liquibase-4.9.1/changelog.txt @@ -0,0 +1,2406 @@ +Liquibase Core Changelog +=========================================== + +Changes in version 4.9.1 (2022.03.25) + +## Liquibase 4.9.1 patch release +Please report any issues to [https://github.com/liquibase/liquibase/issues](https://github.com/liquibase/liquibase/issues). + +## Notable Changes + +[[PR#2666](https://github.com/liquibase/liquibase/pull/2666)] [[nvoxland](https://github.com/nvoxland)] Liquibase 4.9.1 release is a patch release that fixes the `MANIFEST.MF` location in the `liquibase.jar` file for tools that require the `MANIFEST.MF` file to be the first entry in the jar archive. +If the `MANIFEST.MF` file is not the first entry, `java.util.jar.JarInputStream#getManifest()` reading the `MANIFEST.MF` file will not return the manifest information appropriately. The PR fixes issue [#2648](https://github.com/liquibase/liquibase/issues/2648). + +[[Issue#2672](https://github.com/liquibase/liquibase/issues/2672)] Addresses the remaining OSGi-related packaging problems to fully restore Liquibase support in OSGi environments. + +## Fixes +[[PR#2651](https://github.com/liquibase/liquibase/pull/2651)] Fixed the issue with a malicious software alert for the Liquibase macOS Installer preventing from proceeding with the installation. [DAT-9524] + +[[PR#2643](https://github.com/liquibase/liquibase/pull/2643)] Fixed an issue in snapshot on PostgreSQL where non-integer datatypes that used a default value with a sequence would not be handled correctly [DAT-8670] + +Changes in version 4.9.0 (2022.03.17) + +# Notable Changes + +Liquibase 4.9.0 introduces the following functionality: +- [PRO] Quality checks output in a JSON format +- Quality checks for Maven - `checks run` and `checks show` goals +- [PR#2558] [kavya-shastri] The extension of the usage of the Liquibase global configuration for the `secureParsing` parameter to prevent the entity resolver from falling back to looking on the network for missing XSDs. If you reference an XSD other than one of Liquibase, Liquibase will no longer automatically download the XSD from the internet and use it. The default value for `secureParsing` is `true`, but you can override it in any of the Liquibase configuration locations. For more information, see the Example Changelogs: XML Format documentation. +- [PR#2529] [Krzysztof Sierszeń] [LB-1781] The `uniqueConstraintExists` precondition to check for the existence of unique constraints before running the update. You can check the constraint by constraint name or columns: + + + + + + +- [PR#2339] [[nvoxland] [Toukite] The support for running the Liquibase Servlet listener in application servers built on the Jakarta Servlet specification and not the Java Servlet specification. To use the new listener, specify the following tag: + + liquibase.integration.servlet.LiquibaseJakartaServletListener + +The PR fixes issue #2298. +## Enhancements +- [PR#2434] [Balázs Dési] Added the Maven `validate` goal to `maven-liquibase-plugin` to provide access to the existing Liquibase `validate` command and be available not only in CLI, but also in Maven +- Added the ability to use `sqlcmd` on an instance with multiple databases +For more information, see the Using the SQLCMD integration and runWith attribute with Liquibase Pro and MSSQL Server documentation. +- Added support for Liquibase, Spring Boot, and SQL Plus run with Kerberos +- [PR#2561] [Wesley Willard] Added the `--schemas` argument to the `snapshot` command to be able to compare a multi-schema database to its snapshot +- [PR#2606] [Wesley Willard] Added a best practice message for the `generate-changelog` command so that you can check if the `splitStatements` attribute works for your environment when generating formatted SQL changelogs [DAT-9327] +- Added the `StripComments` attribute for the `SQLUserDefinedPatternCheck` quality check to choose the code that the `SQLUserDefinedPatternCheck` searches, including the option for the commented code. The `StripComments` attribute strips comments from SQL before searching for the string. The default value is `N` (no). [DAT-9098] +- [PR#2273] [Tsvi Zandany] Added the autocomplete option for quality checks commands running on macOS +## Fixes +- [PR#2542] [nvoxland] Fixed the `--should-snapshot-data` CLI parameter to be preserved when the `--data-output-directory` property is not specified in the command +- [PR#2330] [Inane Mohammed] Fixed the issue with checking the `referenceSnapshot` parameter instead of `referenceDatabase` for the potential null value +- [PR#2521] [Steven Massaro] Added a label, context, and comment to the `example-changelog.sql` file that comes with the Liquibase installation package +- [PR#2556] [nvoxland] Fixed the CockroachDB processes so that Liquibase checks the URL first rather than proceeding with SQL calls +- [PR#2569] [Clarence Dimitri CHARLES] Made `FormattedSqlChangeLogParser` to be reusable for extensions +- [PR#2377] [devorgpl] Fixed the issue with updating statements when the `onlyUpdate` attribute is `false` in the `loadUpdateData` Change Type for HSQL +- [PR#1908] [Emiliano Capoccia] Fixed the issue with retrieving the CockroachDB version. As part of the fix, Liquibase generates version-specific autoincrement SQL statements for CockroachDB identity columns: + - `SMALLSERIAL`, `SERIAL`, and `BIGSERIAL` for versions earlier than 21.2 + - `GENERATED BY DEFAULT AS IDENTITY` for version 21.2 or later +- [PR#2135] [PR#2133] [Saucistophe] [mkobylarz] Fixed the issue with the `endDelimiter` attribute not being respected during the Liquibase update. The fix for `endDelimiter` does not break the handling of trailing comments in SQL statements. [LB-2186] +- [PR#2573] [nvoxland] Fixed the quoting for the MANIFEST.MF file for correct versioning +- [PR#2572] [Steven Massaro] Fixed the issue with generating changelogs for PostgreSQL columns that use `SET DEFAULT` +- [PR#2589] [nvoxland] [Marcel Blonk] Fixed the MD5 checksums generated by older versions of Liquibase to be correctly updated in the DATABASECHANGELOG table when a more recent version of Liquibase executes against the database. The PR fixes issue #2580. +- [PR#2592] [nvoxland] Added support for the double precision type in MySQL. The PR fixes issue #2337. +- [PR#1894] [KushnirykOleh] Fixed the time data type to be precise for PostgreSQL. The PR fixes issue #1774. +- [PR#2387] [Jenson3210] Fixed the handling of date and time in the `loadData` Change Type +- [PR#2566] [nvoxland] Updated OpenCSV from 5.5.2 to 5.6 + + +Changes in version 4.8.0 (2022.02.23) + +Notable Changes + +Liquibase 4.8.0 introduces a built-in SQLCMD integration that allows you to specify the runwith paramter sqlcmd custom executor to process +complex SQL for MSSQL Server. Liquibase provides the liquibase.sqlcmd.conf file to pass arguments to your executor when running Liquibase Pro. + +For new and existing Liquibase Hub users, Liquibase 4.8.0 introduces the init hub command, used in Hub’s Getting Started on-boarding. +Users can get defaults and changelog files setup, working, and registered to Hub with just this one command. + +Enhancements +- Implemented the SimpleObjectConstructor interface for DB2 on z/OS [DAT-8580] +- Implemented the init hub command to complete Liquibase Hub onboarding +- Included the CLI instructions on how to use the properties file with a nonstandard name when running the init project subcommand [DAT-9041] +- Added to init start-h2 a clearer message when the H2 database driver is specified, but there is no connection detected. [DAT-8992] +- Added validation errors for the enableCheckConstraint, disableCheckConstraint, dropPackage, dropPackageBody Change Types [DAT-9017] +- [PR#2367] [Mike Olivas] Added example rollback scripts to the example-changelog.sql file [LB-2220] +- [PR#1648] [Daniel Gray] Improved the exception error message for the customChange node with no class attribute [LB-1144] +- [PR#2222] [msimko81] Added the offline mode support for the rollback-sql operation [LB-2198] + +Fixes + +- Fixed the renameSequence Change Type generating an uppercase SQL instead of lowercase and causing failures with case-sensitive databases [LB-1763 +- Fixed the generate-changelog and diff commands to show and generate a proper SQL with autoincrement for PostgreSQL [DAT-8779] +- [PR#1320] [Anatoly S] Fixed the issue with the generated SQL incorrectly displaying the numero sign (No) [LB-562] +- [PR#2139] [wziebicki] Improved the UniqueConstraintSnapshotGenerator class to add a table name to the Oracle database query so that the cache key can contain it, and the unique constraint can be read from cache [LB-2206] +- [PR#2335] [erzsebet] Removed duplicated DATABASECHANGELOGLOCK SQL statements when running the update-sql command against a new database [LB-2208] +- [PR#1894] [KushnirykOleh] Made the time data type precise for PostgreSQL [LB-1798]•[PR#2190] [Richard Bradley] [Hannu Hartikainen] [VlasyukA] [Nathan Voxland] Fixed the issue with locking database if no changelogs are needed to run and no updates are pending. The services can proceed in parallel. [LB-2203] +- New Test System management by @nvoxland in https://github.com/liquibase/liquibase/pull/2312 +- Remove duplicate databasechangeloglock SQL when running update-sql against a new database by @nvoxland in https://github.com/liquibase/liquibase/pull/2335 +- UniqueConstraintSnapshotGenerator - Add table name to OracleDB query by @wziebicki in https://github.com/liquibase/liquibase/pull/2139 +- CORE-3326 Numero sign is a symbol in Russian by @tolix in https://github.com/liquibase/liquibase/pull/1320 +- Allow a custom executor to be specified through a property on existing Executor implementations DAT-7531 by @wwillard7800 in https://github.com/liquibase/liquibase/pull/2374 +- Make ClassLoaderResourceAccessor implement Closable by @Delir4um in https://github.com/liquibase/liquibase/pull/2308 +- Liquibase Responsible Disclosure Policy by @kristyldatical in https://github.com/liquibase/liquibase/pull/2435 +- use lowercase sp_rename function in MSSQL (LB-1763) by @StevenMassaro in https://github.com/liquibase/liquibase/pull/2366 +- Added example rollback scripts by @molivasdat in https://github.com/liquibase/liquibase/pull/2367 +- Bump junit from 4.12 to 4.13.1 in /liquibase-extension-testing by @dependabot in https://github.com/liquibase/liquibase/pull/1827 +- Bump maven-surefire-plugin from 2.22.1 to 2.22.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2427 +- Bump testcontainers-bom from 1.16.2 to 1.16.3 by @dependabot in https://github.com/liquibase/liquibase/pull/2467 +- Bump mockito-core from 3.3.3 to 3.12.4 by @dependabot in https://github.com/liquibase/liquibase/pull/2470 +- Bump maven-jar-plugin from 3.1.1 to 3.2.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2458 +- Bump mockito-inline from 3.8.0 to 3.12.4 by @dependabot in https://github.com/liquibase/liquibase/pull/2465 +- Bump surefire-junit4 from 2.22.1 to 2.22.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2466 +- Bump objenesis from 2.1 to 2.6 by @dependabot in https://github.com/liquibase/liquibase/pull/2468 +- Bump slf4j-jdk14 from 1.7.33 to 1.7.35 by @dependabot in https://github.com/liquibase/liquibase/pull/2475 +- Bump assertj-core from 3.13.2 to 3.22.0 by @dependabot in https://github.com/liquibase/liquibase/pull/2474 +- Bump maven-resources-plugin from 3.0.2 to 3.2.0 by @dependabot in https://github.com/liquibase/liquibase/pull/2473 +- Bump maven-verifier from 1.6 to 1.7.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2472 +- Added new Quality Checks command and subcommands (Mac specifict) by @szandany in https://github.com/liquibase/liquibase/pull/2273 +- Don't repackage all org.apache.- classes. by @nvoxland in https://github.com/liquibase/liquibase/pull/2429 +- Log exceptions in CDILiquibase before rethrowing them by @nvoxland in https://github.com/liquibase/liquibase/pull/2397 +- Bump maven-assembly-plugin from 3.1.1 to 3.3.0 by @dependabot in https://github.com/liquibase/liquibase/pull/2499 +- Bump flatten-maven-plugin from 1.1.0 to 1.2.7 by @dependabot in https://github.com/liquibase/liquibase/pull/2495 +- Bump gmavenplus-plugin from 1.6.2 to 1.13.1 by @dependabot in https://github.com/liquibase/liquibase/pull/2491 +- Bump sonar-maven-plugin from 3.7.0.1746 to 3.9.1.2184 by @dependabot in https://github.com/liquibase/liquibase/pull/2490 +- Bump robinraju/release-downloader from 1.2 to 1.3 by @dependabot in https://github.com/liquibase/liquibase/pull/2405 +- Bump maven-plugin-plugin from 3.6.0 to 3.6.4 by @dependabot in https://github.com/liquibase/liquibase/pull/2497 +- Bump maven-bundle-plugin from 5.1.2 to 5.1.4 by @dependabot in https://github.com/liquibase/liquibase/pull/2494 +- [Snyk] Security upgrade com.h2database:h2 from 2.0.206 to 2.1.210 by @snyk-bot in https://github.com/liquibase/liquibase/pull/2392 +- Enable FEATURE_SECURE_PROCESSING XML setting by default by @nvoxland in https://github.com/liquibase/liquibase/pull/2384 +- Correctly set Bundle-Version in META-INF on release by @nvoxland in https://github.com/liquibase/liquibase/pull/2505 +- Bump ant from 1.9.15 to 1.10.9 in /liquibase-core by @dependabot in https://github.com/liquibase/liquibase/pull/1808 +- Bump postgresql from 42.2.12 to 42.3.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2459 +- Use path instead of absolutePath for resources by @liefke in https://github.com/liquibase/liquibase/pull/2122 +- Bump junit from 4.12 to 4.13.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2411 +- Bump slf4j-jdk14 from 1.7.35 to 1.7.36 by @dependabot in https://github.com/liquibase/liquibase/pull/2506 +- Added additional unicode letter points by @nvoxland in https://github.com/liquibase/liquibase/pull/2329 +- Escape schema/tablenames in metadata.getTables() by @nvoxland in https://github.com/liquibase/liquibase/pull/2398 +- Add offline mode support for rollbackSQL by @msimko81 in https://github.com/liquibase/liquibase/pull/2222 +- Avoid NullPointerException when customChange has no "class" attribute by @danielthegray in https://github.com/liquibase/liquibase/pull/1648 +- Support adding computed=true columns with no type set by @nvoxland in https://github.com/liquibase/liquibase/pull/2340 +- Bump maven-javadoc-plugin from 3.3.1 to 3.3.2 by @dependabot in https://github.com/liquibase/liquibase/pull/2525 +- DAT-9218 Added limited permission user for SQLPLUS integration tests by @wwillard7800 in https://github.com/liquibase/liquibase/pull/2480 +- instruct surefire to read files with UTF-8 encoding by @StevenMassaro in https://github.com/liquibase/liquibase/pull/2541 +- Bump mysql-connector-java from 6.0.6 to 8.0.28 by @dependabot in https://github.com/liquibase/liquibase/pull/2419 +- Reworked license not found message by @suryaaki2 in https://github.com/liquibase/liquibase/pull/2371 +- Fix for Github issue dealing with duplicate property keys by @wwillard7800 in https://github.com/liquibase/liquibase/pull/2351 +- Use "GENERATED BY DEFAULT AS IDENTITY" for h2 2.0+ by @nvoxland in https://github.com/liquibase/liquibase/pull/2372 +- MSSQL: Throw validation error if "ordered" is specified in createSequence/alterSequence by @nvoxland in https://github.com/liquibase/liquibase/pull/2549 +- init hub command by @StevenMassaro in https://github.com/liquibase/liquibase/pull/2326 [DAT-8615] + +Changes in version 4.7.1 (2022.01.21) + +- Fix bug which makes Liquibase misidentify your database dialect if the string 'edb' is in your connection url. (#2364) +- Output changeset execution to UI like rollback does (#1932) +- Support MaxDB for sequences (#932) +- Include columnDataType in generated setColumnRemarks changesets (#2188) +- Use database time for changeloglock table (#2217) +- Mysql: support additional information "double" datatypes (#2293) +- Correctly handle old "liquibase tagExists myTag" style CLI structure (#2269) +- Correctly handle cacheSize in mariadb (#2270) +- Mark liquibase-maven-plugin logging configuration as deprecated (#2261) +- Added validation errors for SQLite and DB2z databases (#2359) + +Changes in version 4.7.0 (2022.01.07) + +Liquibase 4.7.0 introduces the init command with the project subcommand, which helps to build the necessary +configuration files for using Liquibase or, if you already use Liquibase, create new project files with minimal input.[DAT-8640] + +Additionally, we have updated the Liquibase Getting Started tutorials and sample changelog files in the installation package. +From now on, you can use sample SQL, XML, JSON, and YAML changelog files with the corresponding changesets. + +Enhancements +- [PRO] Improved the output of the rollback-one-update command +- [PR#2244] [szandany] Enabled the use of the jdbc:edb URL for Liquibase to recognize EnterpriseDB +- [PR#2225] [nvoxland] [catholic-indulgence-vaper] Enabled the use of lowercase sys.synonyms objects for the generate-changelog and diff-changelog commands in Liquibase and SQL Server. The PR fixes PR#2044. +- Added DB2 on z/OS database type and Java classes for Liquibase +- Upgrade h2 to newer version 2.0.206 + +Fixes +- Fixed the generateChangeLog wrong dependency order: the addPrimaryKey Change Type appeared before its base table in PostgreSQL [DAT-8256] +- Fixed the quality checks settings file to be created using both relative and absolute paths +- Fixed quality checks reporting only the first failure for a changeset to report all failures in outputs +- PR#2066] [smainz] Fixed the loadData Change Type to recognize CSV files when loading data with the path that contains a dot character ('.') +- [PR#2071] [nhumblot] [philhinco] Fixed the addNotNullConstraint Change Type causing the "Data too long" error message. The PR fixes PR#1054. +- [PR#2073] [smainz] Fixed the relativeToChangelogFile attribute for loadData, createProcedure, and createView Change Types +- [PR#2228] Handle the fact that FK names are not always unique +- [PR#2081] fix OSGI support (manifest, class loading) +- [PR#928] addColumn should support not-null constraint + +Changes in version 4.6.2(2021.11.30) + +Liquibase 4.6.2 introduces the multiple objects name quality check that allows you to define and check the naming pattern for several objects rather than one object. +For example, you do not want to have a dash in the table, column, and sequence names. With the multiple objects name check, you can specify a pattern to check for dashes +and choose tables, columns, and sequences as the objects to check. In version 4.6.2, the check is available for: +- Table +- Column +- Sequence +You can use two patterns for multiple object check: +- Multiple objects’ name in search: + - Table name matches a pattern + - Column name matches a pattern + - Sequence name matches a pattern +- Multiple objects’ name is not in search: + - Table name does not match a specific pattern + - Column name does not match a specific pattern + - Sequence name does not match a specific pattern + +Enhancements +- [PRO] Added the ability to configure the DDL_LOCK_TIMEOUT parameter for Oracle without SQL Plus and define the connection timeout. +- Improved the output of the SqlUserDefinedPatternCheck quality check copy +- Changed the default value of the strict parameter to false. You can set the strict parameter as follows: +- liquibase.strict=false|true in your liquibase.properties file +- Improved the handling of nested changelog preconditions. The PR fixes PR#1624. +- Enabled the update operations to continue if the DATABASECHANGELOGLOCK table already exists, which helps to serialize all processes following schema creation. +- Added support for MySQL function indexes. The PR fixes PR#1626. +- Added support for the NOT NULL constraint with an initial default value in the addColumn Change Type +- Added a flag to control the logging of SQL statements and SQL execution output +- Added support for the remarks attribute in a primary key column tag for MariaDB +- Implemented the handling of the GENERATED ALWAYS AS clause while creating a table for PostgreSQL +- Added the ability for Liquibase to load an additional directory of liquibase_libs in the current working directory to the classpath. With the liquibase_libs directory located in the /lib directory, projects can have separate extensions, drivers, and versions specific to a project + +Fixes +- [PRO] Fixed the snapshot command failing against CockroachDB with the Liquibase Pro license key applied +- Fixed the naming of the checks settings file shown as null if the file was corrupted +- Fixed the issue with Liquibase escaping the backslash in values stored in objects. The PR fixes PR#1598. +- Fixed the generate-changelog command to generate the NUMERIC[] data type for PostgreSQL correctly +- Fixed the parsing logic for YAMLChangelogParser and changeLogId in a Map. The PR fixes PR#1988. +- Fixed the --verbose flag used in the unexpected-changesets command. The PR fixes PR#1987. +- Fixed the exit code for the validate command running in automation to be 1 when there is an error. The PR fixes PR#1006. +- Fixed the dependency order for a changelog file with the addPrimaryKey Change Type generated by the generate-changelog command for PostgreSQL +- [PRO] Fixed the following environment variables LIQUIBASE_COMMAND_CHECKS_CONFIGURE_CHECKS_SETTINGS_FILE, LIQUIBASE_COMMAND_CHECKS_RUN_CHECKS_SETTINGS_FILE, and LIQUIBASE_COMMAND_CHECKS_SHOW_CHECKS_SETTINGS_FILE to be detected when running the quality checks commands [DAT-8546] +- Fixed quality checks reporting only the first failure in a changeset to report all failures found +- Fixed the time data type to be precise for PostgreSQL. The PR fixes PR#1774. +- Fixed the SQL generated by the alterSequence Change Type to be compatible with the Oracle, PostgreSQL, MariaDB, and MSSQL databases +- Fixed the Liquibase Cassandra extension failing when username and password are enabled +- Fixed the LOCKGRANTED column to include time zone information in the DATABASECHANGELOGLOCK table +- Fixed the classpath to include files with the relativeToChangelog=true parameter for Spring Boot + +Changes in version 4.6.1(2021.11.04) + +- Fixed the liquibase-pro-4.6.xsd + +Changes in version 4.6.0(2021.11.04) + +Windows and Mac/Linux Liquibase installers and the .tar.gz and .zip installation files include the most common JDBC drivers in the installation package: + - DB2 + - Firebird + - H2 + - HSQLDB + - PostgreSQL + - MariaDB + - MSSQL + - Oracle + - SQLite + +**Note:** Since Liquibase 4.6.0 provides driver jar files, the size of the installation package is bigger than the size of the installation package in earlier versions. + - Quality checks have configurable severity and exit codes + - The quality checks bulk-set command + - New Quality checks + - Static check: Warn when a table truncation is detected + - Dynamic check: Warn when granting specific privileges + - Static check: Warn when the `GRANT WITH ADMIN OPTION` statement is detected + - Static check: Warn when the `GRANT WITH GRANT OPTION` statement is detected + - The `liquibase.checks-settings.conf` file is unencoded in version 4.6.0 and later versions for easier inspection that allows you to resolve a merge conflict in source control. Liquibase backs up encoded files in the working directory, and you can still use previous versions by specifying the `--checks-settings-file` parameter in the CLI, as an environment variable, or as a property in the liquibase.properties file. + - Changed the XSD default `errorOnMissingOrEmpty` attribute to `true` for the `includeAll` attribute in the XML _changelog_ file (#1960) + - Added support for deferrable primary keys in the `createTable` Change Type. (#1597) + - Added support for the `constraintName` attribute in the `dropNotNullConstraint` attribute. Updated the `addNotNullConstraint` rollback logic to pass the constraint name to the generated `dropNotNullConstraint` change (#1492) + - Improved code and added tests in the `liquibase.util` package + - Changed the default encoding to UTF-8. Added a new global `liquibase.fileEncoding` setting, which you can set as `--file-encoding=ASCII` in the CLI, `liquibase.fileEncoding: ASCII` in the liquibase.properties file, and `LIQUIBASE_FILE_ENCODING=ASCII` as an environment variable (#1445) + + - [PRO] Added a message to warn Liquibase Pro users when they have noncompliant Liquibase environment variables if the `strict` attribute is set to `true` + - [PRO] Fixed the issue with Liquibase 4.4.0 and later versions to prompt if the Liquibase Pro license key is expired or invalid. + - [PRO] Fixed Liquibase Pro SQL Plus _changesets_ failures with the Kerberos setup + - [PRO] Fixed the `snapshot` command using for CockroachDB with Liquibase Pro license key + - Fixed an issue with running quality checks on Windows when using a configuration file created on Linux/macOS + - Fixed the `ChangesetCommentCheck` check to handle a lack of comments in the `tagDatabase` Change Type + - Fixed the default severity for the existing `liquibase.checks-settings.conf` files + - Fixed the `checks customize` and `checks copy` commands to handle directories with spaces + - Fixed the `schemas` and `includeSchema` attributes for the `generateChangeLog` command in Liquibase 4.4 and later versions + - Fixed the quality checks customization issue when using Git Bash + - Fixed the message for the quality checks severity customization + - Fixed the quality checks halting execution when the checks settings file contains entries for rules which do not exist in the system. Liquibase skips unknown checks and continues the execution + - Fixed the quality checks customization issue when using Git Bash + - Fixed the issue with Liquibase inserting a wrong default datetime value into MySQL. The PR fixes (#1395) + - Fixed the `insert` Change Type with the `valueSequenceNext` and `valueSequenceCurrent` attributes to use the schema specified on a statement level of a _changeset_ (#1304) + - Fixed the issue with Liquibase not handling case-sensitive primary key names in the `dropPrimaryKey` attribute for PostgreSQL (#1933) + - Fixed the `sqlFile` Change Type to handle the `encoding` attribute(#1760) + - Fixed the issue with Liquibase throwing a null pointer exception in the CLI if the `LicenseService` interface cannot be loaded because of the missing `jaxb` dependencies + - Fixed the `UniqueConstraintSnapshotGenerator` class switching to a bulk query after four unique constraints (#1996) + - Fixed the issue with Liquibase formatted SQL _changesets_ that are skipped if there is a space in the `--changeset` line (#1919) + - Fixed the `dropAll` command failing in the PostgreSQL database when the Liquibase-Cassandra extension is in the `liquibase/lib` directory (#47) + - Fixed Liquibase not reading the `liquibaseSchemaName` and `liquibaseCatalogName` configuration settings (#2000) + - Fixed the issue with Liquibase incorrectly inserting a long CLOB value in the database. Added integration tests. + +Changes in version 4.5.0(2021.09.21) + +There is a new family of commands to use to run quality checks: +- liquibase checks show to list the available quality checks +- liquibase checks run to run the available quality checks +along with enable, disable, customize, copy, reset, and delete options, and liquibase checks --help to learn more. +The following is a list of changes related to Liquibase Quality Checks: +- Implement checks enable/disable subcommands +- Implement checks run subcommand for dynamic rules +- Implement checks customize subcommand +- Implement checks copy subcommand +- Implement checks reset subcommand +- Implement checks show subcommand for dynamic rules +- Implement checks delete subcommand +- STATIC CHECK :: Changeset Must Have A Label +- STATIC CHECK :: Changeset Must Have A Context +- STATIC CHECK :: Changeset Must Have A Comment +- STATIC CHECK :: Warn When "DROP TABLE" Detected +- STATIC CHECK :: Warn When "DROP COLUMN" Detected +- STATIC CHECK :: Warn When Data Type Modification is Detected +- STATIC CHECK :: Warn when 'GRANT' Statement Detected +- STATIC CHECK :: Warn when 'REVOKE' Statement Detected +- DYNAMIC CHECK :: Warn when Tables have more than n columns +- Fail when creating a Scope with a null-parent #1354 +- Improve synchronization of LockServiceFactory reset #1991 +- Fix createSequence for h2 when dataType is specified #1992 +- GenerateChangeLog on an Oracle db ignores diffIncludeTablespace when creating MissingTableChange #1812 +- Fix OSGiResourceAccessor failing due to javax.activation #1534 +- Ensure that the root scope is initialized correctly regardless of whether a scope manager has been configured yet or not #1768 +- Manage parent directory relative to changelog in IncludeAll #1968 +- Fix UniqueConstraint snapshot query on db2z #1771 +- Fixes Postgresql bit column support #1468 +- fixed usage of computed values in prepared insert/update changes #1590 +- Get Set deleteCascade for serializer mapping #1837 +- Add support for changeset ids and authors with spaces in formattedsql changelogs. #1845 +- More efficient XML resource loading #1860 +- Too many open files error on application server: LiquibaseEntityResolver opens too many file descriptors and never closes them #1815 +- Classpath scan time lapse for every included changelog file #1913 +- Postgresql: Preserve existing search_path when setting the defaultSchemaName #1864 +- Cannot call extension function from migration #1823 +- Fixed postgresql addPrimaryKey cluster handling #1880 +- PostgresDatabase should ignore addPrimaryKey clustered false #1779 +- CLI no longer reading defaultsFile from classpath #1893 +- [PRO] Pro Enhancement Request: set 'splitStatements' to 'false' for Stored Logic changesets when generating a Formatted SQL changelog +- [PRO] Allow users to indicate names and location of their spool files when using runWith:sqlplus +- [PRO] Cannot update MariaDB expand based storage after first liquibase update +- [PRO] Liquibase PRO generateChangeLog error on Postgresql functions that have long signatures containing any '()' characters + +Changes in version 4.4.3 (2021.08.05) + +- Do not worry about FileSystemAlreadyExistsException errors #1885 +- The sqlFile and relativeToChangelogFile attributes fail when using the logicalFilePath attribute #1277 +- The wrong path received if relativeToChangelogFile=true and databaseChangeLog has logicalFilePath != PhisicalFilePath #1353 +- Added a separate query for DB2 on AS400, which fixed the dropAll command on DB2 for iSeries #1412 +- Fixed the logicalFilePath attribute not being serialized #1471 +- Fixed the SqlParser bug related to parsing UTF-8 valid symbols #1513 +- Fixed the invalid update SQL generated for HSQL database in InsertOrUpdateGeneratorHsql.java #1563 +- Added a validation error when the customChange Change Type has no name attribute #1592 +- Fixed the issue with Liquibase failing to create a DATABASECHANGELOGLOCK record and apply changesets into Firebird 3. isNumericBoolean now checks the Firebird3Database instance type and returns Boolean for Firebird 3. #1875 +- Fixed the issue with escaping question marks in PostgreSQL: #1877 +- SQL changesets are transforming the PostgreSQL ? JSON operator into ??, causing function definitions using this operator to become invalid #1764 +- An error when processing a large Postgres SQL changeset #1507 +- Fixed the issue with ClassCastException in a standard lock service: java.time.LocalDateTime cannot be cast to java.util.Date #1878 +- Added the MySQL reserved word CUBE to the list of Liquibase reserved columns for the schema migration to work. CUBE is a reserved word as of MySQL 8.0.1 #1515 +- Added the ability to handle empty lines at the beginning of a formatted SQL #1713 +- Fixed loading the CLOB data into PostgreSQL. Instead of loading the CLOB file name, PostgreSQL loads the content of the CLOB file. #1791 +- Changed the MD5SUM column value from RawSqlStatement to UpdateStatement #1602 +- Fixed synchronization in ChangeLogHistoryServiceFactory.java #1361 +- Enabled the dropAll report to work with a registered changelog with no extra arguments and send the information to Liquibase Hub +- Renamed the tablespaceName parameter to liquibaseTablespaceName +- Changed from RawSqlStatement to UpdateStatement #1602 +- Fix synchronization in ChangeLogHistoryServiceFactory.java #1361 +- [PRO] Fixed the changeset execution failure related to the DATICAL_SPERRORLOG table when using the runWith=sqlplus attribute and executing operations as a user with only SELECT, UPDATE, and INSERT permissions [DAT-7410] + +Changes in version 4.4.2 (2021.07.22) + +- Changed NullPointerException to ChangeLogParseException for the output when there is a typo in a changeSet node (#1593) +- Added the support method to DatabaseConnection (#1784) +- Fixed the issue with handling serial and bigserial if liquibase.convertDataTypes=false (#1883) +- Improved the ConfigurationValueProvider performance (#1952) +- Added the ability to allow an empty string for the defaultValue attribute (#1963) +- Reintroduced support for the - arguments in the CLI (#1943) +- Restored the updateTestingRollback command (#1939) +- Added the Maven goal for unexpectedChangeSets (#1972) +- Extended the dropAll command with optional hubConnectionId and hubProjectId attributes. For more information, check our [dropAll command]documentation. +- Fixed nested properties and the substitution of variables in YML changelogs. +- Implemented the ability to use connectionjdbcurl when there is no project or connection ID with the dropAll command. +- Improved the Liquibase Pro License key messaging. +- Added the ability to handle a declined auto-registration when running the dropAll command. +- Fixed auto-registration issues. +- [PRO] Added the ability to handle special characters in procedures when using the generateChangeLog command. +- [PRO] Fixed the issue with formatted SQL changesets and runwith:sqlplus being stopped unless Liquibase includes a quit statement. +- [PRO] Fixed the SQL Plus spool log issue. + +Changes in version 4.4.1 (2021.07.09) + - GH PR#1869 ⁃ HubUpdater releases lock even though registration is skipped + - GH PR#1861 ⁃ Only snapshot tables/columns in loadData + - GH PR#1843 ⁃ [LB-704] fixed generating sequences for Postgres versions prior to 10 + - GH Issue#1829 ⁃ Fixes MySQL Snapshot/Generated ChangeLog output for table key constraints when multiple tables + - Postgres: Rollback of rename target fails due to malformed SQL. + - Liquibase Hub registerChangeLog messaging fixes + - Liquibase Hub, Maven, and liquibase.properties file fixes + - Using --liquibaseProLicenseKey is on the left side of the command + - Update Liquibase installer adoptopenjdk from 11.0.10 to 11.0.11 + - [PRO] SQL Plus handles backslashes in changeset attributes' values + - [PRO] SQL Plus passing arguments during runtime fixes + - [PRO] SQL Plus handles Oracle proxy user setups + - [PRO] SQL Plus improve temp file handling + - [PRO] Fixes snapshot on MySQL Stored Logic Objects with Integer Types + +Changes in version 4.4.0 (2021.06.08) +- Refactor Configuration API +-- [PRO] including native use of Environment variables +- Refactor Command API +- Rewrote CLI to use new library +-- including new command options and help content +- Fixes an issue with Maven logs and username password (#1859) +- Fixes an issue with resolving properties files (#1723) +- Fixes an issue with diffChangelog dependency order (#1722) +- Fixes an issue with generating changlogs with DB2 on z/OS (#1506) +- Fixes an issue with long table names in Postgres (#1483) +- Fixes an issue with update flags for Postegres(#1213) +- Fixes an issue with loadData and loadUpdateData(#964) + +Changes in version 4.3.5 (2021.04.29) +- Better error handling in runWith=sqlplus when user doesn't have create/drop table permissions + +Changes in version 4.3.4 (2021.04.15) +- Reverts changes from #1722 because they broke other diffChangeLog/generateChangeLog use cases. + +Changes in version 4.3.3 (2021.04.09) +- Fixes an issue with changelogsync and hub +- Fixes an issue with diff and NullPointerException (#1631) +- Fixes an issue with NullPointerException and DateTimeType (#1366) +- Fixes an issue with maven resolving/using properties file (#1723) +- Fixes an issue with diffChangeLog and addColumn -> addPrimaryKey ordering (#1722) + +Changes in version 4.3.2 (2021.03.25) + +- Added new changelogSyncToTag command #1133 +- Support for working with deactivated changelogs in hub +- Added ability to create hub projects with parameters instead of only via prompts +- Only enable console prompting when explicitly enabled by the CLI #1711 #1689 +- Handle includeAll better in spring boot #1595 and #1436 +- Changed JRE bundled with installers to use the latest LTS version +- Better handle dropAll on postgresql partitioned tables #1650 +- Fixed sample liquibase.sqlplus.conf file #1448 and #1416 +- Fixed loadData's usePreparedStatement attribute #1098 +- Send hub logs at the same log level as configured in the CLI + +Changes in version 4.3.1 (2021.02.12) + +- Fixed handling of `classpath*:` in includeAll #1595 +- ClassCastException on moving to mysql-connector-java 8.0.23 #1639 +- Passwords sent to Hub when using jTDS driver +- ChangeExecListener cannot be used to to HubChangeExecListener #1651 +- RelativePathError when using includeAll tag and Spring Boot #1657 +- Liquibase 4.3.0 throws NullPointerExceptions without snakeyaml in the classpath #1682 + +Changes in version 4.3.0 (2021.02.06) + +- MariaDB is now fully certified for Liquibase Pro users +- Added ability to register for Hub during update operations +- Receive Liquibase Hub report links in the CLI after running commands +- Fixed NPE when an output writer is null #1625 +- Fixed filename + Id + author to be treated as unique in ValidatingVisitor.findChangeSet method #1622 +- Fixed EntityResolver to check the classpath even if the standard ResourceAccessor does not include it #1621 +- Fixed the CVE-2017-18640 issue on snakeyaml-1.2.4 #1608 +- Fixed HistoryCommandTest to run on systems having a non-US default locale #1078 +- Added quotes around ${JAVA_PATH} in Liquibase shell script to avoid spaces in path issues #1062 +- Fixed the issue with automatic dropping of default values on MS SQL #1003 +- Allow --changeset to have a space after -- in formatted sql files +- Modified SetColumnRemarks support for MySQL #942 +- Implemented boolean data type support for DB2 LUW #966 +- Added deprecated LogFactory.getInstance() to smooth the upgrade to 4.x #1642 and #1641 +- Included the existing dropPrimaryKey.dropIndex attribute in XSD #1629 +- Implemented auto-registration and operation report capabilities for Liquibase Hub + +Changes in version 4.2.2 (2020.12.09) + +- Handle null statement objects coming from JdbcConnection objects #1576 + +Changes in version 4.2.1 (2020.12.03) + +- Fixed invalid casting to JdbcConnection in CockroachDatabase #1536 +- Fixed missing unique constraints in snapshot #1477 +- Fixed unexpectedChangeSets command throwing a null pointer exception +- If error occurs during generating SQL, Liquibase stops and does not send POST to Hub +- Use ConcurrentHashMap in ExecutorService #1402 +- DropDefaultValue on postgresql now drops the default value vs. setting the default value to null #931 +- Updated banner to reference to hub.liquibase.com +- [PRO] GenerateChangeLog on postgresql stored logic now hashes parameters in filenames instead of listing them all out +- [PRO] Fix in postgresql check constraints snapshot +- [HUB] Command registerChangeLog now supports YAML and JSON changelog files + +Changes in version 4.2.0 (2020.11.12) + +- [PRO] Support for snapshotting Mysql stored logic +- GH PR#373 - Added option "updateable" to the column tag. +- GH Issue#1523 - Fix xsd, remove surplus space after validateForeignKey (4.1.xsd / 4.2.xsd +- GH Issue#1510 - MySql 8.0 requires create and drop of temporary tables to run generateChangeLog +- GH PR#1496 - Move banner.txt to new location +- GH PR#1495 - Fix issue with loadUpdateData GH-1489 +- GH Issue#1489 - loadUpdateData broken for clob/text fields in 3.10.3 +- GH Issue#1476 - Consider alternative location for banner.txt +- GH Issue#1438 - XML Export adds ',xxx' instead of ',' +- GH Issue#1389 - Precondition onFail="WARN" doesn't work properly +- GH PR#1427 - Update Ant Tasks to use DatabaseFactory rather than create connection itself + +Changes in version 4.1.1 (2020.10.09) + +- GH #1276 Rewrote SpringResourceAccessor +- GH PR#1285 Remove deprecated code in Ant tasks +- GH PR#1286 Fix usage of AntTaskLogger +- GH #1097 diffChangeLog overwrites first changeset in formatted sql changelog + +Changes in version 3.10.3 (2020.10.09) + +- GH PR#912 - CORE-3379 escaping postgres questionmark operators to prevent unwanted parameter syntax +- GH PR#936 - SpringLiquibase createResourceOpener() now returns a ResourceAccessor, which allows it to be overridden with any kind of ResourceAccessor +- GH PR#983 - Fixes for loadData to support Postgres enums with java.sql.Types.OTHER +- GH PR#1010 - Potential fix for generated columns on postgres +- GH PR#1258 - Reduced the verbosity of logging by moving SQL logging from info to debug logging +- GH PR#1239 - Fix xsd, remove surplus space after validateForeignKey +- GH PR#1296 - Put the banner in an external file for easier editing. +- GH PR#1327 - Fix varchar(max) extrainfo in 3.10 branch +- GH PR#1406 - Fixed integration tests for 983 +- GH PR#781 - feat: Maven Liquibase Plugin generateChangeLog mysql sql comment supported +- GH PR#945 - [CORE-3523] Consistently map Liquibase integer types to Oracle integer types. MERGED THEN UNMERGED +- GH PR#1140 - fix root paths for spring boot fat jar +- GH PR#1332 - Update FileSystemResourceAccessor.java +- GH PR#1372 - Fix for PR 1001 in 3.10.x branch +- Fixed priority for JDBC Connections +- GH PR#1140 - Added json and sql to the list +- GH PR#1418 - Revert "[CORE-3523] Consistently map Liquibase integer types to Oracle integer types" UNMERGE 945 +- GH PR#1422 - Updates for #1081 in 3.10.x +- GH PR#1431 - Fix merge issue in OracleDatabase +- GH PR#1443 - Handle MSSQL computed columns in generate changelog LB-366 +- GH PR#1447 - Do not use batched statements for Postgres LoadDataChange LB-744 +- Fixed schema version number for 3.10 + +Changes in version 4.1.0 (2020.9.28) + +- Added support for hub.liquibase.com to CLI and Maven integrations +- New registerChangeLog command +- New syncHub command +- Added hubApiKey argument +- Added hubConnectionId argument +- CLI commands and arguments are now case insensitive +- Includes changes from 3.10.2 + +Changes in version 3.10.2 (2020.7.27) + + - Dependency cycle error during generateChangeLog with --diffTypes=tables,columns,data + - liquibase maven:: unable to run tests on java > 8 + - Add Banner in log out put that directs users to online resources. + - GH PR#980 - fixed invalid carriage return coming from oracle ojdbc8 12.2.0.1 + - GH PR#976 - Changes databasechangelog sql to use legacy mode + - [CORE-3525] Add support for java.sql.Types.TIMESTAMP_WITH_TIMEZONE. + - GH PR#929 - Fix #CORE-3493 Inconsistent resolution of ChangeLogParameters + - GH PR#744 - Informix data type generation with Default Value cause + - GH PR#1176 - Add MariaDB sequence support to the 3.10.x branch + - GH PR#1177 - CORE-3643: fixed the 'shouldValidateX' methods in the Constraints + - GH PR#1201 - H2 unknown reserved word + + +Changes in version 4.0.0 (2020.07.14) +- No changes since 4.0.0 beta2 + +Changes in version 4.0.0 Beta2 (2020.07.1) +- Re-introduced deprecated versions of commonly used 3.x methods that had been removed for 4.0 +- Fix to handle --logLevel=debug/fine CLI argument +- Do not include root filesystem in default CLI search paths +Changes in version 3.10.1 (2020.7.2) + + - GH PR#913 - [CORE-3471] Fixed NPE in LiquibaseUtil when MANIFEST.MF doesn't contain Bundle-Version or Build-Time + - GH PR#917 - [Core 3463] Fix for validateX attributes of constraintsConfig + - GH PR#919 - Fixed issued with bundling in shaded jars + - GH PR#941 - [CORE-3520] Add support for ALWAYS generation type with PostgreSQL auto-increment column. + - GH PR#946 - [CORE-3524] Prevent auto-increment column silently failing on Oracle. + - GH PR#949 - [CORE-3526] TABLE is a reserved keyword in H2database since 1.4.197 + - GH PR#963 - [CORE-3556] No default values for changes' properties + - GH PR#965 - [CORE-3558] Unique constraint name is ignored when using the addColumn change + - GH PR#970 - Fix Java 1.9+ versions require jaxb as separate dependency + - GH PR#971 - Add Class-Path entry to the manifest file to simplify command line execution + - GH PR#975 - NULL date value in prepared statement requires type in MSSQL + - GH PR#986 - XMLSerializer: Correct Map value serialization + - GH PR#993 - Improve ChangeFactory initialization time + - GH Issue#1035 - Change how Liquibase produces debug logs + - GH Issue#1051 - Update liquibase-core.jar to exclude ServiceLoader files + - GH PR#1053 - Update liquibase_autocomplete.shape + - GH PR#1059 - Allow multiple column unique constraints on table creation. + - GH Issue#1069 - Patch Liquibase Runner plugin for Jenkins + - GH Issue#1070 - Enable --help without databse connection + - GH PR#1082 - Correct include bash script + - GH PR#1096 - Fix sequence statement generation for PostgreSQL <= 9.4 + - GH Issue#1104 - Fix maven-liquibase offline diff to prevent errors + - GH Issue#1113 - Fix schema name using "--defaultSchemaName" on a non-default schema + - GH PR#1120 - LiquibaseServletListener.contextInitialized() improved with Embedded Derby + - GH Issue#1220 - Fix how JAVA_HOME env variable is handled + +Changes in version 3.10.0 (2020.6.12) +- [Pro] Built-in runWith="sqlplus" +- New "runWith" changeSet extension point +- Added liquibase_autocomplete_mac.bash completion script + +Changes in version 3.9.0 (2020.5.13) +- [Pro] New ""--format=json" argument for diff command + +Changes in version 4.0.0 Beta1 (2020.4.20) +- MAJOR CHANGE: Replaced old custom classpath scanner with java.util.ServiceLoader for finding extensions +- MAJOR CHANGE: Refactored logging system to clean up API and use java.util.Logging +- Fixes to ConstraintsConfig https://github.com/liquibase/liquibase/pull/954 +- ignoreLines command in formatted sql log https://github.com/liquibase/liquibase/pull/877 +- postgresql >= 10: use identity columns for autoincrement https://github.com/liquibase/liquibase/pull/874 +- Using proxy user for Oracle Connections https://github.com/liquibase/liquibase/pull/894 +- Capture table remarks on mysql https://github.com/liquibase/liquibase/pull/895 +- Add PERIOD to reserved words for MariaDB https://github.com/liquibase/liquibase/pull/896 +- Don't require columnDataType on H2 for addNotNullConstraint https://github.com/liquibase/liquibase/pull/851 +- Do not remove trailing /'s of comments like /* dsds */ https://github.com/liquibase/liquibase/pull/853 +- Require type xsd:string to where element of update element https://github.com/liquibase/liquibase/pull/875/files +- runOnChange change set runs every time even if there wasn't changed https://github.com/liquibase/liquibase/pull/891 +- Indexes with DESC sorting are not created for PostgreSQL https://github.com/liquibase/liquibase/pull/880 +- Added Ingress support https://github.com/liquibase/liquibase/pull/683 +- Support boolean in firebird 3.0 https://github.com/liquibase/liquibase/pull/757 +- Change Log Parameters from Environment Variable https://github.com/liquibase/liquibase/pull/758 +- Adds clearCheckSums property in spring integration https://github.com/liquibase/liquibase/pull/792 +- Oracle datatype translation changes https://github.com/liquibase/liquibase/pull/797 +- Implement Sequence Support for MariaDB https://github.com/liquibase/liquibase/pull/852 +- Cleanup checksum classes https://github.com/liquibase/liquibase/pull/869 +- Fix Turkish uppercase column keys bug https://github.com/liquibase/liquibase/pull/857 +- Generate diff with onDelete and onUpdate https://github.com/liquibase/liquibase/pull/858 +- PrimaryKeySnapshotGenerator throws NPE for SQLite https://github.com/liquibase/liquibase/pull/856 +- Handle java.sql.Time when setting prepared statement parameter values in CSV filese https://github.com/liquibase/liquibase/pull/859 +- DB2 LUW supports boolean data type column from version 11.1.1.1 https://github.com/liquibase/liquibase/pull/865 +- Offline history support not correctly closing files https://github.com/liquibase/liquibase/pull/863 +- Use computeIfAbsent to avoid Liquibase concurrency issues https://github.com/liquibase/liquibase/pull/866 +- Firebird does not support RESTRICT option on Foreign Keys https://github.com/liquibase/liquibase/pull/761 +- Liquibase was ignoring DatabaseFunction value and processing only SequenceNextValueFunction when creating tables and generating column default value. https://github.com/liquibase/liquibase/pull/785 +- Restore usage of `DatabaseList.definitionMatches` to match the `dbms` tag against the database type https://github.com/liquibase/liquibase/pull/811 +- DEPLOYMENT_ID column header not included in offline updateSql CSV https://github.com/liquibase/liquibase/pull/813 +- Can't set some parameters for snapshot & generate changelog https://github.com/liquibase/liquibase/pull/822 +- UUID type handling improvements https://github.com/liquibase/liquibase/pull/838 +- Correctly close yaml file in generateChagneLog https://github.com/liquibase/liquibase/pull/844 +- Adding restricted words for MSSQL Server Database https://github.com/liquibase/liquibase/pull/825 +- Getting a java.io.FileNotFoundException using Liquibase with Spring reactive web https://github.com/liquibase/liquibase/pull/814 +- FileSystemResourceAccessor fails with non-hierarchical URLS on classpath https://github.com/liquibase/liquibase/pull/830 +- fix oracle date literal without millis https://github.com/liquibase/liquibase/pull/828 +- fix nullPointerException when migrating RedShift https://github.com/liquibase/liquibase/pull/823 +- Prints the SQL error code on Exception https://github.com/liquibase/liquibase/pull/833 +- Fixed SetColumnRemarks for mysql https://github.com/liquibase/liquibase/pull/835 +- Allow "NOW" and "Today" literal capabilities in CSV filese https://github.com/liquibase/liquibase/pull/808 +- Add ability to disable running of Liquibase via CDILiquibaseConfig https://github.com/liquibase/liquibase/pull/804 + +Changes in version 3.8.9 (2020.4.06) +- Fixed an issue with how Liquibase handles SMALLINT columns in PostgreSQL when generating a changelog. +- Improved `generateChangeLog` command to assume a `diffTypes` that includes "data" when the `dataOutputDirectory` parameter is used. Most users looking to export data as part of `generateChangeLog` can now simply use the `dataOuputDirectory` parameter without needing to specify `diffTypes`. +- Enabled the use of the `--schemas` parameter to work on either side of the `snapshot` command. +- Enabled `generatechangelog` in PostgreSQL to correctly order `create`, `function`, and `trigger` statements. +- Improved the use of dblink objects when using `diff` command. + +Changes in version 3.8.8 (2020.3.19) +- `rollbackOneChangeSetSQL` now works correctly with the Liquibase Maven plugin. +- Liquibase Pro no longer generates procedural code with incorrect SQL syntax when running `generateChangeLog` against a MySQL database. + +Changes in version 3.8.7 (2020.2.21) + +- New liquibase history command +- [Pro] New liquibase rollbackOneUpdate command +- PR#927 CompositeClassLoader does not implement getResource(String) +- `liquibase --help` was improved to include missing commands and correct information + +Changes in version 3.8.6 (2020.2.6) + +- New graphical installer for Windows and Mac +- New examples directory with sample xml and sql changelogs and test h2 database +- [Pro] New RollbackOneChangeSet and RollbackOneChangeSetSQL commands +- Updated default Mysql driver to com.mysql.cj.jdbc.Driver +- Removed non-jdbc compatible "SET DEFINE OFF" from generated SQL on Oracle +- Fixed --excludeObjects/--includeObjects arguments in diff + +Changes in version 3.8.5 (2020.1.13) + +- Fixes issue in which Liquibase did not add `DESC` to an `id` column +- CLI once again accepts sqlFile, delimiter, rollbackScript, and outputSchemaAs arguments +- Fixes Stored Procedure whitespace impacting update calls +- Fixes generateChangelog failure when there are missing NOT NULL constraints. +- Fixes updateSQL, which was not including schemaName for package bodies. +- Fixes bug in which Liquibase was not always capturing `create package body` while generating changeLog +- Liquibase CLI now gives a more useful error message when an invalid character is passed to a command. +- Fixes an MSSQL issue, which threw an exception when doing diff/diffChangeLog between offline connections (such as when snapshotting json files) +- Fixes an MSSQL issue, which incorrectly generated `datetime` data type column when using`diff` & `diffChangeLog` +- Liquibase Maven plugin fails while executing/using "diff" and "generateChangeLog" with PostgreSQL) + +Changes in version 3.8.4 (2019.12.23) + +- Fixed a 'Class not Found' exception error when using Java +9. +- Fixed a 'Cannot Use Default Schema Name' error when users diff against an SQL Server snapshot file. +- Fixed an 'Unexpected type: java.util.Date' error when using a defaultValueDate attribute in a YAML changelog. + +Changes in version 3.8.3 (2019.12.19) + +- Liquibase-Maven plugin now works with Java 9+. +- Expired license messages should be far less verbose and excitable. + +Changes in version 3.8.2 (2019.11.26) + +- Pro stored logic snapshot logic now supports postgresql and db2 +- Using generateChangeLog/diffChangeLog to generate formatted sql changelogs now works with Liquibase Pro's stored logic support +- CDI-related classes moved back out of the main liquibase jar into an optional jar +- Fixed issue with indexes backing foreign keys not always being caputured in diffChangeLog/generateChangeLog +- Fixed issue with diffChangeLog/generateChangeLog generating primary keys when column order doesn't match the table's column order + +Changes in version 3.8.1 (2019.11.5) + +- [PRO] Oracle and SQL Server users can now reverse engineer database changes for stored logic such as triggers, functions & procedures using generateChangeLog, snapshot, diff, and diffChangeLog commands. +- diff command writes to an external file using --outputFile flag +- updateSQL command no longer outputs to liquibase.log +- Cleaned up unexpected entries in diffchangelog.xml for SQL Server + +Changes in version 3.8.0 (2019.8.16) + +- [CORE-3462] - Add new procedural database code change types for Liquibase Pro + +Changes in version 3.7.0 (2019.7.16) + +- [CORE-3303] - Allow disabling shouldRun configuration via CDI integration +- [CORE-3388] - DB2 LUW supports boolean data type column from version 11.1.1.1 +- [CORE-3400] - add "manifoldclass:" to list of skipped URL protocols in DefaultPackageScanClassResolver +- [CORE-2377] - Using replaceIfExists with generates DROP statements +- [CORE-2971] - Comments at end of statements are incorrectly parsed +- [CORE-3124] - Indexes with DESC sorting are not created for PostgreSQL +- [CORE-3159] - class cast exception when running command line +- [CORE-3174] - Plugin does not create parent directory +- [CORE-3211] - Firebird does not support RESTRICT option on Foreign Keys +- [CORE-3251] - SQL Server Changesets Not Escaping Keywords +- [CORE-3365] - PrimaryKeySnapshotGenerator throws NPE for SQLite +- [CORE-3375] - addNotNullConstraint on h2 still requires (unused) columnDataType +- [CORE-3386] - includeAll can't resolve relativeToChangelogFile path within a jar file +- [CORE-3437] - MariaDB 10.3.4+ problem with add column PERIOD +- [CORE-2235] - Support priority-based selection of Precondition implementation +- [CORE-3205] - Change Log Parameters from Environment Variable + +Changes in version 3.6.3 (2019.1.29) + +- [CORE-3100] - diff with uppercase reference database name +- [CORE-3141] - ForeignKeySnapshotGenerator broken with recent SQL Server driver +- [CORE-3192] - Error while including resources with includeAll directive +- [CORE-3221] - Parsing valueDate Attribute of column Tag leads to precision loss and generating SQL for Oracle DB is broken +- [CORE-3222] - Bin zip doesn't work due to missing slf4j-api JAR +- [CORE-3231] - NPE in LogService.pushContext for MDCs that don't allow null values +- [CORE-3242] - MS SQL Server 2008 support issue +- [CORE-3256] - Verbose flag not getting interperated during 'status' command. +- [CORE-3293] - Non global change log parameters are wrongly resolved in inner files +- [CORE-3296] - CommandLineUtils::getBanner fails if manifest entries are missing +- [CORE-3335] - Not possible to register/unregister SqlGenerators during execution of changeSet +- [CORE-3348] - MSSQLDatabase class has a bug when connecting to SQL Server 2008 databases + +Changes in version 3.6.2 (2018.06.30) + +- [CORE-3129] - PostgreSQL dropPrimaryKey with objectQuotingStrategy="QUOTE_ALL_OBJECTS" +- [CORE-3206] - Liquibase 3.6.x is binary api-incompatible with 3.5.x +- [CORE-3213] - Changelog with includeAll will not find child changelogs in multi-modules Spring Boot's executable JAR +- [CORE-3229] - Oracle 11g doesn't support TIMESTAMP WITHOUT TIME ZONE data type + +Changes in version 3.6.1 (2018.04.11) + +- [CORE-3200] - Wrong SQL generator is selected +- [CORE-3201] - Command line missing required dependencies in 3.6.0 tarball +- [CORE-3198] - Configuration option to prefer internal XSD usage + +Changes in version 3.6.0 (2018.04.5) + +- [CORE-1609] - Command Prompt: Can't connect to database with a special character in pwd +- [CORE-1852] - checksums depend on environment +- [CORE-1888] - Sybase error for TINYINT, INT, BIGINT: Can't specify a length, scale or storage property on type 'int/tinyint/bigint'. +- [CORE-2008] - H2 Supports minValue and maxValue in Sequences since Version 1.3.175, but Liquibase does not +- [CORE-2033] - NPE during Diff when case sensitive table missing +- [CORE-2135] - liquibase corrupting UTF-8 changesets +- [CORE-2162] - MSSQL: Multiple inserts in sqlFile do not fail as expected +- [CORE-2191] - Update on SQL Azure database fails due to unavailable sys.extended_properties +- [CORE-2527] - Sybase create table fails because column name is too long +- [CORE-2631] - dbdoc does not specify content type +- [CORE-2739] - --delimiter parameter in liquibase --help +- [CORE-2747] - CreateView / Oracle: Keyword REPLACE in view definition prohibits "or replace" in DDL statement +- [CORE-2772] - primaryKeyExists check fails on Turkish locale for some chars +- [CORE-2773] - DB2 AS/400 - generateChangeLog throwing Exception +- [CORE-2796] - Handle TimeStamps with nano second precision correctly +- [CORE-2797] - Determine the DB2 data server type correctly +- [CORE-2820] - Unsupported ReorganizeTable for DB2 z/OS causes changelog validation to fail +- [CORE-2821] - AddForeignKey statement generates incorrect SQL for DB2 z/OS +- [CORE-2826] - indexExists precondition fails on AS400 + JDBCDatabaseSnapshot/Snapshot generator code is not coded generically +- [CORE-2843] - Sql wrong lexical analysis for string literals - escaped single quotes are misparsed +- [CORE-2875] - UTF-8 character not understood +- [CORE-2894] - Oracle snapshot not detecting custom datatypes in different schemas +- [CORE-2909] - column remarks for mysql should be escaped +- [CORE-2911] - Oracle: generateChangeLog on RAW types not including the size param +- [CORE-2928] - Invalid snapshot of "duplicate" foreign keys +- [CORE-2929] - Views with definitions that start with a comment are not captured correctly in generateChangeLog +- [CORE-2940] - Do not print warning when DBA_RECYCLEBIN is not available +- [CORE-2944] - outputDefaultSchema and outputDefaultCatalog command line parameters not respected +- [CORE-2953] - update with valueSequenceNext and schema produces wrong SQL on oracle +- [CORE-2965] - Custom Properties XML Changelog +- [CORE-2992] - liquibase.util.grammar.TokenMgrError: Lexical error at line 1, column 71. Encountered: "\u00b4" (180), after : "" +- [CORE-2993] - createSequence with order denied on DB2 +- [CORE-3002] - SQLAnywhere: Revert Unique Index failed +- [CORE-3006] - Oracle CSV-Import: "String index out of range: -1" +- [CORE-3009] - SQLAnywhere: Drop Default Value failed +- [CORE-3020] - No warning when included file doesn't exist (missing extension) +- [CORE-3033] - typo in postgresql reserverd word +- [CORE-3040] - onlyUpdate="true" flag generates empty statements for MySQL DB +- [CORE-3046] - Fix faulty snakeyaml class-path entry after upgrade to 1.17 +- [CORE-3051] - SQLAnywhere: Drop Table does not support CASCADE +- [CORE-3054] - SQLAnywhere: java-coredump on changeSet-SQL +- [CORE-3055] - SQLAnywhere: supports Sequences +- [CORE-3063] - Integration tests failing on master +- [CORE-3069] - Checksum: line endings not standardized on windows if multiple lines +- [CORE-3072] - Add usePreparedStatements="true|false" flag to loadData +- [CORE-3076] - SUM is not reserved word for HsqlDB +- [CORE-3099] - Non English environment; invalid tablename and column name can be generated because of toUpperCase toLowerCase method which is dependent to locale in java +- [CORE-3101] - dropPrimaryKey TABLE_SCHEMA = 'null' +- [CORE-3106] - SQLAnywhere: DROP INDEX should use tablename +- [CORE-3115] - Prefix space in column type causing the Unknown LiquibaseDataType with the latest release +- [CORE-3117] - TIMESTAMP WITH TIME ZONE datatype is changed to TIMESTAMP in H2 +- [CORE-3119] - Maven failing to use driverPropertiesFile from Liquibase Properties File +- [CORE-3135] - Column t1.tgconstrname does not exist +- [CORE-3138] - SQLAnywhere: AddAutoIncrement-Statement is wrong +- [CORE-3140] - MSSQL2005 doesn't support built-in function original_db_name() +- [CORE-3155] - CSV line content behind inline comment character doesn't contribute to checksum +- [CORE-3162] - Diff problem with MSSQL case sensitive database +- [CORE-3171] - LoadUpdateData doesn't work on SAP SQLAnywhere +- [CORE-3180] - A DBMS-specific change set referencing a DBMS-specific rollback can't be parsed on a different DBMS +- [CORE-2735] - Add possibility to test rollback with SpringLiquibase +- [CORE-1225] - Add support for tablespace assigned to liquibase metadata tables +- [CORE-2628] - defaultSchema parameter doesn't do Connection.setCatalog() for SpringLiquibase +- [CORE-2842] - MSSQL: Support creating clustered unique constraints +- [CORE-2891] - Liquibase "Command" objects can be extended and overridden +- [CORE-2919] - Make all variants of Liquibase.listUnrunChangeSets public +- [CORE-2952] - Use the clustered index if duplicate indexes are defined +- [CORE-2955] - MSSQL: Capture explicit null default values on snapshot and generate/diffChangeLog +- [CORE-2970] - MSSQL: Support default value constraint names +- [CORE-2977] - Generated primary key constraint name doesn't match Postgres default +- [CORE-2985] - MSSQL Snapshot performance improvements +- [CORE-3000] - Oracle JDBC batch for load_data +- [CORE-3005] - Consideration of DB2/400 system views +- [CORE-3017] - Add path attribute to createView +- [CORE-3018] - Oracle: support remarks on createView +- [CORE-3045] - Support indexes on views +- [CORE-3079] - Make includeObjects and excludeObjects affect which objects are snapshotted +- [CORE-3094] - HSQLDB UUID support +- [CORE-2920] - Using "//" as an endDelimiter stopped working 3.5.0 + +Changes in version 3.5.5 (2018.02.5) + +- [CORE-2851] - includeAll tag with a relative path duplicates the database changes with an absolute and with a relative changelog + +Changes in version 3.5.4 (2018.02.5) + +- [CORE-2863] - Issue with Spring boot 1.4.0 - 1.4.3 +- [CORE-2898] - includeAll broken in 3.5.1 +- [CORE-2948] - Changelog with includeAll will not find child changelogs in Spring Boot's executable JAR +- [CORE-2978] - AddAutoIncrement on Postgres does not work when no schema is specified +- [CORE-3123] - ResourceComparator is not applied for includeAll +- [CORE-3139] - ClassLoaderResourceAccessor cannot read jar path resources from SpringLiquibase +- [CORE-3015] - Oracle: diffChangeLog TIMESTAMP WITH LOCAL TIME ZONE correctly + +Changes in version 3.5.3 (2016.10.13) + +- No changes + +Changes in version 3.5.2 (2016.09.21) + +- [CORE-1863] - PostgreSQL blob is mapped to bytea instead of oid +- [CORE-2693] - Postgresql dropAll with serial columns fails because tables are dropped then sequences which no longer exist +- [CORE-2698] - Oracle scripts with ending / are not actually getting executed even with splitStatements="false" +- [CORE-2752] - Jtds has silent exceptions in db.getConnectionSchemaName +- [CORE-2753] - defaultValueSequenceNext forgets schema name +- [CORE-2754] - update table columns are not quoted when requested +- [CORE-2756] - Null pointer exception from FileSystemResourceAccessor +- [CORE-2757] - Databasechangelog ORDEREXECUTED and DEPLOYMENT_ID not updated when a changeSet is reran +- [CORE-2758] - Debian package shouldn't symlink liquibase binary to absolute path +- [CORE-2761] - 3.5.1: includeAll from the command line uses the absolute path as the changeSet path +- [CORE-2763] - Postgresql schemas should default to lower case +- [CORE-2765] - dbms in preConditions yaml changelog causes parsing error +- [CORE-2770] - Can't read remarks from mssql 2000 +- [CORE-2774] - Can't read all columns from mssql2000 +- [CORE-2775] - Oracle Sequences not Generated in generateChangeLog after 3.4.1 +- [CORE-2778] - Sybase ASE: Incorrect syntax near the keyword 'ALTER' +- [CORE-2780] - java.sql.SQLException: PooledConnection has already been closed +- [CORE-2781] - DB2: custom-generated indexes for primary keys are not preserved in diff/generateChangeLog +- [CORE-2784] - REGRESSION: Column creation of type 'TIMESTAMP WITHOUT TIMEZONE' fails on PostgreSQL +- [CORE-2785] - Status command inconsistent with databasechangelog table +- [CORE-2786] - Incorrect xml scheme for changlog file +- [CORE-2787] - YAML Snapshot parser not handling strings that get stored as binary +- [CORE-2789] - Postgres does not have a type "BINARY" +- [CORE-2791] - Strip off trailing end delimiter in createProcedure on update, include on updateSql +- [CORE-2793] - using property as startWith attribute +- [CORE-2794] - Make CSV files created by Liquibase readable by Liquibase +- [CORE-2795] - Fix a NullPointerException in DiffToChangeLog.sortMissingObjects +- [CORE-2804] - defaultValueSequenceNext forgets schema name H2/PG/etc +- [CORE-2805] - Multiple calls to generateChecksum() impacting deploy performance +- [CORE-2806] - JsonSnapshotParser does not close stream after parsing +- [CORE-2807] - Column data type "real" incorrectly translated to "double precision" for PostgreSQL, should be "real" +- [CORE-2810] - defaultValueBoolean="false" generates wrong SQL for MySQL +- [CORE-2811] - FileSystemResourceAccessor basepath/includeAll +- [CORE-2813] - java.lang.NullPointerException when creating new ClassLoaderResourceAccessor(); +- [CORE-2814] - DB2: Quoting strategy not respected, objects are always saved as upper case +- [CORE-2815] - Rollback by tag doesn't roll back tagDatabase changeSet +- [CORE-2816] - Snapshot error when snapshotting an index or primary key against a case-sensitive column +- [CORE-2818] - DEPLOYMENT_ID not created for Sybase in DATABASECHANGELOG, liquibase 3.5.1 +- [CORE-2819] - AbstractJdbcData getConnectionSchemaName() methods fails for Sybase +- [CORE-2823] - DROP PRIMARY KEY fails for Sybase database update +- [CORE-2827] - MSSQL: misc default value fixes +- [CORE-2828] - MSSQL not capturing that primary key are non-clustered in generateChangeLog +- [CORE-2830] - GenerateChangeLog does not handle tables with compound primary keys +- [CORE-2831] - MySql BIT(1) defaultValue not snapshotted as Boolean +- [CORE-2835] - GenerateChangeLog doesn't correctly "numeric DEFAULT '" " columns +- [CORE-2836] - addAutoIncrement generates inconsistent sequence name for mixed-case table +- [CORE-2837] - addAutoIncrement doesn't apply default schema in nextval call (PostgreSQL) +- [CORE-2838] - createProcedure schema in the changelog is overwritten by defaultSchemaName +- [CORE-2840] - MSSQL createProcedure for CREATE MERGE AS procedures need a trailing semicolon +- [CORE-2843] - Sql wrong lexical analysis for string literals - escaped single quotes are misparsed +- [CORE-2846] - DATABASECHANGELOG table query failed on postgres on first run +- [CORE-2849] - Fail to execute with sequences +- [CORE-2853] - Diff comparisions reporting differences between '0.0' and '0' in decimals +- [CORE-2863] - Issue with Spring boot 1.4.0 +- [CORE-2864] - Regression for defaultSchemaName on MSSQL +- [CORE-2867] - liquibase with MySQL raises exception "Table 'DATABASECHANGELOG' already exists" when using separate liquibase schema +- [CORE-2868] - Adds schema/username to package and package body in oracle making them invalid +- [CORE-2869] - Without a specified classpath, using includeAll with relativeToChangelogFile="true" fails +- [CORE-2872] - "ON DELETE" not supported for FK constraints in Sybase +- [CORE-2876] - Issue with Spring boot 1.4.0 Repackaged +- [CORE-2878] - MSSQL setTableRemarks limited to 200 chars +- [CORE-2881] - DiffChangeLog unnecessarily includes referenceTableCatalogName attribute if comparing Schema with different names +- [CORE-2885] - AddColumn with defaultValueSequenceNext generated incorrect SQL for PostgreSQL +- [CORE-2788] - handle VARBINARY type in Oracle and H2 +- [CORE-2800] - Add flag to diff command that suppresses reporting of column order difference in tables +- [CORE-1984] - Support for non-split rollback statements in Formatted SQL +- [CORE-2768] - Have the .deb and .rpm part of the release on github +- [CORE-2782] - Update SnakeYAML version to 1.17 +- [CORE-2801] - Add method to Logger to allow closing of the output file stream +- [CORE-2844] - Traverse parent changelogs for rollbacks +- [CORE-2848] - Oracle: primary keys that use a pre-existing index drop the index along with the primary key on rollback +- [CORE-2852] - Postgresql snapshots not correctly handling serial-backing sequences +- [CORE-2857] - Support clustered primary keys in postgresql +- [CORE-2873] - Postgresql custom types are snapshotted as having length 2147483647 +- [CORE-2874] - Ensure consistent charset encoding usage + +Changes in version 3.5.1 (2016.05.10) + +- [CORE-2727] - NPE in DiffToReport.print() method +- [CORE-2728] - Classloading broken in 3.5.0 with nested jars +- [CORE-2729] - NullPointerException on Diff +- [CORE-2731] - diff fails with NullPointerException +- [CORE-2732] - releaseLock fails because ObjectQuotingStrategy is reset to LEGACY +- [CORE-2733] - relativeToChangelogFile fails with FileSystemResourceAccessor +- [CORE-2734] - Liquibase no longer handle newline correctly in endDelimiter when using sqlFile change +- [CORE-2743] - CSV whitespace trimmed in 3.5.0 +- [CORE-2744] - changeset with loadUpdateData changes checksum in 3.5.0 +- [CORE-2745] - Performance degradation of sqlFile change +- [CORE-2746] - Oracle: handle case when schema name contains a hyphen +- [CORE-2750] - MSSQL catalog/database included all the time + +Changes in version 3.5.0 (2016.04.21) + +- New "created" attribute on changeSet +- New runOrder="first|last" attribute on changeSet to override where in the changelog it is ran +- New "context" attribute on and to control when changelogs are included +- Support for AND/OR context expressions in formatted SQL changelogs +- Support for changelog parameters in formatted SQL chagnelogs +- Improved multi-schema snapshot and comparison +- Improved SQL parsing +- Performance improvements +- Lots of bug fixes + +- [CORE-155] - Default-context attribute in databaseChangeLog tag +- [CORE-575] - foreign key constraint is generated with onUpdate and onDelete restrict +- [CORE-910] - Lock is not released if nocount is on for sql server 2008 +- [CORE-1166] - Diff doesn't detect 'on delete cascade' statements +- [CORE-1447] - Inconsistent line endings in updateSQL produced files +- [CORE-1468] - Number / Numeric handling must differ between different database systems +- [CORE-1679] - Changelog SQL routines are partially aware of Database quoting strategy +- [CORE-1690] - OSGiPackageScanClassResolver does not search extensions in Fragment bundles +- [CORE-1836] - Oracle Integer mapping +- [CORE-1839] - H2 multicolumn unique constraints +- [CORE-1883] - Performance issue with large datamodels +- [CORE-1887] - Including the same ChangeSet twice causes ValidationFailedException +- [CORE-1897] - stripComments from SQL is trimming quoted string +- [CORE-1935] - Formatted SQL generateChangeLog failed +- [CORE-1966] - Invalid object name 'INFORMATION_SCHEMA.SEQUENCES' when running generateChangeLog with SQL Azure +- [CORE-1985] - constraints tag is missing referencedTableSchemaName +- [CORE-2024] - Move SDK to its own module +- [CORE-2056] - generateChangeLog generates too many 'constraints' +- [CORE-2059] - escapeObjectName has no respect for quotingStrategy QUOTE_ONLY_RESERVED_WORDS on Postgres +- [CORE-2184] - diff doesn't write correct Changesets for foreign key constraints with ON DELETE CASCADE +- [CORE-2211] - Liquibase tries to execute commented lines in custom SQL file +- [CORE-2213] - Liquibase does not support comments in a line after the semicolon +- [CORE-2333] - loadData fails with quoted string containing a comma +- [CORE-2376] - LiquibaseCatalogName in commandLine not working correctly +- [CORE-2438] - DeleteGenerator does not handle parameter names and values with $ or \ properly +- [CORE-2456] - includeObjects/excludeObjects not work for UniqueConstraint +- [CORE-2474] - dropFirst does not drop objects in not default schemas on Postgres 9+ using sql format with multiple schemas +- [CORE-2483] - Liquibase does not delete unzip directories from temporary directory +- [CORE-2501] - Derby sequenceCurrentValue Incorrect SQL +- [CORE-2502] - Handle single-tag tag on diffChangeLog +- [CORE-2504] - NumberFormatException while checking precondition +- [CORE-2508] - GlobalConfiguration liquibase.should.run alias is incorrect +- [CORE-2512] - Both defautValueComputed and defaultValue included in addColumn diffChangeLog outputs if value is a computed value +- [CORE-2513] - DiffChangeLog fixing changed indexes misses "unique" attribute +- [CORE-2514] - bad Maven documentation for outputDefaultCatalog and outputDefaultSchema +- [CORE-2517] - Foreign key snapshot improvements for DB2 +- [CORE-2518] - DB2: snapshot sees DATE types as TIMESTAMP +- [CORE-2520] - Spurious warning with includeAll: file is not a recognized file type +- [CORE-2521] - addAutoIncrement on Postgres generates invalid SQL when specific schema is used +- [CORE-2522] - Derby: support for findForeignKeyConstraints +- [CORE-2523] - H2: use "REAL" as datatype for "FLOAT" +- [CORE-2524] - MSSQL: need to escape default value constraint names +- [CORE-2525] - Error on dropping sequence +- [CORE-2526] - Oracle 12: TIMESTAMP(3) not handled +- [CORE-2528] - Oracle: improve unique constraint snapshot query performance +- [CORE-2529] - MSSQL auto_increment numeric is 1 smaller in generateChangeLog +- [CORE-2531] - Wrong type mapping of BINARY type in MySQL, H2, HSQLDB and Postgresql +- [CORE-2533] - Poor runtime performance +- [CORE-2538] - regenerate maven documentation for liqubase on website +- [CORE-2545] - MSSQL: createProcedure fails if replaceIfExists=true and body uses "create proc" rather than "create procedure" +- [CORE-2547] - liquibase.database.core.DB2Database - Improper Resource Shutdown or Release +- [CORE-2548] - primaryKeyTablespace is ignored in PostgreSQL +- [CORE-2550] - Proper handling BINARY type in MySQL and H2 +- [CORE-2552] - Oracle performance: fetch view definition along with original view to reduce the number of needed queries +- [CORE-2553] - DB2: add ability to disable automatic reorg statements +- [CORE-2556] - Cannot execute update code including quoted strings containing semicolons +- [CORE-2558] - includeAll incorrectly sorting by including WEB-INF/classes when running in an ear +- [CORE-2561] - Add "cycle" attribute to alterSequence +- [CORE-2562] - MSSQL: Snapshot errors if table names have single quote marks in them +- [CORE-2563] - DiffChangeLog that adds columns does not preserve column order +- [CORE-2565] - Escaping of the sequence names with schema generates invalid statements for Oracle DB +- [CORE-2581] - mysql update emits incorrect sql for BIT(1) when default specified +- [CORE-2587] - Validation not performed before rollback +- [CORE-2591] - autoincrement problem with ORA 12c + COMPATIBLE param to 11 +- [CORE-2595] - DefaultPackageScanClassResolver fails if "fat" jar has dirs and files with same name +- [CORE-2599] - generateChangelog produces incorrect values for binary type +- [CORE-2601] - ORDER keyword isn't escaped for Oracle +- [CORE-2602] - StackOverflowError generating snapshot +- [CORE-2604] - PostgreSQL datatype bit(n) column gives BOOLEAN(n) type for CreateTableChange genearated sql statement +- [CORE-2605] - addColumn with multiple columns, does not create the constraints +- [CORE-2606] - PostgreSQL : Table creation with datatype smallserial fails. +- [CORE-2609] - Liquibase command line fails when using JTDS driver with SSO +- [CORE-2611] - Sybase ASE generated table name is wrong. Roll back CORE-2447 +- [CORE-2615] - Multi-schema snapshot bugfixes +- [CORE-2623] - Oracle: primary keys on tables recovered from recyclebin are not properly snapshotted +- [CORE-2624] - MSSQL: better support for user defined types +- [CORE-2625] - Diff: should not be case sensitive in column default value functions +- [CORE-2629] - SQL syntax doesn't allow commenting indepenrent parts. +- [CORE-2632] - Postgres index drop needs schema +- [CORE-2635] - Applied changeset not detected +- [CORE-2636] - includeAll uses full file path +- [CORE-2637] - Creating column with tinyint(1) instead created as default tinyint +- [CORE-2641] - runOnChange change set runs every time even if there wasn't changed +- [CORE-2642] - Xsd files are not resolved from classpath when resolving from resourceAccessor fails. +- [CORE-2643] - loadData +- [CORE-2645] - Rollback referencing a change set in current child file cannot be parsed +- [CORE-2653] - Liquibase show difference for some UniqueConstraint and Views in SQL SERVER databases but Actually there is NO difference when i compare the SQL scripts manually +- [CORE-2660] - Multiple contexts not recognized in formatted SQL when using AND +- [CORE-2662] - NumberFormatException with default values of type 'real' in postgresql +- [CORE-2663] - New MySQL 5.7.x reserved keywords are not being escaped +- [CORE-2664] - createChangeLog has incorrect nesting of constraints in YAML format +- [CORE-2666] - InsertSetGenerator hard-codes the InsertGenerator +- [CORE-2669] - Impossible to extend BaseLiquibaseTask in a non-deprecated way +- [CORE-2670] - Impossible to create table on mssql with remarks containing apostrophes +- [CORE-2671] - oracle timestamps with time zone +- [CORE-2672] - createSequence with order produces invalid statement on postgresql +- [CORE-2673] - includeAll relativeToChangelogFile doesn't work for FileSystemResourceAccessor +- [CORE-2674] - LoadUpdateData with onlyUpdate="true" generates invalid statements for Oracle DB +- [CORE-2677] - Dropping a postgres index fails +- [CORE-2679] - Hibernate diffChangeLog NullPointerException @ MissingPrimaryKeyChangeGenerator.fixMissing(MissingPrimaryKeyChangeGenerator.java:76) +- [CORE-2680] - Generating a futureRollbackSql when using "classpath:" prefix doesn't recognise any of the ran change sets. +- [CORE-2681] - H2 (automatic mixed mode): createTable: columns remarks ignored +- [CORE-2683] - dropAll dropping sequences that have been dropped via earlier cascade +- [CORE-2684] - Context is ignored with runOnChange and including file (sqlFile/loadUpdateData) +- [CORE-2686] - StandardChangeLogHistoryService.hasDatabaseChangeLogTable value is cached too aggressively +- [CORE-2687] - Oracle scripts with ending / are not actually getting executed even with splitStatements="false" +- [CORE-2699] - concurrency causes NullPointerException in DatabaseObjectComparatorFactory.getInstance() +- [CORE-2705] - diffChangeLog generates dropColumn when dropping an index with a computed column +- [CORE-2706] - Two sides of equal are the same +- [CORE-2709] - endDelimiter regexp problem +- [CORE-2711] - Cannot load CSV via loadData +- [CORE-2713] - CreateView disregards replaceIfExists=true when fullDefinition=true +- [CORE-2715] - tableExists and columnExists preconditions fail on MySQL +- [CORE-2718] - H2 Database should query for default schema instead always use PUBLIC +- [CORE-2719] - Oracle: Cannot snapshot primary keys on lower-case tables +- [CORE-2720] - DB2: Capture full view definition in snapshot/generateChangeLog to support column options +- [CORE-2721] - endDelimiter regex does not work in SQL changelogs/changesets +- [CORE-2725] - DB2: Don't include system-generated indexes +- [CORE-521] - Handle Timestamp with Time Zone types where supported +- [CORE-2448] - New "created" attribute on changeSet +- [CORE-2478] - Liquibase dropAll command line does not allow dropping multiple schemas +- [CORE-2540] - Allow vendor independent SEQUENCE definition +- [CORE-2541] - Add support for registering a Change Exec Listener on command line +- [CORE-2560] - Add new runOrder="first|last" attribute to control when a changeSet is ran +- [CORE-2577] - Add resourceComparator attribute to includeAll to override sorting +- [CORE-2578] - Added addUniqueConstraint deferrable"support for Postgresql +- [CORE-449] - Same changeLog can be included multiple times +- [CORE-1969] - Support for AND/OR context expressions in formatted sql +- [CORE-2100] - formatted sql validCheckSum +- [CORE-2115] - Really slow when using fat jars +- [CORE-2225] - please add the OLD check sum to the validation error message +- [CORE-2336] - Use a grammer for parsing SQL rather than regexps +- [CORE-2419] - Support fluent/builder-style change properties +- [CORE-2455] - Improve messages in databasechangelog.description column +- [CORE-2463] - Don't include liquibase tables in dbdoc +- [CORE-2493] - ExecuteShellCommand improvements +- [CORE-2497] - Support setColumnRemarks and setTableRemarks on MSSQL +- [CORE-2499] - Support for commenting lines in csv files +- [CORE-2539] - Ensure each data row in CSV has same # cols as header +- [CORE-2584] - ValidCheckSum is valid for both stored database values and current changeSet checksum +- [CORE-2589] - Output xml changelogs as xml version="1.1" +- [CORE-2612] - Oracle: include BYTE in CHAR and VARCHAR types from snapshot/generateChangeLog +- [CORE-2619] - Make changeLogFile optional for changeSetExecuted +- [CORE-2622] - Maven: Support ISO date syntax for rollback +- [CORE-2626] - Use schemaName in createProcedure +- [CORE-2638] - GenerateChangeLog should include replaceIfExists=true for changed views +- [CORE-2640] - Better handling of replaceIfExists in createProcedure +- [CORE-2651] - Derby: Default unknown version to 10.6 to support sequences +- [CORE-2652] - Formatted sql precondition not expanding changelog parameters +- [CORE-2657] - Add new DATABASECHANGELOG.DEPLOYMENT_ID column to track changeSets deployed together +- [CORE-2658] - Move the liquibase-debian module to a separate profile +- [CORE-2703] - MySQL NCLOB should conver to LONGTEXT CHARACTER SET utf8 +- [CORE-2724] - Support offline databases in ant-tasks + +Changes in version 3.4.2 (2015.11.24) + +- [CORE-2328] - AbstractExecutor should implement execute(Change) +- [CORE-2475] - Informix: Insert valueComputed not used correctly +- [CORE-2543] - Improved support for time stamps in oracle insert change data types +- [CORE-1778] - createSequence doesn't work on MSSQL +- [CORE-1840] - Liquibase fails when run on a computer that can't connect to the internet +- [CORE-2273] - Oracle char column snapshot not differentiating between a default value of 0 and '0' +- [CORE-2285] - Code in Liquibase class inconsistent +- [CORE-2317] - Custom ConfigurationValueProvider not working +- [CORE-2349] - loadUpdateData does not escape column names in "ON DUPLICATE" clause +- [CORE-2407] - Derby keywords not escaped when used as column/table names +- [CORE-2447] - In sybase, schema is bad preixed +- [CORE-2466] - Rollback referencing a change set in another file cannot be parsed +- [CORE-2467] - SSO with jtds MSSQL doesn't work after 3.3.5 for update - null user error +- [CORE-2469] - Error in method ColumnConfig.setValueNumeric(String) +- [CORE-2470] - MSSQL: FindForeignKeyConstraintsGeneratorMSSQL doesn't honor specified schema +- [CORE-2480] - Primary key exist works fine with 3.3.3 not with 3.4.0 in SQL SERVER +- [CORE-2481] - Primary key creation issue with informix +- [CORE-2482] - Number type issue with informix +- [CORE-2484] - dropAll command crashes because it drops sequences before tables +- [CORE-2487] - updateSql does not output anything for prepared statements +- [CORE-2490] - If you have more than one :name token in the where clause of a delete change, you get an Exception +- [CORE-2491] - Shouldn't a custom change produce a warning if run in updateSql mode +- [CORE-2492] - Logger extension liquibase-slf4j no longer usable with 3.4.1 +- [CORE-2494] - Pgsql: Exporting/generating badly formatted SQL +- [CORE-2498] - Generation of TIMESTAMP(29) causing error in PSQL log TIMESTAMP(6) WITHOUT TIME ZONE +- [CORE-2500] - Fast check of ColumnExistsPrecondition causing transaction abort on PostgreSQL database +- [CORE-2505] - Missing keywords for H2 database +- [CORE-2510] - loadData on MySQL with > 50 rows fails +- [CORE-2544] - LogFactory does not get reset +- [CORE-2549] - Performance regression in resolving local host +- [CORE-2554] - updateSql command fails on validation when upgrading (2.0.5 ->3.4.1) +- [CORE-2566] - Maven - setting skip= true does not work +- [CORE-2571] - primaryKeyExists precondition generating wrong query +- [CORE-2576] - The 'dbms' attribute on is not not taken into account when parsing changes +- [CORE-2579] - dropAll failed for Oracle 12c +- [CORE-2580] - Escape column, table and schema on ColumnExistsPrecondition +- [CORE-2588] - Bad cast +- [CORE-2590] - Default constraint names are not quoted +- [CORE-2596] - DatabaseChangeLogLock race condition exists if two nodes both try to create the table +- [CORE-2598] - Postgres generateChangeLog: "length for type varchar cannot exceed 10485760" + +Changes in version 3.4.1 (2015.07.28) + +- [CORE-998] - Changing index columns leads to wrong output order in the change log xml file. +- [CORE-2104] - ConcurrentModificationException iterating over System.getProperties().entrySet() +- [CORE-2385] - IncludeAll does not work when runing liquibase from inside a jar +- [CORE-2405] - Collation not preserved, depending on configuration +- [CORE-2406] - Escaped built-in data types should be lower case +- [CORE-2408] - Unknown column 'LABELS' in 'field list' +- [CORE-2410] - Snapshot should not include paramaters for MSSQL geometry, geography or sql_variant types +- [CORE-2411] - BLOB string default values not quoted +- [CORE-2412] - Handle Oracle BFILE types +- [CORE-2414] - CLONE - generateChangeLog creates DOUBLE(22) instead of double in MySql +- [CORE-2415] - Custom Logger configuration does not work anymore +- [CORE-2416] - Diff drops and creates primary keys for all tables +- [CORE-2418] - Liquibase 3.4.0 tries to do INSERT instead of UPDATE-Statements with Postgres +- [CORE-2421] - MySQL column sizes are off by 1 in BIGINT and INT for diffChangeLog +- [CORE-2422] - Liquibase intialisation failed +- [CORE-2423] - Sybase IQ : strange procedure called +- [CORE-2426] - Default schema name missing quotes. +- [CORE-2427] - Better handle MSSQL stored procedures with a different defaultSchema and replaceOnExists=true +- [CORE-2428] - liquibase 2.0.3 to 3.3.3 +- [CORE-2435] - includeSystemClasspath switch actually includes SystemClassLoader if false +- [CORE-2436] - Logging in ClassLoaderResourceAccessor prevents installation of custom Logger +- [CORE-2437] - Index.toString() contains "unique" if and only if index is NOT unique +- [CORE-2438] - DeleteGenerator does not handle parameter names and values with $ or \ properly +- [CORE-2440] - Not possible to override DefaultLogger using a Logger in a non-liquibase package. +- [CORE-2441] - Creation of foreign key fails in MySQL if database name contains dashes +- [CORE-2442] - Creating MD5 checksum fails if changeSet id contains the character "?" +- [CORE-2443] - Liquibase 3.4.0 ignores third party loggers in certain situations +- [CORE-2446] - endDelimiter splitting does not work in plain SQL files (regression) +- [CORE-2452] - Index names should be quoted on SQL Server +- [CORE-2458] - loadUpdateData will not update +- [CORE-2460] - Postgres index names cannot include schema name +- [CORE-2433] - quoting error in table creation +- [CORE-2359] - Consistently read dataTypeId for all databases +- [CORE-2419] - Support fluent/builder-style change properties +- [CORE-2449] - Correctly detect "Sybase IQ" +- [CORE-2450] - Non-bash /bin/sh gives "[[ not found" error +- [CORE-2451] - SQL scripts should have "USE " in the header on SQL Server +- [CORE-2453] - Informix: Return null for connection schema name +- [CORE-2459] - Un-change Formatted SQL stripComments default back to true +- [CORE-2461] - Don't do DATABASECHANGELOG ALTER statements if column types are different + +Changes in version 3.4.0 (2015.06.24) + +- [CORE-14] - Dropping default values with MS-SQL +- [CORE-822] - Add a tag to add/update table/column remarks +- [CORE-864] - loaddata performance enhancement +- [CORE-1411] - MariaDB support +- [CORE-2254] - Ability to save snapshot for later comparison +- [CORE-2257] - Ability to use a previously saved database snapshot in diff and generateChangeLog +- [CORE-2302] - Add ability to load nested object/collection properties and BigDecimal properties automatically +- [CORE-2306] - Support passing in a script for rollback to override rollback logic included in the changelog +- [CORE-2308] - Track changeSet contexts and labels in databasechangelog table +- [CORE-2345] - Add XML Type +- [CORE-419] - Allowing ASC and DESC in index definitions +- [CORE-562] - Allow naming of not null constraints +- [CORE-715] - indexExists does a full snapshot +- [CORE-1731] - Support autoincrement in oracle 12c +- [CORE-2124] - Ability to pass properties to a JDBC driver required +- [CORE-2132] - Error message for missing sqlFile reference should be more descriptive +- [CORE-2147] - HsqlDatabase should emit uppercase names when quoting reserved words to preserve case insensitivity +- [CORE-2171] - New ChangeExecListener.runFailed method +- [CORE-2177] - Support NOT(X) syntax for labels +- [CORE-2185] - Few fields needs to be changed as protected and need additional field in RanChangeSet +- [CORE-2217] - Add DataTypeFactory support for delimited data type names, improve resolution of MSSQL data types +- [CORE-2228] - New usingIndexName attribute on addPrimaryKey +- [CORE-2236] - Support .yml extension in YamlChangeLogSerializer +- [CORE-2244] - Handle generating SQL Server DDL where ANSI NULL Default is false +- [CORE-2249] - Index and UniqueConstraint equivalence check should take name into account +- [CORE-2288] - Do not check/updatedatabasechangelog table on status +- [CORE-2292] - New tagExists command for command line +- [CORE-2298] - Allow HSQL to use defaultValueComputed for certain allowed functions on datetime type columns +- [CORE-2299] - Add capability to ignore missing or empty folder with includeAll +- [CORE-2307] - ChangeLog table name option in command line tool +- [CORE-2309] - global/local properties on changesets +- [CORE-2320] - MinGW (Git Bash) support for shell +- [CORE-2334] - Disable CREATE TABLE DATABASECHANGELOG generation when running on OfflineConnection +- [CORE-2336] - Use a grammer for parsing SQL rather than regexps +- [CORE-2358] - Improve data types for Liquibase tables in MSSQL +- [CORE-2359] - Consistently read dataTypeId for all databases +- [CORE-2363] - Improve robustness of MSSQL database case-insensitivity check +- [CORE-2371] - Improve Oracle snapshot performance +- [CORE-2386] - Set the connection default catalog/schema if defaultCatalogName or defaultSchemaName is set +- [CORE-2397] - MSSQL View Snapshot should not use sp_helptext +- [CORE-2399] - DBDoc improvements +- [CORE-2404] - Ability to preserve TEXT type in mssql snapshot and update +- [CORE-842] - Tag database not taking orderexecuted into account +- [CORE-1296] - drop column on ms sql server +- [CORE-1424] - SQL Generation ignores DATETIME parameters +- [CORE-1542] - Sequence is dropped not until a second run of dropAllDatabaseObjects on PostgreSQL +- [CORE-1738] - loadData from csv fails for boolean column (if another column present) +- [CORE-1749] - Update change command does not respect whereParams +- [CORE-1803] - DropAll doesn't delete sequences if they are used as default value in postgres +- [CORE-1904] - Slow indexExists performance in Oracle +- [CORE-1924] - SQLServer diff - DATETIME2 not being handled correctly +- [CORE-2005] - /usr/bin/liquibase: Syntax error: "else" unexpected +- [CORE-2018] - Quotes stripped from index filter_conditions on snapshot +- [CORE-2019] - Comments in empty rollback prevent execution +- [CORE-2041] - Escaping of reserved keywords in HSQLDB +- [CORE-2096] - DiffChangeLog with changed indexes generates drop/add in the wrong order +- [CORE-2109] - dropAll fails for statements the database requires to run non-transactionally +- [CORE-2113] - Informix text datatype fixes +- [CORE-2133] - Oracle: GenerateChangeLog of a table with DEFAULT VALUE NULL creates defaultValueComputed="NULL" +- [CORE-2167] - Issues with generateChangeLog of unique constraints on DB2 +- [CORE-2169] - offline mode seems non-deterministic +- [CORE-2178] - Fatal exception acquiring lock in SQL Server databases with case-sensitive collation +- [CORE-2196] - Ant: "Unable to update database." without explanation +- [CORE-2209] - Oracle snapshot sometimes creates "GENERATED ALWAYS AS (null)" +- [CORE-2211] - Liquibase tries to execute commented lines in custom SQL file +- [CORE-2219] - DB2 for zOs - adding primary key always emits REORG but REORG does not exist on Db2 for zOs +- [CORE-2222] - TIMESTAMP parameters dropped for PostgreSQL +- [CORE-2224] - Index uniqueness is not always recognized correctly +- [CORE-2227] - CLONE - UpdateSQL needs to append a "/" to the end of createProcedure for Oracle +- [CORE-2232] - Support schema other than public on PostgreSQL +- [CORE-2233] - Oracle Timestamp precision lost in generateChangeLog +- [CORE-2234] - columnExists precondition could be much faster (Oracle, mssql) +- [CORE-2237] - YamlChangeLogSerializer does not correctly serialize a changeset +- [CORE-2251] - Adding column with type DATETIME doesn't work for PostgreSQL +- [CORE-2252] - XMLChangeLogSerializer writes array object for rollback tag content +- [CORE-2253] - Handle oracle varchar <-> clob conversions in diffChangeLog +- [CORE-2256] - Drop Sequences before Tables +- [CORE-2266] - DiffChangeLog: Invalid changelog when a primary key backing index is changed +- [CORE-2267] - Rollback fails for mixed-case objects created with QUOTE_ALL_OBJECTS +- [CORE-2270] - Doubledash inside quoted text causes parsing error +- [CORE-2271] - CLONE - DiffChangeLog: Invalid changelog when a unique constraint backing index is changed +- [CORE-2272] - DiffChangeLog must drop foreign keys before primary keys +- [CORE-2273] - Oracle char column snapshot not differentiating between a default value of 0 and '0' +- [CORE-2275] - YAML update fails with Unexpected error running Liquibase: java.util.LinkedHashMap cannot be cast to java.util.List +- [CORE-2281] - Oracle snapshot performance issue with many multiple views +- [CORE-2291] - ObjectQuotingStrategy not reset correctly after changeSet +- [CORE-2295] - includeAll tries to load all files instead only *.xml +- [CORE-2300] - Unsigned Int / Bigint cannot be created +- [CORE-2305] - Snapshot output too verbose +- [CORE-2316] - Data type registry occasionally returns wrong data type implementation +- [CORE-2321] - Liquibase tag command tags too much +- [CORE-2324] - diffChangeLog does not handle changes in sequence incrementBy, maxValue or ordered +- [CORE-2331] - Support for MSSQL collation in data type description broken +- [CORE-2340] - Add support for extensions to override the built-in change log, snapshot serializers +- [CORE-2355] - Improve updateSQL performance +- [CORE-2361] - preConditions, rollback, property, include, includeAll cannot be serialized +- [CORE-2373] - Local DTD files not found in subdirectory +- [CORE-2378] - Adding a new "CustomChange" triggers ClassNotFoundException +- [CORE-2380] - Support reading of gzip files +- [CORE-2381] - Fix unique constraint generator for informix +- [CORE-2383] - Change formatted SQL stripComments default from "true" to "false" +- [CORE-2385] - IncludeAll does not work when runing liquibase from inside a jar +- [CORE-2387] - dropPrimaryKey without constraint name on sql server doesn't query schema correctly +- [CORE-2388] - Views not equal in different schemas +- [CORE-2390] - NullPointerException when generating changelog +- [CORE-2391] - column type doesn't respect unsigned +- [CORE-2393] - changeSet contexts created with maven generateChangeLog are in parentheses +- [CORE-2401] - MSSQL handling timestamp according to sql standard, not sqlserver usage +- [CORE-2402] - Oracle NCLOB defaultValues not read correctly + + +Changes in version 3.3.5 (2015.05.28) + +- [CORE-2379] - Project.version set to 3.3.4-SNAPSHOT in 3.3.4 final + + +Changes in version 3.3.4 (2015.05.27) + +- [CORE-2360] - Maven - Skip is active by default +- [CORE-2199] - Liquibase adds a semicolon after a stored proc definition making the stored proc unusable +- [CORE-2344] - Unknown host exception on OS RHEL 6.5 +- [CORE-2346] - IncludeAll does not work when runing liquibase from inside a jar +- [CORE-2357] - alterSequence does not work as expected when you need to change the cache size +- [CORE-2366] - Derby Network server works with command line but not with maven "Liquibase skipped due to maven configuration" +- [CORE-2368] - No SQL outputted for change + +Changes in version 3.3.3 (2015.04.28) + +- [CORE-1768] - Oracle dropAll fails on spatial tables and sequences +- [CORE-1840] - Liquibase fails when run on a computer that can't connect to the internet +- [CORE-1857] - Wrong column size detection on varchar2 fields with char as datatype +- [CORE-1866] - Filtering changelog list by includeAll tag is not working +- [CORE-1943] - Handle Error: InetAddress.getLocalHost().getHostName() UnknownHostException results in NoClassDefFoundError +- [CORE-1958] - Column type of "TIMESTAMP(6)" under MySql converted to TIMESTAMP dropping fractional seconds +- [CORE-1967] - includeAll uses full file path for sql changelogs +- [CORE-2023] - Problem using includeAll with SpringLiquibase +- [CORE-2126] - Postgres 9.3 - Drop table With Cascade - Not Supported +- [CORE-2156] - Resource loader can't load changelog file +- [CORE-2186] - AbstractResourceAccessor#convertToPath(String, String) fails for processing includeAll from Classpath +- [CORE-2192] - NoSuchMethodException when generating offline Oracle migration script +- [CORE-2199] - Liquibase adds a semicolon after a stored proc definition making the stored proc unusable +- [CORE-2202] - liquibase.should.run inverted boolean +- [CORE-2204] - valueNumeric not being set when using prepared statements +- [CORE-2206] - diffChangeLog with JPA-annotated entities causes ConcurrentModificationException +- [CORE-2208] - Typo in message +- [CORE-2210] - java.lang.NullPointerException when file is empty +- [CORE-2214] - When inserting string value starting and ending with apostrophes (quotes) the value is not quoted in the generated SQL +- [CORE-2218] - Regression on modifyDataType : VARCHAR2 was supported on 3.2...and fails on 3.3 +- [CORE-2239] - Remarks attribute in renameColumn causes parse error +- [CORE-2240] - setDropFirst(true) still broken on empty database +- [CORE-2262] - 3.3.2 ant task dies on NPE in ChangeLogParameters +- [CORE-2263] - Index Snapshot - doesn't include upper cased name indexes when db is NOT case sensitive +- [CORE-2274] - Ant Upade Task does not consider changeLogFile correctly if it is contained in a JAR +- [CORE-2279] - Rollback fails in MS SQL 2008 using liquibase 3.3.2 +- [CORE-2284] - Creating a DatabaseChangeLog() results in NPE +- [CORE-2290] - Liquibase gives different results from Ant and the command line +- [CORE-2301] - Regression from 3.2.3 in mssql 2000 unsupported usage of varchar(max) and sys.extenden_properties +- [CORE-2304] - Autoincrement on type INT4 fails +- [CORE-2310] - IncludeAll Fails with Unknown Reason Error +- [CORE-2315] - NPE in CommandlineResourceAccessor +- [CORE-2325] - Liquibase - New versions break DB create +- [CORE-2329] - Escaped reserved keywords in HSQL are stored in lower case instead of upper case. +- [CORE-2330] - includeAll uses full file path with includeAll +- [CORE-2261] - UpdateSQL needs to append a "/" to the end of createProcedure for Oracle +- [CORE-2287] - Improve support for Groovy-based tests in Eclipse +- [CORE-2296] - Upgrade Groovy and Spock to maintained versions +- [CORE-2318] - Add support for converting BigDecimal objects to a SQL string via DataTypeFactory + +Changes in version 3.3.2 (2015.01.08) +- Support for ignoring objects in diffChangeLog and generateChangeLog +- Bugfixes + +- [CORE-875] - Ignore tables for diffs and generateChangelog +- [CORE-1877] - SQLOutput prints endDelimiter regexes +- [CORE-2114] - AddAutoIncrement on Postgres does not work when changes are applied on a specific schema +- [CORE-2141] - handling dependencies and WAR as classpath +- [CORE-2166] - SpringLiquibase: includeAll within jar causes SetupException +- [CORE-2172] - dropPrimaryKey without constraint name on sql server doesn't honour schema information +- [CORE-2174] - Bad exception handling in OracleDatabase.setConnection +- [CORE-2180] - NPE with bad name +- [CORE-2182] - ClassLoader leak due to shutdown hooks + + +Changes in version 3.3.1 (2014.12.08) +- IncludeAll bugfixes +- Performance improvements +- Datatype handling fixes +- Fix for JSON parsing +- Other bugfixes + +- [CORE-1920] - SpringLiqubase includeAll is not including files +- [CORE-2009] - ClassCastException when executing a custom task change (AntClassLoader problem) +- [CORE-2097] - "mvn liquibase:futureRollbackSQL" asks for tag, count or date +- [CORE-2099] - SQLAnywhere support (Driver not capable) +- [CORE-2103] - changelogSchemaName/changelogCatalogName configuration options will not work on Oracle DB +- [CORE-2104] - ConcurrentModificationException iterating over System.getProperties().entrySet() +- [CORE-2105] - Maven profile performing dropAll and update on Oracle failing with an error on populated database. +- [CORE-2107] - LOWER() keyword fails on Postgres createIndex task +- [CORE-2108] - dropAll command trying to drop column on table that has already been dropped +- [CORE-2114] - AddAutoIncrement on Postgres does not work when changes are applied on a specific schema +- [CORE-2116] - Could not find implementation of liquibase.logging.Logger +- [CORE-2118] - Change default diffChangeLog/generateChangeLog objectQuotingStrategy back to LEGACY +- [CORE-2119] - Bad finally block in SpringLiquibase.afterPropertiesSet() +- [CORE-2120] - LoadUpdateData with value=NUMERIC quoting values +- [CORE-2121] - DB2: DiffChangeLog/GenerateChangeLog/DropAll sees alias column and tries to drop/add them +- [CORE-2127] - updateSQL creates duplicate DATABASECHANGELOGLOCK tables +- [CORE-2130] - setFetchSize to a negative value breaks Oracle JDBC Driver +- [CORE-2134] - ExecuteCommand won't run with no os attribute. +- [CORE-2136] - Mysql must quote PARTITION as a keyword +- [CORE-2137] - Special characters ( ) copied during generateChangelog on DB2/400 +- [CORE-2139] - H2Database.supportsDropTableCascadeConstraints() returns false +- [CORE-2141] - handling dependencies and WAR as classpath +- [CORE-2142] - generateChangeLog not including all columns in a table +- [CORE-2146] - snakeyaml is pulled in as transitive dependency for using projects +- [CORE-2149] - Liquibase command line fails +- [CORE-2150] - On the 3.3.4.9.1, liquibase --version returns 3.2.0 +- [CORE-2153] - Liquibase 3.2.1 is no longer compatible with Oracle 9 +- [CORE-2155] - diffTypes=data fails with java.sql.SQLException: Attribute value not valid (dataOutputDirectory attribute causes build to fail) +- [CORE-2156] - Resource loader can't load changelog file +- [CORE-2157] - SQLException if there are single quotes in ChangeSet +- [CORE-2159] - Datetime2 no longer used for MSSQL +- [CORE-2161] - includeAll relativeToChangelogFile="true" doesn't work +- [CORE-2164] - SpringLiquibase: includeAll within jar causes NullPointerException +- [CORE-2115] - Really slow when using fat jars +- [CORE-2125] - Make DatabaseChangeLog#include(String, boolean, ResourceAccessor) public +- [CORE-2148] - Build failure on jdk-1.8 +- [CORE-2152] - Change logs in json format not processed by liquibase - parsing errors + +Changes in version 3.3.0 (2014.11.03) +- New "label" attribute on changeSet +- New empty and output change tags +- Support for clustered/nonclustered primary keys and indexes +- Saving of remarks in mysql and mssql +- Official RPM and DEB packages +- Refactoring/update of Ant integration + +- [CORE-16] - Support for nonclustered primary keys in mssql +- [CORE-54] - Support System Properties in Maven Plugin +- [CORE-1528] - Installer for Liquibase +- [CORE-1598] - support for rename sequence +- [CORE-1914] - New Change function: output +- [CORE-1942] - Support for changeSet labels +- [CORE-549] - relativeToChangelogFile for loadData, loadUpdateData, sqlFile +- [CORE-1438] - createView should support having the entire view definition in the change body +- [CORE-1502] - CLONE - UpdateSQL needs to append a \r/\n to the end of createProcedure for Oracle +- [CORE-1654] - logicalFilePath support in formatted sql +- [CORE-1660] - remarks attribute is ignored in MSSQL +- [CORE-1932] - support for encrypted passwords / custom properties +- [CORE-1946] - Have a rpm package for liquibase (built with maven) +- [CORE-1963] - Ability to define full CREATE VIEW statement in change. +- [CORE-1990] - Preserve inline comments in view snapshots in mssql +- [CORE-2060] - Support liquibase.properties files with unknown properties +- [CORE-2061] - Improvements to Informix support +- [CORE-2062] - Add onlyUpdate flag to loadUpdateData +- [CORE-2064] - Use ignoreClassPathPrefix for rollback as well +- [CORE-2065] - Use DOUBLE PRECISION for DOUBLE with Firebird +- [CORE-2066] - Support for outputFile in command line +- [CORE-2067] - Refactor Ant Task codebase +- [CORE-2068] - New liquibase.hostDescription property for additional details in the DATABASECHANGELOGLOCK table +- [CORE-2069] - Use prepared statement in change whenever a clob type is used +- [CORE-2072] - Do not include Oracle internal tables in snapshot/diff +- [CORE-870] - Postgres, in an ALTER TABLE ALTER COLUMN statement, sometimes needs USING clause +- [CORE-945] - Oracle : Temporary tables are created as regular tables +- [CORE-1463] - Views not generated correctly with generateChangelog +- [CORE-1556] - remarks attribute ignored for mysql +- [CORE-1723] - unable to update on DB2/400, version V6R1, on jt400-6.7.jar +- [CORE-1745] - afterColumn not working in MySQL +- [CORE-1774] - Autocommit not restored on close in SpringLiquibase +- [CORE-1882] - NullPointerException when MySQL foreign key points to an invalid table +- [CORE-1919] - SpringLiquibase fails when dropFirst is true +- [CORE-1922] - Sequence is not a reserved object name in HSQLDB +- [CORE-1925] - liquibase scripts can not represent clustered indexes +- [CORE-1937] - Oracle Float and VARCHAR precisions in changelog generated by generateChangeLog are incorrect +- [CORE-1952] - liquibase loadData does not properly load numeric field in boolean always as false +- [CORE-1956] - Double and float converted to FLOAT8(*, 17) and FLOAT4(*, 8) in PostgreSQL +- [CORE-1958] - Column type of TIMESTAMP(6) under MySql converted to TIMESTAMP dropping fractional seconds +- [CORE-1974] - dbchangelog-3.1.xsd missing +- [CORE-1977] - CreateSequence with cacheSize=0 failing on Oracle +- [CORE-1979] - MSSQL should not include parameters in SYSNAME data types +- [CORE-1981] - Parameters set in included file are no longer set in 3.2.0 +- [CORE-1982] - Snapshot outputs defautlValueDate as defaultValueComputed on MSSQL for dates not in ISO format with a T in the middle +- [CORE-1986] - includeAll from changeLogs within a jar is not working +- [CORE-1988] - Reported size for Oracle NVARCHAR2 columns is wrong +- [CORE-1993] - Drop table with cascade is not supported by Sybase +- [CORE-1996] - addNotNullConstraint on h2 database has unexpected side effects +- [CORE-1997] - Bit changelog default value of 1 executed as 0 +- [CORE-2002] - AbstractResourceAccessor generates path in a unpredictable way +- [CORE-2010] - Oracle data type SDO_GEOMETRY snapshotted as SDO_GEOMETRY(1) +- [CORE-2014] - applyToRollback property ignored when rollback changes are specified +- [CORE-2015] - DiffChangeLog writes to the wrong point in the file on windows if file uses \n not \r\n +- [CORE-2020] - Oracle default value current_timestamp converted to systimestamp +- [CORE-2021] - Column remarks not snapshotted in mssql +- [CORE-2026] - Oracle columns of type ANYDATA are snapshotted with a size +- [CORE-2028] - generateChangeLog on SQL Anywhere 11.0.1 throws DatabaseException Driver Not Capable +- [CORE-2032] - Snapshot incorrectly including clob/blob sizes on diff +- [CORE-2051] - Not quoting VIEW params with spaces when snapshotting +- [CORE-2054] - Add new 'computed' column attribute to differentiate between an actual column name and a function as a column +- [CORE-2063] - Fix for H2 autoincrement start with and increment by syntax +- [CORE-2070] - dropAllForeignKeyConstraints does not work on Firebird databases +- [CORE-2075] - generateChangelog generates bad definition for TIME type +- [CORE-2080] - Liquibase empty change not present in XSD version 3.2 +- [CORE-2081] - PrimaryKeyExists precondition without tableName is broken +- [CORE-2082] - Column snapshot on PostgreSQL does not include precision information for numeric data type +- [CORE-2087] - Executing against Oracle doesn't respect liquibaseSchemaName or liquibaseCatalogName +- [CORE-2088] - outputDefaultSchema and outputDefaultCatalog command line parameters not respected +- [CORE-2093] - Error: Property 'relativeToChangelogFile' not found on object type liquibase.change.core.LoadDataChange +- [CORE-2094] - Liquibase.dropAll() should reset the lock service +- [CORE-2095] - Invalid generated changeset for mysql bit with defaultValue 0 + +Changes in version 3.2.3 (2014.11.03) +- Bugfixes + +- [CORE-1919] - SpringLiquibase fails when dropFirst is true +- [CORE-1987] - 'mvn liquibase:diff' does not find any differences between databases +- [CORE-1988] - Reported size for Oracle NVARCHAR2 columns is wrong +- [CORE-1989] - Cannot set objectQuotingStrategy on root databaseChangeLog node +- [CORE-2002] - AbstractResourceAccessor generates path in a unpredictable way +- [CORE-2003] - Could not find implementation of liquibase.logging.Logger +- [CORE-2042] - If liquibase.jar is nested in another jar/war/ear, it fails to start with a 'cannot find implementation of liquibase.logging.Logger' error +- [CORE-2058] - Load/Update tags should use 'is null' not '= null' for null comparisons +- [CORE-2070] - dropAllForeignKeyConstraints does not work on Firebird databases +- [CORE-2075] - generateChangelog generates bad definition for TIME type +- [CORE-2080] - Liquibase 'empty' change not present in XSD version 3.2 +- [CORE-2065] - Use DOUBLE PRECISION for DOUBLE with Firebird +- [CORE-54] - Support System Properties in Maven Plugin + + +Changes in version 3.2.2 (2014.07.23) +- Fix for bug in checksum computation vs. 3.1.1 + +- [CORE-1938] - defaultValueNumeric="0" or defaultValue="0" is translated to 0.0 +- [CORE-1950] - Checksum validation failed after Liquibase upgrade (3.1.1 -> 3.2.0) +- [CORE-1959] - generateChangeLog without changeLogFile - better error message + +Changes in version 3.2.1 (2014.07.18) +- Fixes to checksums on valueNumeric, defaultValueNumeric fields +- Fixes to checksums on createProcuedure and sql changes +- Fixed null pointer exception performing a tag +- Fixes to Spring support +- Fixed issue handling changeSet with multiple comments +- Fix support for sqlFile tags in rollback +- Fixed sqlFile not using changelog parameters +- Other bug fixes + +- [CORE-1844] - bulkFetch of foreign keys on Oracle is very slow +- [CORE-1918] - Multiple comment blocks in changesets no longer works +- [CORE-1920] - SpringLiqubase includeAll is not including files +- [CORE-1922] - 3.2.0 Regression due to CORE-1721 +- [CORE-1923] - Error raised: Unknown Reason when doing tagging via command line +- [CORE-1930] - Snapshot command returns no information on MSSQL +- [CORE-1933] - [3.0.8 -> 3.2.0] pom.xml: 2Mb of superfluous dependencies +- [CORE-1934] - file path in databasechangelog is absoulte since liquibase 3.2.0 when using includeAll inside a jar +- [CORE-1936] - NullPointerException while diffing database against hibernate.cfg.xml +- [CORE-1938] - defaultValueNumeric="0" or defaultValue="0" is translated to 0.0 +- [CORE-1940] - Maximum Oracle Sequence fails to be parsed as a BigInteger +- [CORE-1944] - NullPointerException when tagging through Ant before applying changesets +- [CORE-1947] - Liquibase dependency to jetty-servlet/velocity should be true +- [CORE-1950] - Checksum validation failed after Liquibase upgrade (3.1.1 -> 3.2.0) +- [CORE-1957] - Using VARCHAR2 column type fails for Hsqldb running in oracle syntax mode +- [CORE-1960] - "Could not find implementation of liquibase.logging.Logger" starts appearing after migration from 3.1.1 to 3.2.0 +- [CORE-1970] - NullPointerException on rollback with tag +- [CORE-1746] - Support parameters +- [CORE-1951] - Regression on 3.2.0 : --diffTypes=data generates Unknown Reason Exception + +Changes in version 3.2.0 (2014.06.02) + +- Support for and/or/not logic in context expressions +- Better matching of default schemas in database comparisons +- Improvements to resource accessor logic +- Improved memory usage when diffing data +- Improved UTF8 usage +- Better handling if TIMESTAMP [WITH | WITHOUT] TIME ZONE datatypes in pgsql +- Standardization of parsing logic across XML/YAML and JSON +- New command line function: snapshot +- Start of SDK for easier Liquibase extension development and testing: +--- Database watch command +--- Standard "sdk workspace" +--- Beta version of database vagrant configurations +- Snapshot listener interface + +- [CORE-1742] - Standardized system for managing configuration options in core and extensions +- [CORE-1751] - More detailed API for returning changeSet statuses +- [CORE-1783] - Command line option: snapshot +- [CORE-1815] - Liquibase SDK command to easily watch database +- [CORE-1821] - Snapshot listener interface + +- [CORE-1116] - Allow for both "AND" and "OR" specifications of which contexts to run +- [CORE-1422] - Support changeset comments in formatted SQL +- [CORE-1536] - Support specifying the referenceDefaultSchemaName for diff operations +- [CORE-1635] - Generated changelog missing unique constraints should be output before foreign keys +- [CORE-1682] - More machine-independent handling of filesystem-located resources +- [CORE-1695] - Better handling of Postgres timestamp with/without time zone +- [CORE-1706] - Excessive reading from databasechangelog table +- [CORE-1726] - Added offline parameter to generate insert databasechangelog statements +- [CORE-1758] - Add outputDefaultSchema flags to ant +- [CORE-1776] - System-independent checksums +- [CORE-1823] - Search for liquibase.properties in classpath in additional to local filesystem +- [CORE-1874] - Improve XML and other parsers for better extensiblity +- [CORE-1905] - Yaml parser supports .yml extension as well as .yaml + +- [CORE-209] - Double Create Database Lock Table using updateSQL +- [CORE-421] - NPE in MySqlDatabaseSnapshot during diff operation when "enum" or "timestamp" column was removed from table +- [CORE-461] - Wrong datatypes for timestamps generated with generateChangeLog +- [CORE-871] - Unable to use changeSetPath in rollback tag to refer to another change log file +- [CORE-877] - Bug with column type "TIMESTAMP WITHOUT TIME ZONE" +- [CORE-976] - GenerateChangeLog with data: java heap space error +- [CORE-1097] - Liquibase adds a semicolon after a stored proc definition making the stored proc unusable +- [CORE-1108] - Oracle : Unable to create complex primary key for loadUpdateData +- [CORE-1284] - Memory leak in ExecutorService +- [CORE-1563] - dropAll does not delete Sequences on Derby +- [CORE-1572] - Regression: diff generates full schema instead of changes when using liquibase-hibernate4 +- [CORE-1578] - changeset checksum calculates differently on linux and windows +- [CORE-1601] - updateSql generates SQL with unexpected linefeeds, breaks SQLPlus +- [CORE-1642] - Special character issue after upgrade +- [CORE-1643] - DB2: defaultSchemaName and changelogSchemaName are not respected +- [CORE-1650] - dropAll doesn't work on Informix +- [CORE-1668] - defaultSchemaName ignored on createTable in H2 +- [CORE-1673] - Empty default value is not recorded for MySQL +- [CORE-1676] - Colons in changeSet IDs no longer supported +- [CORE-1688] - The 'valuum' extension seems not to be working under version 3.0.8 of liquibase +- [CORE-1701] - Oracle: snapshot of default date/time values come back as to_date functions +- [CORE-1714] - 2->3.1 migration error +- [CORE-1715] - 2 -> 3.1 migration, 3.1 errors if there are single quotes in comments +- [CORE-1718] - foreignKeyConstraintExists precondition fails with constraints on unique keys +- [CORE-1721] - HsqlDatabase.escapeObjectName(...) ignores QUOTE_ALL_OBJECTS +- [CORE-1727] - Drop default constraint syntax for DB2 not correct +- [CORE-1728] - Only sequence name is captured by snapshot process and used in generateChangeLog +- [CORE-1733] - Data in diffChangeLog coming through as one row per changeSet +- [CORE-1734] - updateSQL is not including content from sqlFile (at least not when ran from Linux) +- [CORE-1739] - Liquibase ignores Oracle varchar precision +- [CORE-1743] - Snapshot VARCHAR(MAX) correctly on sqlserver +- [CORE-1744] - Derby: UpdateSQL not including creating databasechangeloglock table if needed +- [CORE-1748] - Maven Plugin does not use outputDefaultCatalog property +- [CORE-1750] - liquibase-modify-column 3.0 broken with liquibase-core 3.1.1 +- [CORE-1752] - Oracle XML Datatype snapshot containing size +- [CORE-1753] - HSQLDB 1.8 does not support catalogs +- [CORE-1754] - Default value functions on Oracle snapshoted as "defaultValue" +- [CORE-1755] - DefaultValueComputed is quoted for Char, Varchar, Clob, MediumInt and SmallInt types +- [CORE-1756] - Oracle indexes with functions not returned correctly in generateChangeLog +- [CORE-1765] - Failed to drop a VIEW pointing on not existing table from another schema +- [CORE-1767] - Oracle snapshot not capturing all indexes +- [CORE-1772] - Informix cannot drop constraints +- [CORE-1774] - Autocommit not restored on close in SpringLiquibase +- [CORE-1775] - Informix error when creating primary key +- [CORE-1779] - User Defined Types Come back with Unnecessary Size specifier in diff +- [CORE-1782] - dropALL fails when tables are referenced by other tables in another schema +- [CORE-1784] - GenerateChangeLog with objects in multiple schemas returns objects from multiple schemas and empty createTable statements +- [CORE-1788] - dropAll does not work in not default schemas using postgresql +- [CORE-1794] - Drop index failing for sybase +- [CORE-1797] - Autoincrement on type Serial8 fails +- [CORE-1798] - Invalid type syntax in Informix for Int(10) and SMALLINT(5) and FRACTION(3) +- [CORE-1799] - Attempted recreation of DATABASECHANGELOG in informix +- [CORE-1817] - Foreign Key Constraints Built on Unique Constraints are not captured in generateChangeLog +- [CORE-1818] - SQL Server "smalldatetime" converted to "datetime" on update +- [CORE-1824] - GUID Default values not quoted correctly in MSSQL +- [CORE-1828] - sqlFile should fail when file does not exists +- [CORE-1831] - CREATE/DROP INDEX issue: Sybase ASE 15.7.0 +- [CORE-1834] - generateChangeLog creates DOUBLE(22) instead of double in MySql +- [CORE-1840] - Liquibase fails when run on a computer that can't connect to the internet +- [CORE-1843] - includeAll does not alphabetize classpath loaded files +- [CORE-1853] - Liquibase generates invalid SQL for 'character varying' type +- [CORE-1856] - Ability for Change classes to verify update and rollback succeeded +- [CORE-1859] - DataTypeFactory doesn't take database into account +- [CORE-1861] - MSSQLDatabase.isCaseSensitive() provides a wrong information +- [CORE-1878] - Maven plugin behaviour different than command line with the same parameters +- [CORE-1881] - Case sensitivity issue with tableExists precondition +- [CORE-1893] - type="DATETIME" in changelog is converted to TIMESTAMP in MySql +- [CORE-1899] - Non-existing referenced sql files doesn't report error +- [CORE-1901] - DropPrimaryKey - Fails in Postgres +- [CORE-1906] - Diff between objects in different named default schemas doesn't see them as the same object +- [CORE-1912] - Unit tests fail due to dependency on system time zone + +Changes in version 3.1.1 (2014.01.16) +Bug Fix release. Most critical bug is CORE-1704 + +- [CORE-1704] - Checksum errors for changeSets with createProcedure in 3.1.0 vs 3.0.x +- [CORE-1707] - TableRowCountGenerator shouldn't pass tableName as catalogName +- [CORE-1710] - Oracle: NUMBER data type size specification is deployed with a precision specifier even though precision isn't specified in the change log +- [CORE-1711] - rowCount doesn't work if only the tableName is given +- [CORE-1713] - liquibase.precondition.core.ForeignKeyExistsPrecondition exception +- [CORE-1715] - Errors if there are single quotes in comments +- [CORE-1709] - generateChangeLog returns tables created by Materialized Views as standard tables + +Changes in version 3.1.0 (2014.01.09) +- Major Changes: + Offline Datatabase Support + CreateProcedures supports external files and dbms attribute + New dropProcedure change + New tableIsEmpty precondition + New rowCount precondition + Mysql enum & set support + Mysql date/time/timestamp size parameter support + MSSQL 2012 sequence support + General Sybase & DB2 improvements + Change- and precondition- level callbacks in ChangeExecListener + Extensions can define custom XSDs and namespaces + Maven support for futureRollbackSql command + +- [CORE-1424] - SQL Generation ignores DATETIME parameters +- [CORE-1579] - DefaultPackageScanClassResolver should suppress LinkageErrors +- [CORE-1626] - createIndex does not work for function based indexes anymore +- [CORE-1659] - "dbms" attribute is ignored for "sql" tag inside "rollback" +- [CORE-1666] - CommandLineResourceAccessor throwing exception from getResourceAsStream() +- [CORE-1669] - DB2Database the method getDefaultCatalogName returns the defaultSchemaName. +- [CORE-1677] - Default Sybase schema name +- [CORE-1680] - DbDoc fails with NullPointerException +- [CORE-1685] - NPE at SchemaComparator +- [CORE-1692] - generateChangeLog does not handle sets correct +- [CORE-1693] - SqlCheck precondition's 'expectedResult' accounts for the amount of columns instead of the amount of rows +- [CORE-1696] - Syntax error in command line UNIX shell script +- [CORE-1698] - Add FormattedSQL support for comma separated list dbms attribute +- [CORE-1428] - Support Springs classpath*: prefix for includeAll +- [CORE-1458] - Maven support for futureRollbackSql +- [CORE-1473] - JSON/YAML support for onFail/onError and onFailMessage/onErrorMessage on preconditions +- [CORE-1474] - Support 'dbms' attribute on +- [CORE-1476] - Support reading unique constraints and sequences in DB2 for iSeries +- [CORE-1544] - liquibase-maven-plugin: diffChangeLog goal is missing +- [CORE-1638] - SnapshotGenerator extension system does not allow replacement of generators +- [CORE-1639] - Support foreignKeyConstraintExists precondition specifying table and columns instead of name +- [CORE-1656] - Extension to allow updateSql without a live database connection +- [CORE-1657] - Extension support for external DatabaseChangeLog tables +- [CORE-1663] - Support replaceIfExists for createView on H2 +- [CORE-1671] - Add millisecond precision Time, Timestamp, and DateTime for MySQL +- [CORE-1681] - Log change and precondition execution into the ChangeExecListener +- [CORE-641] - Support ${} params in included sql files +- [CORE-883] - updateSQL without database access +- [CORE-929] - Support for ordering of columns in addColumn +- [CORE-1310] - Support column remarks for mysql +- [CORE-1513] - tableIsEmpty precondition +- [CORE-1514] - rowCount precondition +- [CORE-1558] - Modify Liquibase to allow extensions to specify prefix for xml tags +- [CORE-1617] - dropProcedure change +- [CORE-1618] - Support defining createProcedure body in an external file +- [CORE-1661] - Add support for MSSQL sequences + +Changes in version 3.0.8 (2013.12.12) + +- Major Changes: + Improvements to data type handling + Bug fixes + Performance improvements + +- [CORE-1224] - Enum column types are not appropriately represented in the change log created by generateChangeLog +- [CORE-1299] - modifyDataType does not auto reorg on DB2 +- [CORE-1302] - MySQL syntax for autoincrement column with start value +- [CORE-1357] - Postgresql sequences create error in log files +- [CORE-1368] - Unable to recreate DB from generated change logs +- [CORE-1427] - Not generateChangeLog properly for INT2 type for Postgres +- [CORE-1430] - When I was in sybase database using liquibase create the index, reported "information_schema.constraints" not found error +- [CORE-1432] - Liquibase H2 InsertOrUpdateGeneratorH2 fails if primary key column name contains $ character +- [CORE-1446] - Liquibase changelog generation can add linefeed to defaultValueComputed if last column +- [CORE-1454] - Precondition negation does not seem to work +- [CORE-1455] - Value not taken into account when inserting data with YAML +- [CORE-1484] - very poor performance of dropAll on Oracle +- [CORE-1496] - Custom Change validation happening before being fully initialized +- [CORE-1531] - includeAll with relativeToChangeLogFile fails under certain conditions +- [CORE-1537] - Liquibase: diffChangeLog on DB2 performing out of order steps +- [CORE-1538] - diffChangeLog for DB2 injects invalid characters in xml +- [CORE-1540] - Call 'Reorg table' after modifyDataType on DB2 +- [CORE-1541] - Column type="LONGVARCHAR" fails +- [CORE-1545] - Oracle wrong LONG datatype declaration +- [CORE-1547] - CLONE - H2 (and other) support for BLOB and CLOB is incorrect +- [CORE-1548] - Oracle Data Type: DATE - defaultValueComputed should be defaultValue +- [CORE-1549] - Oracle Data Type: INTERVAL YEAR TO MONTH - returned at "INTERNAL(2) YEAR" +- [CORE-1550] - Oracle Data Type: NCLOB - Receive SQL error when specifying NCLOB size +- [CORE-1551] - Oracle Data Type: NCHAR +- [CORE-1552] - Oracle Data Type: NVARCHAR2 - Column sizing is wrong +- [CORE-1553] - dropDefaultValue does not work on SQL Server +- [CORE-1554] - dbDoc for Informix IDS +- [CORE-1555] - Oracle UID reserved word not detected +- [CORE-1557] - Mysql: BLOB type changes to LONGBLOB +- [CORE-1559] - Columns defined as "serial" are created as "int" without autoincrement in Postgres +- [CORE-1562] - update throws Recoverable Exception +- [CORE-1564] - Broken links in dbDoc +- [CORE-1566] - DB2 Datatype - DBCLOB, GRAPHIC, VARGRAPHIC doubling datatype size +- [CORE-1567] - DB2 Datatype - defaultValueComputed being used instead of defaultValue for DBCLOB, TIME, TIMESTAMP, DATE +- [CORE-1568] - DB2 Datatype - REAL and XML should not have datatype sizes +- [CORE-1571] - updateDatabase can't find a changelog +- [CORE-1572] - Regression: diff generates full schema instead of changes when using liquibase-hibernate4 +- [CORE-1580] - Mysql SET type not handled correctly +- [CORE-1581] - modifyDataType ignores additional info of newDataType +- [CORE-1582] - SQLServer datatype for TIMESTAMP +- [CORE-1583] - Wrong datatype with renameColumn +- [CORE-1584] - Unable do rollback not in transaction block +- [CORE-1586] - MySQL DataType - defaultValueComputed being injected into TIMESTAMP, VARBINARY, BINARY, YEAR +- [CORE-1587] - MySQL Datatype - VARBINARY vs LONGBLOB confusion +- [CORE-1588] - MySQL DataType - BIT size and default not captured on Snapshot +- [CORE-1589] - MySQL DataType - BLOB becomes LONGBLOB +- [CORE-1590] - MySQL DataType - DOUBLE sizing not persisted on snapshot +- [CORE-1591] - MySQL DataType - TIME not persisting seconds (getting hours and minutes..so I've got that going for me.) +- [CORE-1592] - MySQL DataType - TEXT converted to LONGTEXT +- [CORE-1594] - PostgreSQL 'bigserial' type is automatically converted to 'bigint' +- [CORE-1595] - Schema version incompatibility is logged as INFO instead of WARN +- [CORE-1596] - Liquibase 3.0.5 will not create tables in dbo schema in SQL Server +- [CORE-1597] - ORA-01000: maximum open cursors exceeded +- [CORE-1600] - "Collation" and "Lateral" are not escaped in Postgres (new reserved words in v9.3) +- [CORE-1602] - DatabaseException in changesets that include date fields with default values +- [CORE-1603] - MySQL Datatype - BIGINT, INT, MEDIUMINT, SMALLINT, TINYINT all "shaving" off sizes +- [CORE-1606] - MySQL - TEXT vs. LONGTEXT for diffChangeLog presents CLOB +- [CORE-1607] - MSSQL java.sql.Types.TIMESTAMP should map to DateTime +- [CORE-1610] - MSSQL - NTEXT type being snapshot with MSSQL driver default size parameter. +- [CORE-1611] - Avoid reverse DNS lookup with getLocalHost().getHostName(); +- [CORE-1612] - YAML/JSON changelogs not picking up "value" attribute on column configs +- [CORE-1614] - mysql case insensitive affects databasechangelog creation +- [CORE-1615] - Failed to drop default value in MSSQL +- [CORE-1616] - SQLFileChange uses too many file descriptors +- [CORE-1619] - MSSQL: preconditions treat object names in a case-sensitive way +- [CORE-1622] - Ant not respecting diffTypes=data +- [CORE-1623] - MSSQL: precondition primaryKeyExists doesn't work +- [CORE-1625] - H2 Blob Type support is incorrect +- [CORE-1626] - createIndex does not work for function based indexes anymore +- [CORE-1627] - Option 'diffTypes' does not accept type 'indexes' +- [CORE-1632] - It's impossible to setup Logger's log level with system property 'liquibase.defaultlogger.level' +- [CORE-1636] - Case sensitivity issue with tableExists precondition +- [CORE-1640] - foreignKeyExists precondition always failing +- [CORE-1641] - Add column with foreign key throws NPE +- [CORE-1644] - ValidationFailedException after update to 3.0.7 +- [CORE-1646] - Exception when comparing two schemas +- [CORE-1647] - Mysql enum default values not quoted +- [CORE-1648] - Mysql columns with colons and other special chars are not quoted +- [CORE-1664] - MSSQL. "DATE" type doesn't exist for MSSQL 2005 and 2000. +- [CORE-1382] - Allow to create DATABASECHANGELOG* tables in another schema +- [CORE-1546] - Schema-Support on Informix +- [CORE-1577] - Oracle tinyint, smallint, int being created as number(38,0) +- [CORE-1604] - Minor maven pom cleanups +- [CORE-1635] - Generated changelog missing unique constraints should be output before foreign keys + +Changes in version 3.0.7 (2013.10.24) + +- Major Changes: + Decreased memory usage, especially with large sql files + Fixed SQLite support + Improvements to data type handling, especially in MS SqlServer + +- [CORE-1509] - Memory improvements for large sqlFile files +- [CORE-1533] - Performance improvements in dropAll +- [CORE-1247] - [Sqlite] bad syntax in create table statements with single autoincrement primary key +- [CORE-1519] - Allow relative file paths for valueClobFile and valueBlobFile inserts/updates. +- [CORE-1275] - LoadData insert statements do not escape column names containing an open paren +- [CORE-1312] - Error when creating changelog tables +- [CORE-1399] - IncludeAll Failing when running in WAR files +- [CORE-1440] - Invalid Reorg table statement gets generated on DB2 +- [CORE-1504] - dbDoc should html-encode author names +- [CORE-1506] - updateSQL generates invalid SQL for oracle +- [CORE-1507] - dropAll fails with NullPointerException +- [CORE-1510] - Maven plugin fails to configure parameters within property file with trailing spaces, error message misleading +- [CORE-1511] - modifyDataType truncates enum values +- [CORE-1512] - Insert with valueClobFile fails with unicode encoding. +- [CORE-1515] - Liquibase MSSQL: Snapshot incorrectly injecting size for some datatypes +- [CORE-1516] - Liquibase MSSQL: Snapshot recording incorrect size for VARBINARY +- [CORE-1517] - Liquibase MSSQL: Autoincrement property of decimal datatype not supported +- [CORE-1518] - Liquibase MSSQL: Incorrect datatypes captured in the snapshot +- [CORE-1520] - Liquibase Snapshot: Default datetime is wrong +- [CORE-1521] - When generateChangeLog is run, objects do not always come back in a consistent order +- [CORE-1522] - PreparedStatement.setCharacterStream() not supported by Postgres JDBC driver. +- [CORE-1524] - Ant diff command running diffChangeLog +- [CORE-1525] - Liquibase MSSQL: Snapshot not capturing alter statements that add default values +- [CORE-1526] - Unicode string escaping in MSSQL +- [CORE-1530] - Column called VERSION is quoted in PostgreSQL +- [CORE-1531] - includeAll with relativeToChangeLogFile fails under certain conditions +- [CORE-1532] - NPE in ChangedIndexChangeGenerator +- [CORE-1534] - Single quotes in liquibase.bat causing issues + +Changes in version 3.0.6 (2013.10.08) + +- Major Changes: + Split out CDI code to a separate jar + Remove primary key on DATABASECHANGELOG and increased column sizes + Case sensitivity fixes + General bug fixes + +- [CORE-1485] - Extract CDI support into a separate module +- [CORE-602] - Increase the default size of the FILENAME column +- [CORE-1471] - Add support for Sybase IQ +- [CORE-1475] - Support entering password(s) interactively on the command line +- [CORE-1477] - Support overriding LockService changeLogWaitTime +- [CORE-1492] - DatabaseChangelog Description useless +- [CORE-1502] - CLONE - UpdateSQL needs to append a "/" to the end of createProcedure for Oracle +- [CORE-1088] - Derby fails to create databasechangelog tables +- [CORE-1093] - generateChangeLog fails on MSSQL with coalation CS on views named in lowerCase +- [CORE-1158] - Escaping of reserved keywords in HSQLDB +- [CORE-1170] - loadUpdateData sometimes needs / and sometimes not +- [CORE-1177] - Failure to write a change set to the DATABASECHANGELOG table still applies the change set +- [CORE-1325] - CDI injection does not work with openwebbeans +- [CORE-1343] - Include SQL file with relativeToChangelogFile doesn't work +- [CORE-1378] - Deploy fails on Glassfish +- [CORE-1409] - Package CDI support as a separate module +- [CORE-1436] - loadUpdateData does not escape apostrophes +- [CORE-1437] - Diff is case-sensitive on column names +- [CORE-1440] - Reorg Table gets called before table is created on DB2 +- [CORE-1441] - Drop table with cascade does not work on MS SQL Server +- [CORE-1443] - Documentation for liquibase maven logging configuration needs update +- [CORE-1445] - Mysql Reserved Words Not quoted +- [CORE-1449] - Liquibase throws null pointer if included file does not exist +- [CORE-1464] - SQL changelog are not correctly handled (NPE) +- [CORE-1465] - GetViewDefinitionGeneratorMSSQL generates UPPER case view name +- [CORE-1469] - GenerateChangelog not working on Firebird +- [CORE-1470] - Use NUMERIC instead of NUMBER for Sybase ASE +- [CORE-1478] - MySQL keywords `key' not quoted as a column name +- [CORE-1479] - MySQL 5.5.27 fails to create DATABASECHANGELOG table (Liquibase support fully broken) +- [CORE-1480] - ChangedPrimaryKeyChangeGenerator missing name +- [CORE-1481] - Schema.toString NPE +- [CORE-1482] - Update fails with "Table DATABASECHANGELOGLOCK already exists" +- [CORE-1483] - Boolean values of "false" being incorrectly handled +- [CORE-1488] - Encoding issue with UpdateSQL +- [CORE-1490] - Oracle 10g: Changelog generation changes type NUMBER(*,0) to NUMBER(22) +- [CORE-1491] - Oracle 10g: changelog generation converts VARCHAR2(n CHAR) to VARCHAR2(n BYTE) +- [CORE-1497] - SQL SERVER: sysdiagram table is captured during generateChangeLog if system diagrams are enabled. +- [CORE-1499] - null appearing in liquibase maven output +- [CORE-1500] - Snapshots do not order objects alphabetically +- [CORE-1501] - Incorrect SQL generated for default column value in PostgreSQL for text columns +- [CORE-1448] - Throw a more helpful error message and continue on if snakeyaml isn't in the classpath +- [CORE-1472] - Support multi-tenant spring applications + +Changes in version 3.0.5 (2013.09.24) +- Major Focus: Performance Improvements +- [CORE-1453] - Multi-column foreign keys not snapshotted correctly +- [CORE-845] - "DATE" data type is deployed as "SMALLDATETIME" in SQL 2008 +- [CORE-859] - Nullable TIMESTAMP columns in MySQL are not nullable. +- [CORE-1257] - Oracle: generateChangeLog exports a column of type "NUMBER" as "NUMBER(0,-127)" +- [CORE-1288] - H2 (and other) support for BLOB and CLOB is incorrect +- [CORE-1338] - Using apostrophe in changeset's ID causes SQL error +- [CORE-1360] - Confirmation message of a custom change change is only printed if loglevel is debug +- [CORE-1364] - SQL Server incorrect INFORMATION_SCHEMA table case in native query +- [CORE-1365] - SQL Server: "Database 'dbo' does not exist" error +- [CORE-1401] - Unnecessary snapshot on liquibase update +- [CORE-1415] - Liquibase tables are not detected in oracle running in the SYSTEM schema +- [CORE-1426] - ORACLE: Check for existing tables is case sensitive +- [CORE-1429] - Random order of UniqueConstraint and ForeignKey drop statements +- [CORE-1459] - Maven updateSQL creates databasechangelog table, should only output SQL to do it +- [CORE-1462] - renameColumn with 'text' data type improperly trying to use 'clob' against MySql +- [CORE-1433] - Handle changes in column datatypes in diffChangeLog +- [CORE-1434] - Formatted Changelog format not parsing UTF8 .sql files with BOM + +Changes in version 3.0.4 (2013.09.06) +- [CORE-548] - GenerateChangeLog generates invalid XML/SQL for mysql tables with autoincrement and compound PKs +- [CORE-1423] - NPE in ForeignKeyComparator + +Changes in version 3.0.3 (2013.08.29) +- [CORE-1241] - Remove schema name from SQL generated when running updateSQL +- [CORE-1412] - UpdateSQL should write to stdout not stderr +- [CORE-844] - Integer with range limitations handled incorrectly on Oracle +- [CORE-1313] - Unique constraint name is ignored when adding a column +- [CORE-1316] - Column Type COMPUTED in loadData is not implemented correctly (shoud pass a DB Function instead of String to DB). +- [CORE-1327] - renameColumn and renameTable with Sybase +- [CORE-1329] - GenerateChangeLog on MSSQL exports a SMALLINT(5) - smallint does not allow precision +- [CORE-1336] - AutoIncrement not working with some types +- [CORE-1351] - PostgreSql 9 doesnt have datetime data type +- [CORE-1353] - AutoIncrement not working for numeric types +- [CORE-1354] - Sequences get dropped too early +- [CORE-1356] - Unnecessary size specifications on MEDIUMTEXT, TINYTEXT, MEDIUMBLOB, TINYBLOB from generateChangeLog +- [CORE-1358] - LiquiBase 3.0.2 writes '3.0.0-SNP' (Snapshot) to 'LIQUIBASE' column instead of '3.0.2' +- [CORE-1362] - Informix fails when schema is not equal catalog +- [CORE-1363] - ForeignKey NPE during dbDoc generation +- [CORE-1364] - SQL Server incorrect INFORMATION_SCHEMA table case in native query +- [CORE-1366] - Oracle database dbDoc generation performance issues +- [CORE-1367] - updateSQL generates an empty file using standard output in 3 version +- [CORE-1369] - Whitespace in author in SQL formatted changelog causes that migration to be silently skipped +- [CORE-1370] - Oracle doesnt have DATETIME datatype +- [CORE-1371] - MySQL syntax error is thrown if schema name contains hyphens +- [CORE-1372] - Version Command Line Argument Incorrect +- [CORE-1373] - dropAll attempts to drop objects in other schemas under Oracle +- [CORE-1375] - "group" is not included as a reserved word +- [CORE-1377] - liquibase version says 3.0.0-SNP +- [CORE-1380] - ^M present in liquibase unix running file (from jar on maven repo) +- - - - - [CORE-1381] - DropAll: Not working with MsSql +- - [CORE-1383] - Error attempting to re-create databasechangeloglock on second liquibase run if running in Oracle under SYSTEM user +- [CORE-1387] - dropAll fails with oracle since version 3.0.2 +- [CORE-1388] - MSSQLServer: 'REAL' dataype is returned with unnecessary size modifier during generateChangeLog +- [CORE-1389] - AddLookupTable fails when using QUOTE_ALL_OBJECTS +- [CORE-1394] - additionalInformation lost in DataTypeFactory.fromDescription() +- [CORE-1395] - Bug in MSSQLDatabase.getViewDefinition() +- [CORE-1396] - Liquibase is loosing indices on foreign key columns +- [CORE-1397] - Informix DB: Size of VARCHAR more than 255 +- [CORE-1398] - Missing or unexpected unique constraint not found on Postgres +- [CORE-1402] - Custom preconditions not passing XML validation +- [CORE-1403] - Default schema not correct when using +- [CORE-1405] - SpringLiquibase not closing connection if rollback exception +- [CORE-1406] - MySQL loadUpdateData using literal values for update +- [CORE-1408] - NVarcharType on Derby Fails +- [CORE-1413] - NPE in changeSetExecuted precondition in changelog-level preconditions +- [CORE-1414] - Improve error handling in empty databasechangeloglock tables +- [CORE-1417] - generateChangeLog failed +- [CORE-1418] - Foreign Key changes not detected in snapshot process + +Changes in version 3.0.2 (2013.07.11) +- [CORE-628] - Specify the output encoding that liquibase should use to output data in Maven +- [CORE-169] - Oracle TIMESTAMPS not exported correctly +- [CORE-1301] - defaultschemaName not used +- [CORE-1315] - Database Objects do not get dropped on DB2 +- [CORE-1317] - Not all FK Constraints get dropped on Oracle +- [CORE-1318] - Not all FK Constraints get dropped on SQL Server +- [CORE-1328] - includeAll trying to process invalid file types, should only process valid change log types +- [CORE-1331] - If logicalFilePath attribute is set on databaseChangeLog, I am unable to use relativeToChangelogFile="true" on +- [CORE-1332] - includeAll of changelog files throws duplicate identifiers error +- [CORE-1335] - Data export support broken in 3.0 +- [CORE-1336] - AutoIncrement not working with some types +- [CORE-1337] - Problem with changeset defined as runAlways="true" +- [CORE-1339] - NPE on update if default ServiceLocator.packagesToScan is used +- [CORE-1340] - indexExists Changesets throwing PreconditionErrorException instead of PreconditionFailedException +- [CORE-1341] - foreignKeyConstraintExists precondition broken +- [CORE-1347] - dropAll function work incorrectly when table has 2 foreign keys + +Changes in version 3.0.1 (2013.06.25) +- [CORE-898] - Custom precondition xsd failing +- [CORE-1171] - Maven plugin displaying password in plain text +- [CORE-1320] - Cannot include YAML file +- [CORE-1323] - Conversion from char to SMALLINT is unsupported +- [CORE-1324] - Formatted SQL does not support contexts such as "some-context" or "some/context" + +Changes in version 3.0.0 (2013.06.17) +- Dropped Java 1.5 support +- Major changes in diff and snapshot log +- Support for "catalogs" in addition to schemas +- Separated "diff" and "snapshot" logic for better modularity +- Extension support for LockService +- Extension support for defining new DataTypes +- Extension support for defining new snapshot DatabaseObjects +- Extension support for defining new Snapshot log +- Extension support for how to compare DatabaseObjects +- Better extension support for changelog generation +- More object types are snapshotted +- Changes can provide metadata helpful for IDE and other integrations +- Added ability for objects to control how they are serialized via the LiquibaseSerializable interface +- Can define tablespace for liquibase tables +- Performance improvements +- Ability to specify sequences to read values from on +- Improve OSGi support +- Support preconditions in formatted SQL +- Maven supports generateChangeLog +- Better support for case sensitive databases +- API cleanup +- Ability to SKIP columns in a CSV file +- Improved Informix support +- Support JDBC escape syntax in SQL +- Added futureRollbackCountSQL +- Support ${} params in formatted SQL +- Many bug fixes + +Change in version 2.0.5 (2012.05.01) https://liquibase.jira.com/secure/ReleaseNote.jspa?projectId=10020&version=10360 +---------------------- +- Reverted load blog/clob data from files feature +- Fixed linux distribution script +- Fixed command line output back to stdout + +Change in version 2.0.4 (2012.04.18) https://liquibase.jira.com/secure/ReleaseNote.jspa?projectId=10020&version=10160 +---------------------- +- Support ${} params in included sql files +- Ability to load blog/clob data from files +- Bug Fixes + + +Change in version 2.0.2 (2011.09.15) +---------------------- +- dropFirst parameter on SpringLiquibase bean +- Bug Fixes + +Change in version 2.0.0 (2010.12.19) +---------------------- +- Major change to codebase, focusing on extension/integration APIs + +Changes in version 1.9.3 (2009.4.3) +---------------------- +- Fixed index column nested tags in generated XML + +Changes in version 1.9.2 (2009.4.6) +---------------------- +- Fix for includeAll on windows +- Other bug fixes + +Changes in version 1.9.1 (2009.2.20) +---------------------- +- Escape hsql tables/columns if they are a keyword +- opensvn is included in our jar, not a dependency +- Bug in runInTransaction +- Additional bug fixes +- Grails 1.1-SNAPSHOT support + +Changes in version 1.9.0 (2009.1.7) +---------------------- +- Paths in can be relative to changelog +- Sybase Adaptive SQL Anywhere support +- Better Derby support (drop column, rename column) +- support +- change +- support +- runInTransaction attribute for changeSet +- Stronger validation in .xsd +- Bug fixes + +Changes in version 1.8.1 (2008.10.1) +---------------------- +- Bug fixes + +Changes in version 1.8.0 (2008.09.17) +---------------------- +- Added SQLite support +- Bug fixes +- Added dropAllForeignKeyConstraints change +- Added onFail and onError precondition failure controls +- Auto-increment specifying on a non-auto-increment table does not fail but simply ignores flag +- Can control onDelete and onUpdate behavior for FK constraints +- Added ability to specify that an index should be unique +- Additional validation step checks for required attributes at run time +- Improved ordering of generated scripts with diff +- Improved command line migrator return codes +- Context checking is case insensitive +- Can specify end delimiter in change +- Added several new precondition checks +- Custom preconditions can be passed parameters + +Changes in version 1.7.0 (2008.06.25) +---------------------- +- Added loadData change +- Added support for changelog paramters +- Allow preconditions in +- Can export data with generateChangeLog +- Added markNextChangeSetRan command +- Added validCheckSum tag to changeSet +- Can use change tags in +- Can reference previous changeSets in +- Allow custom preconditions +- RowMapper interface is now public +- Misc bug fixes + +Changes in version 1.6.1 (2008.04.23) +---------------------- +- Maven/Grails/IntlliJ Plugin relase of 1.6.x +- Many misc bug fixes + +Changes in version 1.6.0 (2008.03.27) +---------------------- +- Added Hibernate diff support +- Fix to MD5Sum generation that requires updating all rows in databasechangelog table +- Added tagDatabase tag +- Added primaryKeyName attribute +- Supports multiple rollback tags per changeSet +- Column remarks stored in generated changelogs +- executeCommand output logged to logging system +- Many misc bug fixes + +Changes in version 1.5.3 (2008.02.28) +---------------------- +- Recompiled to work with Java 1.5 + +Changes in version 1.5.2 (2008.02.07) +---------------------- +- Fixed bug with runOnChange and MD5sum check +- Handles generating changelog for tables with composite primary keys +- Other minor bug fixes + +Changes in version 1.5.1 (2008.02.01) +---------------------- +- Fixed failOnError logic +- Improved serial column detection in Postgres +- Rollback connections before close for DB2 +- Other minor bug fixes + +Changes in version 1.5.0 (2008.01.29) +---------------------- +- Major Refactoring of XML parser and Migrator/Liquibase class +- Database table comments saved to generated change log +- ReplaceIfExists attribute added to createView +- Setting value/valueNumeric/valueBoolean/valueDate on addColumn will update all existing rows with the given value +- Added defaultSchemaName parameter for setting default schema +- Changelog file comparisons are case-insensitive on windows +- Output warning of old schema version +- Added updateCount and updateCountSQL commands +- Changed "migrate" command to "update". Note: "migrate" is now an alias for "update" +- Added comments tag to generated SQL output +- Custom Database implementations can be specified with the databaseClassName parameter +- Created changeLogSync command +- Rollback commands can specify contexts +- createTable can specify unique constraint name +- XSDs are not pulled from network +- Handles Postgres datatypes better +- added change +- added change +- Additional and enhanced Ant tasks +- Changed database.migrator.should.run system property to liquibase.should.run +- Moved liquibase.servlet.MigratorStatusServlet to liquibase.servlet.LiquibaseStatusServlet +- Moved liquibase.servlet.ServletMigrator to liquibase.servlet.LiquibaseServletListener +- Moved liquibase.spring.SpringMigrator to liquibase.spring.SpringLiquibase +- Moved liquibase.commandline.CommandLineMigrator to liquibase.commandline.Main +- Renamed checked servlet listener parameters +- Other bug fixes + +Changes in version 1.4.1 (2007.11.30) +---------------------- +- Bug fixes + +Changes in version 1.4.0 (2007.11.19) +---------------------- +- IntelliJ Plug-in Support +- Added support for specifying schemas in change log +- MaxDB/SAPDB Support +- Refactored Code +- Can specify data types as java.sql.Types.* +- Support for composite foreign keys +- Improved Maven support +- Bug Fixes + +Changes in version 1.3.2 (2007.10.8) +---------------------- +- Grails support +- Firebird support + +Changes in version 1.3.1 (2007.10.2) +---------------------- +- Bug fix for createStoredProcedure in Oracle + +Changes in version 1.3.0 (2007.9.27) +---------------------- +- Added tablespace support to createTable, createIndex, addPrimaryKey, and addUniqueConstraint +- Restored Java 6 Support +- Added defaultCascade attribute to addForeignKeyConstraint +- Can have multiple comma-separated contexts per change set +- Created change +- Added sqlCheck precondition +- Database Diff checks column types and nullability +- DiffChangeLog will write to a file specified with the --changeLog flag +- Added dbdoc documentation generator +- Database Diff checks views +- Package re-organization +- Added createProcedure change +- Added change +- Table names are enclosed in []'s on MS SQL +- Added Spring migrator +- Misc bug fixes + +Changes in version 1.2.1 (2007.8.31) +---------------------- +- Include sequences in generateChangeLog +- Fixed ordering of statements default and null clauses based on database + +Changes in version 1.2 (2007.8.28) +---------------------- +- Added support for H2 database +- Added support for InterSystems Cache` database +- Support for sqlfile change +- Improved error messages +- Sybase fixes +- Handle --defaultsFile correctly +- Handle command line parameters correctly on Windows systems +- tag can contain a tag +- Change log file references can be absolute +- SQL can be ; or 'go' delimited +- Added clearCheckSums command +- Bug fixes + +Changes in version 1.1.1 (2007.7.24) +----------------------------------- +- Bug fixes related to the diff tool + +Changes in version 1.1 (2007.7.23) +----------------------------------- +- Support for additional databases: DB2, Derby, Sybase (not fully tested), and HSQL +- Support for "unsupported" databases +- Database Diff Tool +- Database Creation Script Generator +- new DBMS attribute on change set tag that allows you to specify what databases to run the change set against +- "verify" command that checks for change log problems without attempting to execute any +- "status" command that shows information on unrun change sets +- Handle date/time and numeric values better on inserts and setting default values +- Bug Fixes + +Changes in version 1.0.1 (2007.7.07) +------------------------------------ +- Do not quote "null" default values +- Documentation fixes + +Changes in version 1.0 (2007.6.25) +------------------------------------ +- Minor Bug Fixes + +Changes in version 1.0 RC2 (2007.6.19) +------------------------------------ +- Improved documentation +- Bug fixes +- Changes to exception throwing + +Changes in version 1.0 RC1 (2007.6.8) +------------------------------------ +- Added batch/shell scripts for command line migrator +- Improved documentation +- Bug fixes +- Blog started at http://blog.liquibase.org + +Changes in version 0.9.1 (2007.5.23) +------------------------------------ +- Bug fixes + +Changes in version 0.9.0 (2007.5.14) +------------------------------------ +- Rollback support +- Initial Maven support +- Performance improvements +- Can have a logical file and path for changelogs +- New Database Refactorings: + - Add View + - Rename View + - Drop View + - Merge Columns + - Add Foreign-Key Constraint + - Drop Foreign-Key Constraint + - Add Lookup Table + - Add Primary Key + - Add Auto-Increment + - Add Default Value + - Drop Default Value + - Drop Primary Key + - Add Unique Constraint + - Drop Unique Constraint +- Code refactorings + +Changes in version 0.8.2 (2007.4.30) +------------------------------------- +- Bug fixes + +Changes in version 0.8.1 (2007.4.25) +------------------------------------- +- Prompting for non-local database is now false by default +- Ant non-local database prompt attribute changed to promptOnNonLocalDatabase from promptOnNonDevDatabase +- Bug Fixes + + +Changes in version 0.8.0 (2007.4.22) +------------------------------------- +- Changelog Pre-conditions +- Execution contexts +- failOnError tag for changeSets +- addNotNullConstraint / dropNotNullConstraint +- allow "comment" tags +- Improved documentation +- Completed conversion to SourceForge +- Improved automated tests + + +Changes in version 0.7.0 (2007.3.16) +------------------------------------- +- Changed MD5Sum logic. !! Need to run 'update databasechangelog set md5sum=null' !! +- Added support for autoIncrement columns in createTableChange +- Switched to Liquibase name, including all package structures +- Moved code to SourceForge + + +Changes in version 0.6.3 (2007.1.10) +-------------------------------------- +- Fixed bug in create table refactoring where it ignored constraint clauses + +Changes in version 0.6.2 (2006.12.19) +-------------------------------------- +- Fixed missing non-upper cased insert statement + +Changes in version 0.6.1 (2006.12.12) +-------------------------------------- +- Classpath for command line migrator can now include .ear files +- Can specify a "database.migrator.should.run" system property that blocks the migrator from running if set to "false" +- Added a liquibase.migrator.servlet.MigratorStatusServlet servlet that can used to see the migrator logs +- Added a MIGRATOR_FAIL_ON_ERROR web.xml context parameter that controls if an exception should be raised if an exception is thrown, or if the listener should just return. Throws an exception by default +- All database SQL is upper case. +- Fixed issues with postgres schemas and getTables() call +- Added retroweaver build for 1.4 JVMs +- Misc. Bug fixes + +Changes in version 0.6 (2006.11.10) +-------------------------------------- +- Added change log locking support, so multiple migrators running at the same time won't interfere with eachother +- Fixed bug with command line parsing and URLs with '='s in them +- Misc bug fixes + +Changes in version 0.5.1 (2006.10.18) +-------------------------------------- +- Bugfixes related to running ant task + +Changes in version 0.5 (2006.10.16) +-------------------------------------- +- LGPL Licence +- Oracle uses Timestamp for datetime columns +- Command line migrator can be run against WAR and EAR files +- Command line migrator can be run via java -jar +- ChangeSets can be marked as "runAlways" and "runOnChange" +- ServletListener can be configured to only run on certain hostnames +- Removed all dependencies +- Improved MD5Sum generation. To update your MD5Sums, run "update databasechangelog set md5sum=null" +- MySQL Support +- Misc bugfixes +- Improved Documentation diff --git a/liquibase-4.9.1/db/changelog/db.changelog-master.xml b/liquibase-4.9.1/db/changelog/db.changelog-master.xml new file mode 100644 index 0000000..ce01d12 --- /dev/null +++ b/liquibase-4.9.1/db/changelog/db.changelog-master.xml @@ -0,0 +1,10 @@ + + + + + + + \ No newline at end of file diff --git a/liquibase-4.9.1/db/changelog/liquibase.properties b/liquibase-4.9.1/db/changelog/liquibase.properties new file mode 100644 index 0000000..fdf288b --- /dev/null +++ b/liquibase-4.9.1/db/changelog/liquibase.properties @@ -0,0 +1,5 @@ +url=jdbc:postgresql://localhost:5432/liquibase_example +username=postgres +password= +changeLogFile=db/changelog/db.changelog-master.xml +liquibase.hub.mode=off \ No newline at end of file diff --git a/liquibase-4.9.1/db/changelog/v.1.0.0/create-table.xml b/liquibase-4.9.1/db/changelog/v.1.0.0/create-table.xml new file mode 100644 index 0000000..8d24881 --- /dev/null +++ b/liquibase-4.9.1/db/changelog/v.1.0.0/create-table.xml @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/liquibase-4.9.1/db/changelog/v.1.0.0/cumulative-changelog.xml b/liquibase-4.9.1/db/changelog/v.1.0.0/cumulative-changelog.xml new file mode 100644 index 0000000..4059715 --- /dev/null +++ b/liquibase-4.9.1/db/changelog/v.1.0.0/cumulative-changelog.xml @@ -0,0 +1,13 @@ + + + + + + + + + + \ No newline at end of file diff --git a/liquibase-4.9.1/db/changelog/v.2.0.0/create-table-hero.xml b/liquibase-4.9.1/db/changelog/v.2.0.0/create-table-hero.xml new file mode 100644 index 0000000..941a386 --- /dev/null +++ b/liquibase-4.9.1/db/changelog/v.2.0.0/create-table-hero.xml @@ -0,0 +1,54 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + name = 'Савельич' + + + name = 'Капитанская дочка' + + + first_name = 'Александр' + + + + + \ No newline at end of file diff --git a/liquibase-4.9.1/db/changelog/v.2.0.0/cumulative-changelog.xml b/liquibase-4.9.1/db/changelog/v.2.0.0/cumulative-changelog.xml new file mode 100644 index 0000000..ddfdd91 --- /dev/null +++ b/liquibase-4.9.1/db/changelog/v.2.0.0/cumulative-changelog.xml @@ -0,0 +1,13 @@ + + + + + + + + + + \ No newline at end of file diff --git a/liquibase-4.9.1/examples/json/blank-changelog.json b/liquibase-4.9.1/examples/json/blank-changelog.json new file mode 100644 index 0000000..d912de6 --- /dev/null +++ b/liquibase-4.9.1/examples/json/blank-changelog.json @@ -0,0 +1,18 @@ +{ "databaseChangeLog": [ + "changeset": { + "id": "1", + "author": "your.name", + "changes": [ + { + } + ] + }, + "changeset": { + "id": "2", + "author": "your.name", + "changes": [ + { + } + ] + } +]} diff --git a/liquibase-4.9.1/examples/json/example-changelog.json b/liquibase-4.9.1/examples/json/example-changelog.json new file mode 100644 index 0000000..f625a23 --- /dev/null +++ b/liquibase-4.9.1/examples/json/example-changelog.json @@ -0,0 +1,135 @@ +{ "databaseChangeLog": [ + { + "changeSet": { + "id": "1", + "author": "your.name", + "labels": "example-label", + "context": "example-context", + "comment": "example-comment", + "changes": [ + { + "createTable": { + "tableName": "person", + "columns": [ + { + "column": { + "name": "id", + "type": "int", + "autoIncrement": true, + "constraints": { + "primarykey": true, + "nullable": false + } + } + }, + { + "column": { + "name": "name", + "type": "varchar(50)", + "constraints": { + "nullable": false + } + } + }, + { + "column": { + "name": "addresss1", + "type": "varchar(50)" + } + }, + { + "column": { + "name": "addresss2", + "type": "varchar(50)" + } + }, + { + "column": { + "name": "city", + "type": "varchar(30)" + } + } + ] + } + }] + } + }, + { + "changeSet": { + "id": "2", + "author": "your.name", + "labels": "example-label", + "context": "example-context", + "comment": "example-comment", + "changes": [ + { + "createTable": { + "tableName": "company", + "columns": [ + { + "column": { + "name": "id", + "type": "int", + "autoIncrement": true, + "constraints": { + "primarykey": true, + "nullable": false + } + } + }, + { + "column": { + "name": "name", + "type": "varchar(50)", + "constraints": { + "nullable": false + } + } + }, + { + "column": { + "name": "addresss1", + "type": "varchar(50)" + } + }, + { + "column": { + "name": "addresss2", + "type": "varchar(50)" + } + }, + { + "column": { + "name": "city", + "type": "varchar(30)" + } + } + ] + } + }] + } + }, + { + "changeSet": { + "id": "3", + "author": "other.dev", + "labels": "example-label", + "context": "example-context", + "comment": "example-comment", + "changes": [ + { + "addColumn": { + "tableName": "person", + "columns": [ + { + "column": { + "name": "country", + "type": "varchar(2)" + } + } + ] + } + }] + } + } +]} \ No newline at end of file diff --git a/liquibase-4.9.1/examples/json/example-changeset-json.txt b/liquibase-4.9.1/examples/json/example-changeset-json.txt new file mode 100644 index 0000000..4c7e5d5 --- /dev/null +++ b/liquibase-4.9.1/examples/json/example-changeset-json.txt @@ -0,0 +1,30 @@ +"changeSet": { + "id": "1", + "author": "dev", + "changes": [ + { + "createTable": { + "tableName": "person", + "columns": [ + { + "column": { + "name": "id", + "type": "int", + "autoIncrement": true, + "constraints": { + "primaryKey": true, + "nullable": false + } + } + }, + { + "column": { + "name": "name", + "type": "varchar(255)" + } + } + ] + } + } + ] +} diff --git a/liquibase-4.9.1/examples/json/liquibase.properties b/liquibase-4.9.1/examples/json/liquibase.properties new file mode 100644 index 0000000..5c2fd4e --- /dev/null +++ b/liquibase-4.9.1/examples/json/liquibase.properties @@ -0,0 +1,76 @@ +#### _ _ _ _ +## | | (_) (_) | +## | | _ __ _ _ _ _| |__ __ _ ___ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| +## | | +## |_| +## +## The liquibase.properties file stores properties which do not change often, +## such as database connection information. Properties stored here save time +## and reduce risk of mistyped command line arguments. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.properties file requires paths for some properties. +## The classpath is the path/to/resources (ex. src/main/resources). +## The changeLogFile path is relative to the classpath. +## The url H2 example below is relative to 'pwd' resource. +#### +# Enter the path for your changelog file. +changeLogFile=example-changelog.json + +#### Enter the Target database 'url' information #### +liquibase.command.url=jdbc:h2:tcp://localhost:9090/mem:dev + +# Enter the username for your Target database. +liquibase.command.username: dbuser + +# Enter the password for your Target database. +liquibase.command.password: letmein + +#### Enter the Source Database 'referenceUrl' information #### +## The source database is the baseline or reference against which your target database is compared for diff/diffchangelog commands. + +# Enter URL for the source database +liquibase.command.referenceUrl: jdbc:h2:tcp://localhost:9090/mem:integration + +# Enter the username for your source database +liquibase.command.referenceUsername: dbuser + +# Enter the password for your source database +liquibase.command.referencePassword: letmein + +# Logging Configuration +# logLevel controls the amount of logging information generated. If not set, the default logLevel is INFO. +# Valid values, from least amount of logging to most, are: +# OFF, ERROR, WARN, INFO, DEBUG, TRACE, ALL +# If you are having problems, setting the logLevel to DEBUG and re-running the command can be helpful. +# logLevel: DEBUG + +# The logFile property controls where logging messages are sent. If this is not set, then logging messages are +# displayed on the console. If this is set, then messages will be sent to a file with the given name. +# logFile: liquibase.log + + +#### Liquibase Pro Key Information #### +# Learn more, contact support, or get or renew a Pro Key at https://www.liquibase.com/protrial +# liquibase.pro.licensekey: + +#### Liquibase Hub Information #### +# Liquibase Hub is a free secure SaaS portal providing status reporting, monitoring & insights +# into your Liquibase database release automation. +# https://hub.liquibase.com + +## Add your free Hub API key here +# liquibase.hub.apikey: +# liquibase.hub.mode:all + + + + +## Get documentation at docs.liquibase.com ## +## Get certified courses at learn.liquibase.com ## +## Get support at liquibase.com/support ## diff --git a/liquibase-4.9.1/examples/sql/blank-changelog.sql b/liquibase-4.9.1/examples/sql/blank-changelog.sql new file mode 100644 index 0000000..b82062b --- /dev/null +++ b/liquibase-4.9.1/examples/sql/blank-changelog.sql @@ -0,0 +1,12 @@ +--liquibase formatted sql +/* https://www.liquibase.org/documentation/sql_format.html */ + +--changeset authorname:1 +/* Insert SQL change objects here */ + + +--changeset authorname:2 +/* Insert SQL change objects here */ + + + diff --git a/liquibase-4.9.1/examples/sql/example-changelog.sql b/liquibase-4.9.1/examples/sql/example-changelog.sql new file mode 100644 index 0000000..31a04fd --- /dev/null +++ b/liquibase-4.9.1/examples/sql/example-changelog.sql @@ -0,0 +1,29 @@ +--liquibase formatted sql + +--changeset your.name:1 labels:example-label context:example-context +--comment: example comment +create table person ( + id int primary key auto_increment not null, + name varchar(50) not null, + address1 varchar(50), + address2 varchar(50), + city varchar(30) +) +--rollback DROP TABLE person; + +--changeset your.name:2 labels:example-label context:example-context +--comment: example comment +create table company ( + id int primary key auto_increment not null, + name varchar(50) not null, + address1 varchar(50), + address2 varchar(50), + city varchar(30) +) +--rollback DROP TABLE company; + +--changeset other.dev:3 labels:example-label context:example-context +--comment: example comment +alter table person add column country varchar(2) +--rollback ALTER TABLE person DROP COLUMN country; + diff --git a/liquibase-4.9.1/examples/sql/example-changeset-sql.txt b/liquibase-4.9.1/examples/sql/example-changeset-sql.txt new file mode 100644 index 0000000..88f1816 --- /dev/null +++ b/liquibase-4.9.1/examples/sql/example-changeset-sql.txt @@ -0,0 +1,7 @@ +(example-changeset-sql.txt) + +--changeset dev:1 +create table test1( + id int primary key, + name varchar(255) +); diff --git a/liquibase-4.9.1/examples/sql/liquibase.properties b/liquibase-4.9.1/examples/sql/liquibase.properties new file mode 100644 index 0000000..d15b155 --- /dev/null +++ b/liquibase-4.9.1/examples/sql/liquibase.properties @@ -0,0 +1,76 @@ +#### _ _ _ _ +## | | (_) (_) | +## | | _ __ _ _ _ _| |__ __ _ ___ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| +## | | +## |_| +## +## The liquibase.properties file stores properties which do not change often, +## such as database connection information. Properties stored here save time +## and reduce risk of mistyped command line arguments. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.properties file requires paths for some properties. +## The classpath is the path/to/resources (ex. src/main/resources). +## The changeLogFile path is relative to the classpath. +## The url H2 example below is relative to 'pwd' resource. +#### +# Enter the path for your changelog file. +changeLogFile=example-changelog.sql + +#### Enter the Target database 'url' information #### +liquibase.command.url=jdbc:h2:tcp://localhost:9090/mem:dev + +# Enter the username for your Target database. +liquibase.command.username: dbuser + +# Enter the password for your Target database. +liquibase.command.password: letmein + +#### Enter the Source Database 'referenceUrl' information #### +## The source database is the baseline or reference against which your target database is compared for diff/diffchangelog commands. + +# Enter URL for the source database +liquibase.command.referenceUrl: jdbc:h2:tcp://localhost:9090/mem:integration + +# Enter the username for your source database +liquibase.command.referenceUsername: dbuser + +# Enter the password for your source database +liquibase.command.referencePassword: letmein + +# Logging Configuration +# logLevel controls the amount of logging information generated. If not set, the default logLevel is INFO. +# Valid values, from least amount of logging to most, are: +# OFF, ERROR, WARN, INFO, DEBUG, TRACE, ALL +# If you are having problems, setting the logLevel to DEBUG and re-running the command can be helpful. +# logLevel: DEBUG + +# The logFile property controls where logging messages are sent. If this is not set, then logging messages are +# displayed on the console. If this is set, then messages will be sent to a file with the given name. +# logFile: liquibase.log + + +#### Liquibase Pro Key Information #### +# Learn more, contact support, or get or renew a Pro Key at https://www.liquibase.com/protrial +# liquibase.pro.licensekey: + +#### Liquibase Hub Information #### +# Liquibase Hub is a free secure SaaS portal providing status reporting, monitoring & insights +# into your Liquibase database release automation. +# https://hub.liquibase.com + +## Add your free Hub API key here +# liquibase.hub.apikey: +# liquibase.hub.mode:all + + + + +## Get documentation at docs.liquibase.com ## +## Get certified courses at learn.liquibase.com ## +## Get support at liquibase.com/support ## diff --git a/liquibase-4.9.1/examples/sql/liquibase.sqlcmd.conf b/liquibase-4.9.1/examples/sql/liquibase.sqlcmd.conf new file mode 100644 index 0000000..1f9d48b --- /dev/null +++ b/liquibase-4.9.1/examples/sql/liquibase.sqlcmd.conf @@ -0,0 +1,55 @@ +#### _ _ _ _ _____ +## | | (_) (_) | | __ \ +## | | _ __ _ _ _ _| |__ __ _ ___ ___ | |__) | __ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ | ___/ '__/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ | | | | | (_) | +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| |_| |_| \___/ +## | | +## |_| +## +## The liquibase.sqlcmd.conf file stores properties which are used during the +## execution of the Microsoft SQLCMD tool. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.sqlcmd.path must be a valid path to the SQLCMD executable. +## The liquibase.sqlcmd.timeout value can be one of: +## -1 - disable the timeout +## Any integer value > 0 (measured in seconds) +## +#### + +# The full path to the SQLCMD executable. +# Sample Linux path +# liquibase.sqlcmd.path=/opt/mssql-tools/bin/sqlcmd +# Sample Windows path +# liquibase.sqlcmd.path="C:\\Program Files\\Microsoft SQL Server\\Client SDK\\ODBC\\170\\Tools\\Binn\\SQLCMD.EXE" + +# A valid timeout value for the execution of the SQLCMD tool +liquibase.sqlcmd.timeout=-1 + +# Flag to indicate whether or not to keep the temporary SQL file after execution of SQLCMD. +# True = keep False = delete (default) +liquibase.sqlcmd.keep.temp=true + +# OPTIONAL Flag to designate the location to store temporary SQL file after execution of SQLCMD. +# Liquibase will attempt to use path exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlcmd.keep.temp.path= + +# OPTIONAL Flag to designate the name of temporary SQL file after execution of SQLCMD. +# Liquibase will attempt to use the name exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlcmd.keep.temp.name= + +# OPTIONAL Args to pass directly to SQLCMD. +# Learn about SQLCMD args at https:// +# Note: The delimiter for args is a space eg:" " and not "," or ";" separated. +# liquibase.sqlcmd.args= + +# OPTIONAL Path to a log file for the SQLCMD output +# liquibase.sqlcmd.logFile= +# + +# OPTIONAL Name of a custom executor to use instead of SQLCMD +# The Executor must be on the Liquibase classpath +# liquibase.sqlcmd.executor= diff --git a/liquibase-4.9.1/examples/sql/liquibase.sqlplus.conf b/liquibase-4.9.1/examples/sql/liquibase.sqlplus.conf new file mode 100644 index 0000000..9a748db --- /dev/null +++ b/liquibase-4.9.1/examples/sql/liquibase.sqlplus.conf @@ -0,0 +1,51 @@ +#### _ _ _ _ _____ +## | | (_) (_) | | __ \ +## | | _ __ _ _ _ _| |__ __ _ ___ ___ | |__) | __ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ | ___/ '__/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ | | | | | (_) | +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| |_| |_| \___/ +## | | +## |_| +## +## The liquibase.sqlplus.conf file stores properties which are used during the +## execution of the Oracle SQLPLUS tool. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.sqlplus.path must be a valid path to the SQLPlUS executable. +## The liquibase.sqlplus.timeout value can be one of: +## -1 - disable the timeout +## Any integer value > 0 (measured in seconds) +## +#### + +# The full path to the SQLPLUS executable. +# Sample Linux path +# liquibase.sqlplus.path=/apps/app/12.2.0.1.0/oracle/product/12.2.0.1.0/client_1/bin/sqlplus +# Sample Windows path +# liquibase.sqlplus.path=c:\\oracle\\product\\11.2.0\\client_1\\bin\\sqlplus.exe + +# A valid timeout value for the execution of the SQLPLUS tool +liquibase.sqlplus.timeout=-1 + +# Flag to indicate whether or not to keep the temporary SQL file after execution of SQLPLUS. +# True = keep False = delete (default) +liquibase.sqlplus.keep.temp=true + +# OPTIONAL Flag to designate the location to store temporary SQL file after execution of SQLPLUS. +# Liquibase will attempt to use path exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlplus.keep.temp.path= + +# OPTIONAL Flag to designate the name of temporary SQL file after execution of SQLPLUS. +# Liquibase will attempt to use the name exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlplus.keep.temp.name= + +# OPTIONAL Args to pass directly to SQLPLUS. +# Learn about SQLPLUS args at https://docs.oracle.com/cd/B10501_01/server.920/a90842/ch4.htm +# Note: The delimiter for args is a space eg:" " and not "," or ";" separated. +# liquibase.sqlplus.args= + +# OPTIONAL Name of a custom executor to use instead of SQLPLUS +# The Executor must be on the Liquibase classpath +# liquibase.sqlplus.executor= diff --git a/liquibase-4.9.1/examples/start-h2 b/liquibase-4.9.1/examples/start-h2 new file mode 100755 index 0000000..aab4997 --- /dev/null +++ b/liquibase-4.9.1/examples/start-h2 @@ -0,0 +1,38 @@ +#!/usr/bin/env bash + +if [ -z "${LIQUIBASE_HOME}" ]; then + #liquibase home is not set + + LIQUIBASE_PATH="$(which liquibase)" + + if [ -z "${LIQUIBASE_PATH}" ]; then + echo "Must set LIQUIBASE_HOME environment variable, or have liquibase in your PATH" + exit 1 + fi + + LIQUIBASE_HOME=$(dirname "$(which liquibase)") +fi + +if [ -z "${JAVA_HOME}" ]; then + #JAVA_HOME not set, try to find a bundled version + if [ -d "${LIQUIBASE_HOME}/jre" ]; then + JAVA_HOME="$LIQUIBASE_HOME/jre" + elif [ -d "${LIQUIBASE_HOME}/.install4j/jre.bundle/Contents/Home" ]; then + JAVA_HOME="${LIQUIBASE_HOME}/.install4j/jre.bundle/Contents/Home" + fi +fi + +if [ -z "${JAVA_HOME}" ]; then + JAVA_PATH="$(which java)" + + if [ -z "${JAVA_PATH}" ]; then + echo "Cannot find java in your path. Install java or use the JAVA_HOME environment variable" + + exit 1 + fi +else + #Use path in JAVA_HOME + JAVA_PATH="${JAVA_HOME}/bin/java" +fi + +"${JAVA_PATH}" -cp "${LIQUIBASE_HOME}/lib/h2-2.1.210.jar:${LIQUIBASE_HOME}/liquibase.jar" liquibase.example.StartH2Main diff --git a/liquibase-4.9.1/examples/start-h2.bat b/liquibase-4.9.1/examples/start-h2.bat new file mode 100644 index 0000000..d5f88a7 --- /dev/null +++ b/liquibase-4.9.1/examples/start-h2.bat @@ -0,0 +1,34 @@ +@echo off +if "%OS%" == "Windows_NT" setlocal + +setlocal enabledelayedexpansion + +rem %~dp0 is expanded pathname of the current script under NT +rem %~p0 is the directory of the current script + +if exist %~p0\..\liquibase.jar SET LIQUIBASE_HOME="%~p0\.." + +if "%LIQUIBASE_HOME%"=="" ( + FOR /F "tokens=* USEBACKQ" %%g IN (`where liquibase.bat`) do (SET "LIQUIBASE_HOME=%%~dpg") +) + +if "%LIQUIBASE_HOME%"=="" ( + echo "Must set LIQUIBASE_HOME environment variable, or have liquibase.bat in your PATH" + exit /B 1 +) + +if "%JAVA_HOME%"=="" ( + + rem check for jre dir in liquibase_home + if NOT "%LIQUIBASE_HOME%"=="" if exist "%LIQUIBASE_HOME%\jre" ( + set JAVA_HOME=%LIQUIBASE_HOME%\jre + ) +) + +if "%JAVA_HOME%"=="" ( + set JAVA_PATH=java +) else ( + set JAVA_PATH=%JAVA_HOME%\bin\java +) + +"%JAVA_PATH%" -cp "%LIQUIBASE_HOME%\lib\h2-2.1.210.jar;%LIQUIBASE_HOME%\liquibase.jar" liquibase.example.StartH2Main diff --git a/liquibase-4.9.1/examples/xml/blank-changelog.xml b/liquibase-4.9.1/examples/xml/blank-changelog.xml new file mode 100644 index 0000000..61e339e --- /dev/null +++ b/liquibase-4.9.1/examples/xml/blank-changelog.xml @@ -0,0 +1,18 @@ + + + + + + + + + + + + + diff --git a/liquibase-4.9.1/examples/xml/example-changelog.xml b/liquibase-4.9.1/examples/xml/example-changelog.xml new file mode 100644 index 0000000..75a2d01 --- /dev/null +++ b/liquibase-4.9.1/examples/xml/example-changelog.xml @@ -0,0 +1,46 @@ + + + + + + example-comment + + + + + + + + + + + + + + + example-comment + + + + + + + + + + + + + + + example-comment + + + + + diff --git a/liquibase-4.9.1/examples/xml/example-changeset-xml.txt b/liquibase-4.9.1/examples/xml/example-changeset-xml.txt new file mode 100644 index 0000000..4f162b3 --- /dev/null +++ b/liquibase-4.9.1/examples/xml/example-changeset-xml.txt @@ -0,0 +1,13 @@ + + + + + + + + + + + + + diff --git a/liquibase-4.9.1/examples/xml/liquibase.properties b/liquibase-4.9.1/examples/xml/liquibase.properties new file mode 100644 index 0000000..30b30d9 --- /dev/null +++ b/liquibase-4.9.1/examples/xml/liquibase.properties @@ -0,0 +1,76 @@ +#### _ _ _ _ +## | | (_) (_) | +## | | _ __ _ _ _ _| |__ __ _ ___ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| +## | | +## |_| +## +## The liquibase.properties file stores properties which do not change often, +## such as database connection information. Properties stored here save time +## and reduce risk of mistyped command line arguments. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.properties file requires paths for some properties. +## The classpath is the path/to/resources (ex. src/main/resources). +## The changeLogFile path is relative to the classpath. +## The url H2 example below is relative to 'pwd' resource. +#### +# Enter the path for your changelog file. +changeLogFile=example-changelog.xml + +#### Enter the Target database 'url' information #### +liquibase.command.url=jdbc:h2:tcp://localhost:9090/mem:dev + +# Enter the username for your Target database. +liquibase.command.username: dbuser + +# Enter the password for your Target database. +liquibase.command.password: letmein + +#### Enter the Source Database 'referenceUrl' information #### +## The source database is the baseline or reference against which your target database is compared for diff/diffchangelog commands. + +# Enter URL for the source database +liquibase.command.referenceUrl: jdbc:h2:tcp://localhost:9090/mem:integration + +# Enter the username for your source database +liquibase.command.referenceUsername: dbuser + +# Enter the password for your source database +liquibase.command.referencePassword: letmein + +# Logging Configuration +# logLevel controls the amount of logging information generated. If not set, the default logLevel is INFO. +# Valid values, from least amount of logging to most, are: +# OFF, ERROR, WARN, INFO, DEBUG, TRACE, ALL +# If you are having problems, setting the logLevel to DEBUG and re-running the command can be helpful. +# logLevel: DEBUG + +# The logFile property controls where logging messages are sent. If this is not set, then logging messages are +# displayed on the console. If this is set, then messages will be sent to a file with the given name. +# logFile: liquibase.log + + +#### Liquibase Pro Key Information #### +# Learn more, contact support, or get or renew a Pro Key at https://www.liquibase.com/protrial +# liquibase.pro.licensekey: + +#### Liquibase Hub Information #### +# Liquibase Hub is a free secure SaaS portal providing status reporting, monitoring & insights +# into your Liquibase database release automation. +# https://hub.liquibase.com + +## Add your free Hub API key here +# liquibase.hub.apikey: +# liquibase.hub.mode:all + + + + +## Get documentation at docs.liquibase.com ## +## Get certified courses at learn.liquibase.com ## +## Get support at liquibase.com/support ## diff --git a/liquibase-4.9.1/examples/xml/liquibase.sqlcmd.conf b/liquibase-4.9.1/examples/xml/liquibase.sqlcmd.conf new file mode 100644 index 0000000..d27bb25 --- /dev/null +++ b/liquibase-4.9.1/examples/xml/liquibase.sqlcmd.conf @@ -0,0 +1,54 @@ +#### _ _ _ _ _____ +## | | (_) (_) | | __ \ +## | | _ __ _ _ _ _| |__ __ _ ___ ___ | |__) | __ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ | ___/ '__/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ | | | | | (_) | +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| |_| |_| \___/ +## | | +## |_| +## +## The liquibase.sqlcmd.conf file stores properties which are used during the +## execution of the Microsoft SQLCMD tool. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.sqlcmd.path must be a valid path to the SQLCMD executable. +## The liquibase.sqlcmd.timeout value can be one of: +## -1 - disable the timeout +## Any integer value > 0 (measured in seconds) +## +#### + +# The full path to the SQLCMD executable. +# Sample Linux path +# liquibase.sqlcmd.path=/opt/mssql-tools/bin/sqlcmd +# Sample Windows path +# liquibase.sqlcmd.path="C:\\Program Files\\Microsoft SQL Server\\Client SDK\\ODBC\\170\\Tools\\Binn\\SQLCMD.EXE" + +# A valid timeout value for the execution of the SQLCMD tool +liquibase.sqlcmd.timeout=-1 + +# Flag to indicate whether or not to keep the temporary SQL file after execution of SQLCMD. +# True = keep False = delete (default) +liquibase.sqlcmd.keep.temp=true + +# OPTIONAL Flag to designate the location to store temporary SQL file after execution of SQLCMD. +# Liquibase will attempt to use path exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlcmd.keep.temp.path= + +# OPTIONAL Flag to designate the name of temporary SQL file after execution of SQLCMD. +# Liquibase will attempt to use the name exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlcmd.keep.temp.name= + +# OPTIONAL Args to pass directly to SQLCMD. +# Learn about SQLCMD args at https:// +# Note: The delimiter for args is a space eg:" " and not "," or ";" separated. +# liquibase.sqlcmd.args= + +# OPTIONAL Path to a log file for the SQLCMD output +# liquibase.sqlcmd.logFile= + +# OPTIONAL Name of a custom executor to use instead of SQLCMD +# The Executor must be on the Liquibase classpath +# liquibase.sqlcmd.executor= diff --git a/liquibase-4.9.1/examples/xml/liquibase.sqlplus.conf b/liquibase-4.9.1/examples/xml/liquibase.sqlplus.conf new file mode 100644 index 0000000..281ea92 --- /dev/null +++ b/liquibase-4.9.1/examples/xml/liquibase.sqlplus.conf @@ -0,0 +1,51 @@ +#### _ _ _ _ _____ +## | | (_) (_) | | __ \ +## | | _ __ _ _ _ _| |__ __ _ ___ ___ | |__) | __ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ | ___/ '__/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ | | | | | (_) | +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| |_| |_| \___/ +## | | +## |_| +## +## The liquibase.sqlplus.conf file stores properties which are used during the +## execution of the Oracle SQLPLUS tool. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.sqlplus.path must be a valid path to the SQLPlUS executable. +## The liquibase.sqlplus.timeout value can be one of: +## -1 - disable the timeout +## Any integer value > 0 (measured in seconds) +## +#### + +# The full path to the SQLPLUS executable. +# Sample Linux path +# liquibase.sqlplus.path=/apps/app/12.2.0.1.0/oracle/product/12.2.0.1.0/client_1/bin/sqlplus +# Sample Windows path +# liquibase.sqlplus.path=c:\\oracle\\product\\11.2.0\\client_1\\bin\\sqlplus.exe + +# A valid timeout value for the execution of the SQLPLUS tool +liquibase.sqlplus.timeout=-1 + +# Flag to indicate whether or not to keep the temporary SQL file after execution of SQLPLUS. +# True = keep False = delete (default) +liquibase.sqlplus.keep.temp=true + +# OPTIONAL Flag to designate the location to store temporary SQL file after execution of SQLPLUS. +# Liquibase will attempt to use path exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlplus.keep.temp.path= + +# OPTIONAL Flag to designate the name of temporary SQL file after execution of SQLPLUS. +# Liquibase will attempt to use the name exactly as entered, so please ensure it complies with your OS requirements. +# liquibase.sqlplus.keep.temp.name= + +# OPTIONAL Args to pass directly to SQLPLUS. +# Learn about SQLPLUS args at https://docs.oracle.com/cd/B10501_01/server.920/a90842/ch4.htm +# Note: The delimiter for args is a space eg:" " and not "," or ";" separated. +# liquibase.sqlplus.args= + +# OPTIONAL Name of a custom executor to use instead of SQLPLUS +# The Executor must be on the Liquibase classpath +# liquibase.sqlplus.executor= diff --git a/liquibase-4.9.1/examples/yaml/blank-changelog.yaml b/liquibase-4.9.1/examples/yaml/blank-changelog.yaml new file mode 100644 index 0000000..771e191 --- /dev/null +++ b/liquibase-4.9.1/examples/yaml/blank-changelog.yaml @@ -0,0 +1,12 @@ +databaseChangeLog: +- changeSet: + id: 1 + author: your.name + changes: + # Insert Yaml change objects here https://www.liquibase.org/documentation/yaml_format.html + +- changeSet: + id: 2 + author: your.name + changes: + # Insert Yaml change objects here https://www.liquibase.org/documentation/yaml_format.html diff --git a/liquibase-4.9.1/examples/yaml/example-changelog.yaml b/liquibase-4.9.1/examples/yaml/example-changelog.yaml new file mode 100644 index 0000000..96258e4 --- /dev/null +++ b/liquibase-4.9.1/examples/yaml/example-changelog.yaml @@ -0,0 +1,78 @@ +databaseChangeLog: +- changeSet: + id: 1 + author: your.name + labels: example-label + context: example-context + comment: example-comment + changes: + - createTable: + tableName: person + columns: + - column: + name: id + type: int + autoIncrement: true + constraints: + primaryKey: true + nullable: false + - column: + name: name + type: varchar(50) + constraints: + nullable: false + - column: + name: address1 + type: varchar(50) + - column: + name: address2 + type: varchar(50) + - column: + name: city + type: varchar(30) + +- changeSet: + id: 2 + author: your.name + labels: example-label + context: example-context + comment: example-comment + changes: + - createTable: + tableName: company + columns: + - column: + name: id + type: int + autoIncrement: true + constraints: + primaryKey: true + nullable: false + - column: + name: name + type: varchar(50) + constraints: + nullable: false + - column: + name: address1 + type: varchar(50) + - column: + name: address2 + type: varchar(50) + - column: + name: city + type: varchar(30) + +- changeSet: + id: 3 + author: other.dev + labels: example-label + context: example-context + comment: example-comment + changes: + - addColumn: + tableName: person + columns: + - column: + name: country + type: varchar(2) diff --git a/liquibase-4.9.1/examples/yaml/example-changeset-yaml.txt b/liquibase-4.9.1/examples/yaml/example-changeset-yaml.txt new file mode 100644 index 0000000..ac332f2 --- /dev/null +++ b/liquibase-4.9.1/examples/yaml/example-changeset-yaml.txt @@ -0,0 +1,17 @@ + - changeSet: + id: 1 + author: dev + changes: + - createTable: + tableName: person + columns: + - column: + name: id + type: int + autoIncrement: true + constraints: + primaryKey: true + nullable: false + - column: + name: name + type: varchar(255) diff --git a/liquibase-4.9.1/examples/yaml/liquibase.properties b/liquibase-4.9.1/examples/yaml/liquibase.properties new file mode 100644 index 0000000..f964af5 --- /dev/null +++ b/liquibase-4.9.1/examples/yaml/liquibase.properties @@ -0,0 +1,76 @@ +#### _ _ _ _ +## | | (_) (_) | +## | | _ __ _ _ _ _| |__ __ _ ___ ___ +## | | | |/ _` | | | | | '_ \ / _` / __|/ _ \ +## | |___| | (_| | |_| | | |_) | (_| \__ \ __/ +## \_____/_|\__, |\__,_|_|_.__/ \__,_|___/\___| +## | | +## |_| +## +## The liquibase.properties file stores properties which do not change often, +## such as database connection information. Properties stored here save time +## and reduce risk of mistyped command line arguments. +## Learn more: https://www.liquibase.org/documentation/config_properties.html +#### +#### +## Note about relative and absolute paths: +## The liquibase.properties file requires paths for some properties. +## The classpath is the path/to/resources (ex. src/main/resources). +## The changeLogFile path is relative to the classpath. +## The url H2 example below is relative to 'pwd' resource. +#### +# Enter the path for your changelog file. +changeLogFile=example-changelog.yaml + +#### Enter the Target database 'url' information #### +liquibase.command.url=jdbc:h2:tcp://localhost:9090/mem:dev + +# Enter the username for your Target database. +liquibase.command.username: dbuser + +# Enter the password for your Target database. +liquibase.command.password: letmein + +#### Enter the Source Database 'referenceUrl' information #### +## The source database is the baseline or reference against which your target database is compared for diff/diffchangelog commands. + +# Enter URL for the source database +liquibase.command.referenceUrl: jdbc:h2:tcp://localhost:9090/mem:integration + +# Enter the username for your source database +liquibase.command.referenceUsername: dbuser + +# Enter the password for your source database +liquibase.command.referencePassword: letmein + +# Logging Configuration +# logLevel controls the amount of logging information generated. If not set, the default logLevel is INFO. +# Valid values, from least amount of logging to most, are: +# OFF, ERROR, WARN, INFO, DEBUG, TRACE, ALL +# If you are having problems, setting the logLevel to DEBUG and re-running the command can be helpful. +# logLevel: DEBUG + +# The logFile property controls where logging messages are sent. If this is not set, then logging messages are +# displayed on the console. If this is set, then messages will be sent to a file with the given name. +# logFile: liquibase.log + + +#### Liquibase Pro Key Information #### +# Learn more, contact support, or get or renew a Pro Key at https://www.liquibase.com/protrial +# liquibase.pro.licensekey: + +#### Liquibase Hub Information #### +# Liquibase Hub is a free secure SaaS portal providing status reporting, monitoring & insights +# into your Liquibase database release automation. +# https://hub.liquibase.com + +## Add your free Hub API key here +# liquibase.hub.apikey: +# liquibase.hub.mode:all + + + + +## Get documentation at docs.liquibase.com ## +## Get certified courses at learn.liquibase.com ## +## Get support at liquibase.com/support ## diff --git a/liquibase-4.9.1/lib/h2-2.1.210.jar b/liquibase-4.9.1/lib/h2-2.1.210.jar new file mode 100644 index 0000000..d9656f4 Binary files /dev/null and b/liquibase-4.9.1/lib/h2-2.1.210.jar differ diff --git a/liquibase-4.9.1/lib/hsqldb-2.5.2.jar b/liquibase-4.9.1/lib/hsqldb-2.5.2.jar new file mode 100644 index 0000000..49124e0 Binary files /dev/null and b/liquibase-4.9.1/lib/hsqldb-2.5.2.jar differ diff --git a/liquibase-4.9.1/lib/jaxb-api-2.3.0.jar b/liquibase-4.9.1/lib/jaxb-api-2.3.0.jar new file mode 100644 index 0000000..0817c08 Binary files /dev/null and b/liquibase-4.9.1/lib/jaxb-api-2.3.0.jar differ diff --git a/liquibase-4.9.1/lib/jaxb-core-2.3.0.jar b/liquibase-4.9.1/lib/jaxb-core-2.3.0.jar new file mode 100644 index 0000000..864ba31 Binary files /dev/null and b/liquibase-4.9.1/lib/jaxb-core-2.3.0.jar differ diff --git a/liquibase-4.9.1/lib/jaxb-impl-2.3.0.jar b/liquibase-4.9.1/lib/jaxb-impl-2.3.0.jar new file mode 100644 index 0000000..02f50ab Binary files /dev/null and b/liquibase-4.9.1/lib/jaxb-impl-2.3.0.jar differ diff --git a/liquibase-4.9.1/lib/jaybird-4.0.3.java8.jar b/liquibase-4.9.1/lib/jaybird-4.0.3.java8.jar new file mode 100644 index 0000000..efeebf9 Binary files /dev/null and b/liquibase-4.9.1/lib/jaybird-4.0.3.java8.jar differ diff --git a/liquibase-4.9.1/lib/jcc-11.5.6.0.jar b/liquibase-4.9.1/lib/jcc-11.5.6.0.jar new file mode 100644 index 0000000..0752cc2 Binary files /dev/null and b/liquibase-4.9.1/lib/jcc-11.5.6.0.jar differ diff --git a/liquibase-4.9.1/lib/liquibase_autocomplete.sh b/liquibase-4.9.1/lib/liquibase_autocomplete.sh new file mode 100644 index 0000000..1609610 --- /dev/null +++ b/liquibase-4.9.1/lib/liquibase_autocomplete.sh @@ -0,0 +1,162 @@ +_liquibase() +{ + local cur prev opts + COMPREPLY=() + cur="${COMP_WORDS[COMP_CWORD]}" + prev="${COMP_WORDS[COMP_CWORD-1]}" + + # Liquibase options, has to be improved to be more context aware + opts=" + help + update + updateSQL + updateCount + updateCountSQL + updateToTag + updateToTagSQL + status + registerChangeLog + syncHub + rollback + rollbackSQL + rollbackOneChangeSet + rollbackOneChangeSetSQL + rollbackOneUpdate + rollbackOneUpdateSQL + rollbackToDate + rollbackToDateSQL + rollbackCount + rollbackCountSQL + futureRollbackSQL + futureRollbackFromTagSQL + updateTestingRollback + generateChangeLog + snapshot + snapshotReference + diff + diffChangeLog + dbDoc + history + tag + tagExists + status + unexpectedChangeSets + validate + calculateCheckSum + clearCheckSums + changelogSync + changelogSyncSQL + changeLogSyncToTag + changeLogSyncToTagSQL + checks^show + checks^run + checks^bulk-set + checks^delete^--check-name= + checks^customize^--check-name= + checks^enable^--check-name= + checks^disable^--check-name= + checks^copy^--check-name= + checks^reset^--check-name= + markNextChangeSetRan + markNextChangeSetRanSQL + listLocks + releaseLocks + dropAll + --changeLogFile + --changeSetAuthor= + --changeSetId= + --changeSetPath= + --deploymentId= + --force + --format + --username + --password + --url + --classpath + --driver + --databaseClass + --propertyProviderClass + --defaultSchemaName + --contexts + --labels + --defaultsFile + --delimiter + --driverPropertiesFile + --changeExecListenerClass + --changeExecListenerPropertiesFile + --liquibaseCatalogName + --liquibaseSchemaName + --databaseChangeLogTableName + --databaseChangeLogLockTableName + --databaseChangeLogTablespaceName + --liquibaseSchemaName + --includeSystemClasspath + --overwriteOutputFile + --promptForNonLocalDatabase + --logLevel + --logFile + --currentDateTimeFunction + --outputDefaultSchema + --outputDefaultCatalog + --outputFile + --rollbackScript + --excludeObjects + --includeObjects + --help + --version + --snapshotFormat + --referenceUsername + --referencePassword + --referenceUrl + --defaultCatalogName + --defaultSchemaName + --referenceDefaultCatalogName + --referenceDefaultSchemaName + --schemas + --referenceSchemas + --outputSchemaAs + --includeCatalog + --includeSchema + --includeTablespace + --referenceDriver + --dataOutputDirectory + --diffTypes + --diffTypes= -D= + --verbose + --liquibaseProLicenseKey" + + # Handle --xxxxxx= + if [[ ${prev} == "--"* && ${cur} == "=" ]] ; then + COMPREPLY=(*) + return 0 + fi + # Handle --xxxxx=path + if [[ ${prev} == '=' ]] ; then + # Unescape space + cur=${cur//\\ / } + # Expand tilder to $HOME + [[ ${cur} == "~/"* ]] && cur=${cur/\~/$HOME} + # Show completion if path exist (and escape spaces) + local files=("${cur}"*) + [[ -e ${files[0]} ]] && COMPREPLY=( "${files[@]// /\ }" ) + return 0 + fi + + # Handle other options + COMPREPLY=( $(compgen -W "${opts}" -- "${cur}") ) + if [[ ${#COMPREPLY[@]} == 1 && ${COMPREPLY[0]} != "--"*"=" ]] ; then + # If there's only one option, without =, then allow a space + compopt +o nospace + fi + + # Handle subcommands + for i in "${!COMPREPLY[@]}"; do + temp="${COMPREPLY[$i]}" + COMPREPLY[$i]="${temp//\^/ }" + done + + return 0 +} + + +complete -o nospace -F _liquibase liquibase diff --git a/liquibase-4.9.1/lib/liquibase_autocomplete_mac.bash b/liquibase-4.9.1/lib/liquibase_autocomplete_mac.bash new file mode 100755 index 0000000..2566151 --- /dev/null +++ b/liquibase-4.9.1/lib/liquibase_autocomplete_mac.bash @@ -0,0 +1,112 @@ +#/usr/bin/env bash + +complete -W \ + "help \ + update \ + updateSQL \ + updateCount \ + updateCountSQL \ + updateToTag \ + updateToTagSQL \ + 'status --verbose' \ + 'registerChangeLog --changeLogFile=' \ + 'syncHub --changeLogFile=' \ + rollback \ + rollbackSQL \ + 'rollbackOneChangeSet --changeSetAuthor= --changeSetId= --changeSetPath= --force' \ + 'rollbackOneChangeSetSQL --changeSetAuthor= --changeSetId= --changeSetPath=' \ + 'rollbackOneUpdate --deploymentId= --force' \ + 'rollbackOneUpdateSQL --deploymentId=' \ + rollbackToDate \ + rollbackToDateSQL \ + rollbackCount \ + rollbackCountSQL \ + futureRollbackSQL \ + futureRollbackFromTagSQL \ + updateTestingRollback \ + generateChangeLog \ + snapshot \ + snapshotReference \ + diff \ + diffChangeLog \ + dbDoc \ + history \ + tag \ + tagExists \ + status \ + unexpectedChangeSets \ + validate \ + calculateCheckSum \ + clearCheckSums \ + changelogSync \ + changelogSyncSQL \ + markNextChangeSetRan \ + markNextChangeSetRanSQL \ + listLocks \ + releaseLocks \ + dropAll \ + 'checks run' \ + 'checks delete --check-name=' \ + 'checks bulk-set' \ + 'checks show' \ + 'checks customize --check-name=' \ + 'checks reset --check-name=' \ + 'checks enable --check-name=' \ + 'checks disable --check-name=' \ + 'checks copy --check-name=' \ + --changeLogFile \ + --username \ + --password \ + --url \ + --classpath \ + --driver \ + --databaseClass \ + --propertyProviderClass \ + --defaultSchemaName \ + --contexts \ + --labels \ + --defaultsFile \ + --delimiter \ + --driverPropertiesFile \ + --changeExecListenerClass \ + --changeExecListenerPropertiesFile \ + --liquibaseCatalogName \ + --liquibaseSchemaName \ + --databaseChangeLogTableName \ + --databaseChangeLogLockTableName \ + --databaseChangeLogTablespaceName \ + --liquibaseSchemaName \ + --includeSystemClasspath \ + --overwriteOutputFile \ + --promptForNonLocalDatabase \ + --logLevel \ + --logFile \ + --currentDateTimeFunction \ + --outputDefaultSchema \ + --outputDefaultCatalog \ + --outputFile \ + --rollbackScript \ + --excludeObjects \ + --includeObjects \ + --help \ + --version \ + --snapshotFormat \ + --referenceUsername \ + --referencePassword \ + --referenceUrl \ + --defaultCatalogName \ + --defaultSchemaName \ + --referenceDefaultCatalogName \ + --referenceDefaultSchemaName \ + --schemas \ + --referenceSchemas \ + --outputSchemaAs \ + --includeCatalog \ + --includeSchema \ + --includeTablespace \ + --referenceDriver \ + --dataOutputDirectory \ + --diffTypes \ + --diffTypes= -D= \ + --format \ + --liquibaseProLicenseKey" liquibase diff --git a/liquibase-4.9.1/lib/mariadb-java-client-2.7.0.jar b/liquibase-4.9.1/lib/mariadb-java-client-2.7.0.jar new file mode 100644 index 0000000..e9406dd Binary files /dev/null and b/liquibase-4.9.1/lib/mariadb-java-client-2.7.0.jar differ diff --git a/liquibase-4.9.1/lib/mssql-jdbc-8.4.0.jre8.jar b/liquibase-4.9.1/lib/mssql-jdbc-8.4.0.jre8.jar new file mode 100644 index 0000000..a57a146 Binary files /dev/null and b/liquibase-4.9.1/lib/mssql-jdbc-8.4.0.jre8.jar differ diff --git a/liquibase-4.9.1/lib/ojdbc8-18.3.0.0.jar b/liquibase-4.9.1/lib/ojdbc8-18.3.0.0.jar new file mode 100644 index 0000000..8c3ab3d Binary files /dev/null and b/liquibase-4.9.1/lib/ojdbc8-18.3.0.0.jar differ diff --git a/liquibase-4.9.1/lib/picocli-4.6.1.jar b/liquibase-4.9.1/lib/picocli-4.6.1.jar new file mode 100644 index 0000000..77bb17f Binary files /dev/null and b/liquibase-4.9.1/lib/picocli-4.6.1.jar differ diff --git a/liquibase-4.9.1/lib/postgresql-42.3.2.jar b/liquibase-4.9.1/lib/postgresql-42.3.2.jar new file mode 100644 index 0000000..955adab Binary files /dev/null and b/liquibase-4.9.1/lib/postgresql-42.3.2.jar differ diff --git a/liquibase-4.9.1/lib/snakeyaml-1.27.jar b/liquibase-4.9.1/lib/snakeyaml-1.27.jar new file mode 100644 index 0000000..79bd430 Binary files /dev/null and b/liquibase-4.9.1/lib/snakeyaml-1.27.jar differ diff --git a/liquibase-4.9.1/lib/sqlite-jdbc-3.34.0.jar b/liquibase-4.9.1/lib/sqlite-jdbc-3.34.0.jar new file mode 100644 index 0000000..e3374e1 Binary files /dev/null and b/liquibase-4.9.1/lib/sqlite-jdbc-3.34.0.jar differ diff --git a/liquibase-4.9.1/licenses/Liquibase Pro EULA Software License Subscription and Support Agreement.txt b/liquibase-4.9.1/licenses/Liquibase Pro EULA Software License Subscription and Support Agreement.txt new file mode 100644 index 0000000..fd9564f --- /dev/null +++ b/liquibase-4.9.1/licenses/Liquibase Pro EULA Software License Subscription and Support Agreement.txt @@ -0,0 +1,182 @@ +SOFTWARE LICENSE SUBSCRIPTION AND SUPPORT AGREEMENT + +PLEASE READ THIS AGREEMENT CAREFULLY BEFORE USING THIS SERVICE. + +BY USING THE SOFTWARE OR CLICKING AGREE, CUSTOMER IS AGREEING TO BE BOUND BY +THIS AGREEMENT. IF YOU ARE AGREEING TO THIS AGREEMENT ON BEHALF OF OR FOR THE +BENEFIT OF YOUR EMPLOYER OR A THIRD PARTY, THEN YOU REPRESENT AND WARRANT THAT +YOU HAVE THE NECESSARY AUTHORITY TO AGREE TO THIS AGREEMENT ON YOUR EMPLOYER'S +OR THAT THIRD PARTY'S BEHALF. + +This agreement is between Liquibase, Inc. a Delaware corporation (Liquibase) and +you, the customer entering into this agreement (Customer). The LiquibasePro +software, updates, documentation and license keys provided to Customer +(Software) are licensed and are not sold. + +SCOPE. This agreement describes the licensing of the Software and support +provided to Customer under an order. Third party contractors and majority owned +affiliates of Customer can use and access the Software under the terms of this +agreement, and Customer is responsible for each of their compliance with such +terms. + +1. LICENSE. Subject to the other terms of this agreement, Liquibase grants +Customer, under an order, a term based non-exclusive, non-transferable license +up to the license capacity purchased to use the Software only in Customer’s +internal business operations. Third party licenses delivered with the Software +may be subject to additional license rights and restrictions a set forth at +https://download.liquibase.org/lbpro-third-party-licenses/. + +2. RESTRICTIONS. Customer may not: +a. Transfer, assign, sublicense, rent the Software, create derivative works of +the Software, or use it in any type of service provider environment; +b. Reverse engineer, decompile, disassemble, or translate the Software; or +c. Evaluate the Software for the purpose of competing with Liquibase Pro or +operate the Software other than in accordance with its technical documentation. + +3. PROPRIETARY RIGHTS AND MUTUAL CONFIDENTIALITY. +a. Proprietary Rights. The Software, workflow processes, user interface, +designs and other technologies provided by Liquibase as part of the Software are +the proprietary property of Liquibase and its licensors, and all right, title and +interest in and to such items, including all associated intellectual property +rights, remain only with Liquibase and its licensors. The Software is protected +by copyright and other intellectual property laws. Customer may not remove any +product identification, copyright, trademark or other notice from the Software. +Liquibase reserves all rights not expressly granted. +b. Mutual Confidentiality. Recipient may not disclose Confidential Information +of Discloser to any third party or use the Confidential Information in +violation of this agreement. +Confidential Information means all information that is disclosed to the +recipient (Recipient) by the discloser (Discloser), and includes, among other +things: + * any and all information relating to products or services provided by a +Discloser, software code, flow charts, techniques, specifications, development +and marketing plans, strategies, and forecasts; + * as to Liquibase, the Software and the terms of this agreement, including +without limitation, all pricing information. +Confidential Information excludes information that: + * was rightfully in Recipient's possession without any obligation of +confidentiality before receipt from the Discloser; + * is or becomes a matter of public knowledge through no fault of Recipient; + * is rightfully received by Recipient from a third party without violation of +a duty of confidentiality; or + * is independently developed by or for Recipient without use or access to the +Confidential Information. + +Recipient may disclose Confidential Information if required by law, but it will +attempt to provide notice to the Discloser in advance so it may seek a +protective order. Each party acknowledges that any misuse of the other party’s +Confidential Information may cause irreparable harm for which there is no +adequate remedy at law. Either party may seek immediate injunctive relief in +such event. + +4. WARRANTY, REMEDY and DISCLAIMER. For new license purchases, Liquibase warrants +that the Software will perform in substantial accordance with its accompanying +technical documentation for a period of 60 days from the date of the order. +This warranty will not apply to any problems caused by software not licensed to +Customer by Liquibase, use other than in accordance with the technical +documentation, or misuse of the Software. The warranty only covers problems +reported to Liquibase during the warranty period or 30 days after. Customer will +cooperate with Liquibase in resolving any warranty claim. +A. EXCLUSIVE REMEDY AND SOLE LIABILITY. Liquibase will use commercially +reasonable efforts to remedy covered warranty claims within a reasonable period +of time or replace the Software, or if Liquibase cannot do so it will refund to +Customer the license fee paid. THIS REMEDY IS CUSTOMER’S EXCLUSIVE REMEDY, AND +LIQUIBASE’S SOLE LIABILITY FOR THESE WARRANTY CLAIMS. +B. DISCLAIMER OF WARRANTIES. LIQUIBASE DISCLAIMS ALL OTHER EXPRESS AND IMPLIED +WARRANTIES, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTY OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. CUSTOMER UNDERSTANDS THAT +THE SOFTWARE MAY NOT BE ERROR FREE, AND USE MAY BE INTERRUPTED. + +5. TERMINATION. This agreement expires at the end of the license period +specified. Either party may terminate this agreement upon a material breach of +the other party after a 30 days’ notice/cure period, if the breach is not cured +during such time period. Upon terminationof this agreement or a license, +Customer must discontinue using the Software, de-install and destroy or return +the Software and all copies, within 5 days. Upon Liquibase's request, Customer +will provide written certification of such compliance. + +6. SUPPORT. Liquibase’s technical support and maintenance services (Support) is +included with the license fees. Customer will receive best efforts e-mail +response for support within two business days from receipt of issue. Liquibase +may change its Support terms, but Support will not materially degrade during +any Support term. + +7. LIMIT ON LIABILITY. There may be situations in which (as a result of +material breach or other liability) Customer is entitled to make a claim +against Liquibase. In each situation (regardless of the form of the legal action +(e.g. contract or tort claims)), Liquibase is not responsible for any damage and +does not have any liability beyond the greater of the amount paid or payable by +Customer to Liquibase within the 12 months prior to the event that gave rise to +the claim and in no event is Liquibase responsible for any: loss of data or +information; lost profits, revenue, or productivity; or other special, +consequential, incidental or indirect damages. + +8. INTELLECTUAL PROPERTY INDEMNITY +a. Defense of Third Party Claims. Liquibase will defend or settle any third party +claim against Customer to the extent that such claim alleges that the Software +violates a copyright, patent, trademark or other intellectual property right, +if Customer, promptly notifies Liquibase of the claim in writing, cooperates with +Liquibase in the defense, and allows Liquibase to solely control the defense or +settlement of the claim. Costs. Liquibase will pay infringement claim defense +costs incurred as part of its obligations above, and Liquibase negotiated +settlement amounts, and court awarded damages. Process. If such a claim appears +likely, then Liquibase may modify the Software, procure the necessary rights, or +replace it with the functional equivalent. If Liquibase determines that none of +these are reasonably available, then Liquibase may terminate the Software and +refund any prepaid and unused fees. Exclusions. Liquibase has no obligation for +any claim arising from: Liquibase’s compliance with Customer’s specifications; A +combination of the Software with other technology where the infringement would +not occur but for the combination; or Technology not provided by Liquibase. THIS +SECTION CONTAINS CUSTOMER’S EXCLUSIVE REMEDIES AND LIQUIBASE’S SOLE LIABILITY FOR +INTELLECTUAL PROPERTY INFRINGEMENT CLAIMS. + +9. GOVERNING LAW AND EXCLUSIVE FORUM. This agreement is governed by the laws of +the State of Delaware (without regard to conflicts of law principles) for any +dispute between the parties or relating in any way to the subject matter of +this agreement. Any suit or legal proceeding must be exclusively brought in the +federal or state courts for Travis County, Texas, and Customer submits to this +personal jurisdiction and venue. Nothing in this agreement prevents either +party from seeking injunctive relief in a court of competent jurisdiction. The +prevailing party in litigation is entitled to recover its attorneys’ fees and +costs from the other party. + +10. OTHER TERMS. +a. Entire Agreement. This agreement and the order constitute the entire +agreement between the parties and supersede any prior or contemporaneous +negotiations or agreements, whether oral or written, related to this subject +matter. Customer is not relying on any representation concerning this subject +matter, oral or written, not included in this agreement. No representation, +promise or inducement not included in this agreement is binding. +b. Non-Assignment. Neither party may assign or transfer this agreement to a +third party, nor delegate any duty, except that the agreement and all orders +may be assigned, without the consent of the other party, as part of a merger, +or sale of all or substantially all of the business or assets, of a party. +c. Independent Contractors. The parties are independent contractors with +respect to each other. +d. Enforceability. If any term of this agreement is invalid or unenforceable, +the other terms remain in effect. +e. Survival of Terms and Force Majeure. All terms that by their nature survive +termination of this agreement for each party to receive the benefits and +protections of this agreement, will survive. Neither party is liable for events +beyond its reasonable control, including, without limitation force majeure +events. +f. Modification Only in Writing. No modification or waiver of any term of this +agreement is effective unless signed by both parties. +g. Export Compliance. Customer must comply with all applicable export control +laws of the United States, foreign jurisdictions and other applicable laws and +regulations. +h. US GOVERNMENT RESTRICTED RIGHTS. If Customer is a United States government +agency or acquired the license to the Software hereunder pursuant to a +government contract or with government funds, then as defined in FAR §2.101, +DFAR §252.227-7014(a)(1) and DFAR §252.227-7014(a)(5) or otherwise, all +Software provided in connection with this agreement are “commercial items,” +“commercial computer software” or “commercial computer software documentation.” +Consistent with DFAR §227.7202 and FAR §12.212, any use, modification, +reproduction, release, performance, display, disclosure or distribution by or +for the United States government is governed solely by the terms of this +agreement and is prohibited except to the extent permitted by the terms of this +agreement. +i. No PO Terms. Liquibase rejects conflicting terms of a Customer’s +form-purchasing document. +j. Order of Precedence. If there is an inconsistency between this agreement and +an order, the order prevails. diff --git a/liquibase-4.9.1/licenses/README.txt b/liquibase-4.9.1/licenses/README.txt new file mode 100644 index 0000000..6e4be8a --- /dev/null +++ b/liquibase-4.9.1/licenses/README.txt @@ -0,0 +1,87 @@ +Liquibase License Information +Version: 4.9.1 + +Liquibase ships with 3rd party components using the following licenses: + +- Apache 2.0 License - https://opensource.org/licenses/Apache-2.0 +- BSD 2 Clause License - https://opensource.org/licenses/BSD-2-Clause +- CDDL 1.1 License - https://opensource.org/licenses/cddl1.txt +- CPL 1.0 License - https://opensource.org/licenses/CPL-1.0 +- Eclipse Public 1.0 License - https://opensource.org/licenses/epl-1.0 +- ISC License - https://opensource.org/licenses/ISC +- LPGL 3.0 License - https://opensource.org/licenses/LGPL-3.0 +- MIT License - https://opensource.org/licenses/MIT +- Plexus Classworlds License - https://spdx.org/licenses/Plexus.html + +Libraries and their licenses: + +Apache 2.0 License +- avalon-framework:avalon-framework +- commons-logging:commons-logging +- doxia:doxia-sink-api +- javax.enterprise:cdi-api +- javax.inject:javax.inject +- org.apache.ant:ant +- org.apache.ant:ant-launcher +- org.apache.maven:maven-artifact +- org.apache.maven:maven-artifact-manager +- org.apache.maven:maven-core +- org.apache.maven:maven-error-diagnostics +- org.apache.maven:maven-model +- org.apache.maven:maven-monitor +- org.apache.maven:maven-plugin-api +- org.apache.maven:maven-plugin-descriptor +- org.apache.maven:maven-plugin-parameter-documenter +- org.apache.maven:maven-plugin-registry +- org.apache.maven:maven-profile +- org.apache.maven:maven-project +- org.apache.maven:maven-repository-metadata +- org.apache.maven:maven-settings +- org.apache.maven.reporting:maven-reporting-api +- org.apache.maven.shared:maven-plugin-testing-harness +- org.apache.maven.shared:maven-verifier +- org.apache.maven.wagon:wagon-file +- org.apache.maven.wagon:wagon-http-lightweight +- org.apache.maven.wagon:wagon-provider-api +- org.apache.maven.wagon:wagon-ssh +- org.codehaus.plexus:plexus-archiver +- org.codehaus.plexus:plexus-container-default +- org.codehaus.plexus:plexus-interactivity-api +- org.codehaus.plexus:plexus-utils +- org.jboss.weld.se:weld-se +- org.liquibase:liquibase-cdi +- org.liquibase:liquibase-core +- org.liquibase:liquibase-debian +- org.liquibase:liquibase-maven-plugin +- org.liquibase:liquibase-parent +- org.springframework:spring +- org.yaml:snakeyaml +- snakeyaml.jar + +BSD 2 Clause License +- com.jcraft:jsch +- org.hamcrest:hamcrest-core +- org.hsqldb:hsqldb +- org.postgresql:postgresql + +CDDL 1.1 License +- javax.annotation:jsr250-api +- javax.servlet:servlet-api (Dual license: CDDL-1.1, GPL-2.0) +- jaxb-api.jar +- jaxb-core.jar +- jaxb-impl.jar + +CPL 1.0 License +- junit:junit + +Eclipse Public License 1.0 +- h2.jar + +ISC License +- logkit:logkit + +LGPL-3.0 license +- org.jboss.spec.javax.interceptor:jboss-interceptors-api_1.1_spec + +Plexus Classworlds License +- classworlds:classworlds diff --git a/liquibase-4.9.1/licenses/apache-2.0.txt b/liquibase-4.9.1/licenses/apache-2.0.txt new file mode 100644 index 0000000..8e77af1 --- /dev/null +++ b/liquibase-4.9.1/licenses/apache-2.0.txt @@ -0,0 +1,65 @@ +Apache License +Version 2.0, January 2004 +http://www.apache.org/licenses/ + +TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + +1. Definitions. + +"License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. + +"Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. + +"Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. + +"You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. + +"Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. + +"Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. + +"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). + +"Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. + +"Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." + +"Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. + +2. Grant of Copyright License. + +Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. + +3. Grant of Patent License. + +Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. + +4. Redistribution. + +You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: + +You must give any other recipients of the Work or Derivative Works a copy of this License; and +You must cause any modified files to carry prominent notices stating that You changed the files; and +You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and +If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. +You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. + +5. Submission of Contributions. + +Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. + +6. Trademarks. + +This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. + +7. Disclaimer of Warranty. + +Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. + +8. Limitation of Liability. + +In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. + +9. Accepting Warranty or Additional Liability. + +While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. diff --git a/liquibase-4.9.1/licenses/bsd-2-clause.txt b/liquibase-4.9.1/licenses/bsd-2-clause.txt new file mode 100644 index 0000000..66e2f1d --- /dev/null +++ b/liquibase-4.9.1/licenses/bsd-2-clause.txt @@ -0,0 +1,9 @@ +The 2-Clause BSD License + +Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: + +1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. + +2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/liquibase-4.9.1/licenses/cddl1.txt b/liquibase-4.9.1/licenses/cddl1.txt new file mode 100644 index 0000000..07ee90a --- /dev/null +++ b/liquibase-4.9.1/licenses/cddl1.txt @@ -0,0 +1,131 @@ +COMMON DEVELOPMENT AND DISTRIBUTION LICENSE (CDDL) Version 1.0 + +1. Definitions. + +1.1. "Contributor" means each individual or entity that creates or contributes to the creation of Modifications. + +1.2. "Contributor Version" means the combination of the Original Software, prior Modifications used by a Contributor (if any), and the Modifications made by that particular Contributor. + +1.3. "Covered Software" means (a) the Original Software, or (b) Modifications, or (c) the combination of files containing Original Software with files containing Modifications, in each case including portions thereof. + +1.4. "Executable" means the Covered Software in any form other than Source Code. + +1.5. "Initial Developer" means the individual or entity that first makes Original Software available under this License. + +1.6. "Larger Work" means a work which combines Covered Software or portions thereof with code not governed by the terms of this License. + +1.7. "License" means this document. + +1.8. "Licensable" means having the right to grant, to the maximum extent possible, whether at the time of the initial grant or subsequently acquired, any and all of the rights conveyed herein. + +1.9. "Modifications" means the Source Code and Executable form of any of the following: + +A. Any file that results from an addition to, deletion from or modification of the contents of a file containing Original Software or previous Modifications; + +B. Any new file that contains any part of the Original Software or previous Modification; or + +C. Any new file that is contributed or otherwise made available under the terms of this License. + +1.10. "Original Software" means the Source Code and Executable form of computer software code that is originally released under this License. + +1.11. "Patent Claims" means any patent claim(s), now owned or hereafter acquired, including without limitation, method, process, and apparatus claims, in any patent Licensable by grantor. + +1.12. "Source Code" means (a) the common form of computer software code in which modifications are made and (b) associated documentation included in or with such code. + +1.13. "You" (or "Your") means an individual or a legal entity exercising rights under, and complying with all of the terms of, this License. For legal entities, "You" includes any entity which controls, is controlled by, or is under common control with You. For purposes of this definition, "control" means (a) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (b) ownership of more than fifty percent (50%) of the outstanding shares or beneficial ownership of such entity. + +2. License Grants. + +2.1. The Initial Developer Grant. + +Conditioned upon Your compliance with Section 3.1 below and subject to third party intellectual property claims, the Initial Developer hereby grants You a world-wide, royalty-free, non-exclusive license: + +(a) under intellectual property rights (other than patent or trademark) Licensable by Initial Developer, to use, reproduce, modify, display, perform, sublicense and distribute the Original Software (or portions thereof), with or without Modifications, and/or as part of a Larger Work; and + +(b) under Patent Claims infringed by the making, using or selling of Original Software, to make, have made, use, practice, sell, and offer for sale, and/or otherwise dispose of the Original Software (or portions thereof). + +(c) The licenses granted in Sections 2.1(a) and (b) are effective on the date Initial Developer first distributes or otherwise makes the Original Software available to a third party under the terms of this License. + +(d) Notwithstanding Section 2.1(b) above, no patent license is granted: (1) for code that You delete from the Original Software, or (2) for infringements caused by: (i) the modification of the Original Software, or (ii) the combination of the Original Software with other software or devices. + +2.2. Contributor Grant. + +Conditioned upon Your compliance with Section 3.1 below and +subject to third party intellectual property claims, each +Contributor hereby grants You a world-wide, royalty-free, +non-exclusive license: + +(a) under intellectual property rights (other than patent or trademark) Licensable by Contributor to use, reproduce, modify, display, perform, sublicense and distribute the Modifications created by such Contributor (or portions thereof), either on an unmodified basis, with other Modifications, as Covered Software and/or as part of a Larger Work; and + +(b) under Patent Claims infringed by the making, using, or selling of Modifications made by that Contributor either alone and/or in combination with its Contributor Version (or portions of such combination), to make, use, sell, offer for sale, have made, and/or otherwise dispose of: (1) Modifications made by that Contributor (or portions thereof); and (2) the combination of Modifications made by that Contributor with its Contributor Version (or portions of such combination). + +(c) The licenses granted in Sections 2.2(a) and 2.2(b) are effective on the date Contributor first distributes or otherwise makes the Modifications available to a third party. +(d) Notwithstanding Section 2.2(b) above, no patent license is granted: (1) for any code that Contributor has deleted from the Contributor Version; (2) for infringements caused by: (i) third party modifications of Contributor Version, or (ii) the combination of Modifications made by that Contributor with other software (except as part of the Contributor Version) or other devices; or (3) under Patent Claims infringed by Covered Software in the absence of Modifications made by that Contributor. + +3. Distribution Obligations. + +3.1. Availability of Source Code. + +Any Covered Software that You distribute or otherwise make available in Executable form must also be made available in Source Code form and that Source Code form must be distributed only under the terms of this License. You must include a copy of this License with every copy of the Source Code form of the Covered Software You distribute or otherwise make available. You must inform recipients of any such Covered Software in Executable form as to how they can obtain such Covered Software in Source Code form in a reasonable manner on or through a medium customarily used for software exchange. + +3.2. Modifications. + +The Modifications that You create or to which You contribute are governed by the terms of this License. You represent that You believe Your Modifications are Your original creation(s) and/or You have sufficient rights to grant the rights conveyed by this License. + +3.3. Required Notices. + +You must include a notice in each of Your Modifications that identifies You as the Contributor of the Modification. You may not remove or alter any copyright, patent or trademark notices contained within the Covered Software, or any notices of licensing or any descriptive text giving attribution to any Contributor or the Initial Developer. + +3.4. Application of Additional Terms. + +You may not offer or impose any terms on any Covered Software in Source Code form that alters or restricts the applicable version of this License or the recipients' rights hereunder. You may choose to offer, and to charge a fee for, warranty, support, indemnity or liability obligations to one or more recipients of Covered Software. However, you may do so only on Your own behalf, and not on behalf of the Initial Developer or any Contributor. You must make it absolutely clear that any such warranty, support, indemnity or liability obligation is offered by You alone, and You hereby agree to indemnify the Initial Developer and every Contributor for any liability incurred by the Initial Developer or such Contributor as a result of warranty, support, indemnity or liability terms You offer. + +3.5. Distribution of Executable Versions. + +You may distribute the Executable form of the Covered Software under the terms of this License or under the terms of a license of Your choice, which may contain terms different from this License, provided that You are in compliance with the terms of this License and that the license for the Executable form does not attempt to limit or alter the recipient's rights in the Source Code form from the rights set forth in this License. If You distribute the Covered Software in Executable form under a different license, You must make it absolutely clear that any terms which differ from this License are offered by You alone, not by the Initial Developer or Contributor. You hereby agree to indemnify the Initial Developer and every Contributor for any liability incurred by the Initial Developer or such Contributor as a result of any such terms You offer. + +3.6. Larger Works. + +You may create a Larger Work by combining Covered Software with other code not governed by the terms of this License and distribute the Larger Work as a single product. In such a case, You must make sure the requirements of this License are fulfilled for the Covered Software. + +4. Versions of the License. + +4.1. New Versions. + +Sun Microsystems, Inc. is the initial license steward and may publish revised and/or new versions of this License from time to time. Each version will be given a distinguishing version number. Except as provided in Section 4.3, no one other than the license steward has the right to modify this License. + +4.2. Effect of New Versions. + +You may always continue to use, distribute or otherwise make the Covered Software available under the terms of the version of the License under which You originally received the Covered Software. If the Initial Developer includes a notice in the Original Software prohibiting it from being distributed or otherwise made available under any subsequent version of the License, You must distribute and make the Covered Software available under the terms of the version of the License under which You originally received the Covered Software. Otherwise, You may also choose to use, distribute or otherwise make the Covered Software available under the terms of any subsequent version of the License published by the license steward. + +4.3. Modified Versions. + +When You are an Initial Developer and You want to create a new license for Your Original Software, You may create and use a modified version of this License if You: (a) rename the license and remove any references to the name of the license steward (except to note that the license differs from this License); and (b) otherwise make it clear that the license contains terms which differ from this License. + +5. DISCLAIMER OF WARRANTY. + +COVERED SOFTWARE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES THAT THE COVERED SOFTWARE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED SOFTWARE IS WITH YOU. SHOULD ANY COVERED SOFTWARE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF ANY COVERED SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER. + +6. TERMINATION. + +6.1. This License and the rights granted hereunder will terminate automatically if You fail to comply with terms herein and fail to cure such breach within 30 days of becoming aware of the breach. Provisions which, by their nature, must remain in effect beyond the termination of this License shall survive. + +6.2. If You assert a patent infringement claim (excluding declaratory judgment actions) against Initial Developer or a Contributor (the Initial Developer or Contributor against whom You assert such claim is referred to as "Participant") alleging that the Participant Software (meaning the Contributor Version where the Participant is a Contributor or the Original Software where the Participant is the Initial Developer) directly or indirectly infringes any patent, then any and all rights granted directly or indirectly to You by such Participant, the Initial Developer (if the Initial Developer is not the Participant) and all Contributors under Sections 2.1 and/or 2.2 of this License shall, upon 60 days notice from Participant terminate prospectively and automatically at the expiration of such 60 day notice period, unless if within such 60 day period You withdraw Your claim with respect to the Participant Software against such Participant either unilaterally or pursuant to a written agreement with Participant. + +6.3. In the event of termination under Sections 6.1 or 6.2 above, all end user licenses that have been validly granted by You or any distributor hereunder prior to termination (excluding licenses granted to You by any distributor) shall survive termination. + +7. LIMITATION OF LIABILITY. + +UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT (INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED SOFTWARE, OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOST PROFITS, LOSS OF GOODWILL, WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU. + +8. U.S. GOVERNMENT END USERS. + +The Covered Software is a "commercial item," as that term is defined in 48 C.F.R. 2.101 (Oct. 1995), consisting of "commercial computer software" (as that term is defined at 48 C.F.R. ¤ 252.227-7014(a)(1)) and "commercial computer software documentation" as such terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48 C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995), all U.S. Government End Users acquire Covered Software with only those rights set forth herein. This U.S. Government Rights clause is in lieu of, and supersedes, any other FAR, DFAR, or other clause or provision that addresses Government rights in computer software under this License. + +9. MISCELLANEOUS. + +This License represents the complete agreement concerning subject matter hereof. If any provision of this License is held to be unenforceable, such provision shall be reformed only to the extent necessary to make it enforceable. This License shall be governed by the law of the jurisdiction specified in a notice contained within the Original Software (except to the extent applicable law, if any, provides otherwise), excluding such jurisdiction's conflict-of-law provisions. Any litigation relating to this License shall be subject to the jurisdiction of the courts located in the jurisdiction and venue specified in a notice contained within the Original Software, with the losing party responsible for costs, including, without limitation, court costs and reasonable attorneys' fees and expenses. The application of the United Nations Convention on Contracts for the International Sale of Goods is expressly excluded. Any law or regulation which provides that the language of a contract shall be construed against the drafter shall not apply to this License. You agree that You alone are responsible for compliance with the United States export administration regulations (and the export control laws and regulation of any other countries) when You use, distribute or otherwise make available any Covered Software. + +10. RESPONSIBILITY FOR CLAIMS. + +As between Initial Developer and the Contributors, each party is responsible for claims and damages arising, directly or indirectly, out of its utilization of rights under this License and You agree to work with Initial Developer and Contributors to distribute such responsibility on an equitable basis. Nothing herein is intended or shall be deemed to constitute any admission of liability. diff --git a/liquibase-4.9.1/licenses/cpl-1.0.txt b/liquibase-4.9.1/licenses/cpl-1.0.txt new file mode 100644 index 0000000..22527e7 --- /dev/null +++ b/liquibase-4.9.1/licenses/cpl-1.0.txt @@ -0,0 +1,211 @@ +THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THIS COMMON PUBLIC +LICENSE ("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THE PROGRAM +CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS AGREEMENT. + +1. DEFINITIONS + +"Contribution" means: + + a) in the case of the initial Contributor, the initial code and +documentation distributed under this Agreement, and + + b) in the case of each subsequent Contributor: + + i) changes to the Program, and + + ii) additions to the Program; + + where such changes and/or additions to the Program originate from and are +distributed by that particular Contributor. A Contribution 'originates' from a +Contributor if it was added to the Program by such Contributor itself or anyone +acting on such Contributor's behalf. Contributions do not include additions to +the Program which: (i) are separate modules of software distributed in +conjunction with the Program under their own license agreement, and (ii) are not +derivative works of the Program. + +"Contributor" means any person or entity that distributes the Program. + +"Licensed Patents " mean patent claims licensable by a Contributor which are +necessarily infringed by the use or sale of its Contribution alone or when +combined with the Program. + +"Program" means the Contributions distributed in accordance with this Agreement. + +"Recipient" means anyone who receives the Program under this Agreement, +including all Contributors. + +2. GRANT OF RIGHTS + + a) Subject to the terms of this Agreement, each Contributor hereby grants +Recipient a non-exclusive, worldwide, royalty-free copyright license to +reproduce, prepare derivative works of, publicly display, publicly perform, +distribute and sublicense the Contribution of such Contributor, if any, and such +derivative works, in source code and object code form. + + b) Subject to the terms of this Agreement, each Contributor hereby grants +Recipient a non-exclusive, worldwide, royalty-free patent license under Licensed +Patents to make, use, sell, offer to sell, import and otherwise transfer the +Contribution of such Contributor, if any, in source code and object code form. +This patent license shall apply to the combination of the Contribution and the +Program if, at the time the Contribution is added by the Contributor, such +addition of the Contribution causes such combination to be covered by the +Licensed Patents. The patent license shall not apply to any other combinations +which include the Contribution. No hardware per se is licensed hereunder. + + c) Recipient understands that although each Contributor grants the licenses +to its Contributions set forth herein, no assurances are provided by any +Contributor that the Program does not infringe the patent or other intellectual +property rights of any other entity. Each Contributor disclaims any liability to +Recipient for claims brought by any other entity based on infringement of +intellectual property rights or otherwise. As a condition to exercising the +rights and licenses granted hereunder, each Recipient hereby assumes sole +responsibility to secure any other intellectual property rights needed, if any. +For example, if a third party patent license is required to allow Recipient to +distribute the Program, it is Recipient's responsibility to acquire that license +before distributing the Program. + + d) Each Contributor represents that to its knowledge it has sufficient +copyright rights in its Contribution, if any, to grant the copyright license set +forth in this Agreement. + +3. REQUIREMENTS + +A Contributor may choose to distribute the Program in object code form under its +own license agreement, provided that: + + a) it complies with the terms and conditions of this Agreement; and + + b) its license agreement: + + i) effectively disclaims on behalf of all Contributors all warranties and +conditions, express and implied, including warranties or conditions of title and +non-infringement, and implied warranties or conditions of merchantability and +fitness for a particular purpose; + + ii) effectively excludes on behalf of all Contributors all liability for +damages, including direct, indirect, special, incidental and consequential +damages, such as lost profits; + + iii) states that any provisions which differ from this Agreement are offered +by that Contributor alone and not by any other party; and + + iv) states that source code for the Program is available from such +Contributor, and informs licensees how to obtain it in a reasonable manner on or +through a medium customarily used for software exchange. + +When the Program is made available in source code form: + + a) it must be made available under this Agreement; and + + b) a copy of this Agreement must be included with each copy of the Program. + +Contributors may not remove or alter any copyright notices contained within the +Program. + +Each Contributor must identify itself as the originator of its Contribution, if +any, in a manner that reasonably allows subsequent Recipients to identify the +originator of the Contribution. + +4. COMMERCIAL DISTRIBUTION + +Commercial distributors of software may accept certain responsibilities with +respect to end users, business partners and the like. While this license is +intended to facilitate the commercial use of the Program, the Contributor who +includes the Program in a commercial product offering should do so in a manner +which does not create potential liability for other Contributors. Therefore, if +a Contributor includes the Program in a commercial product offering, such +Contributor ("Commercial Contributor") hereby agrees to defend and indemnify +every other Contributor ("Indemnified Contributor") against any losses, damages +and costs (collectively "Losses") arising from claims, lawsuits and other legal +actions brought by a third party against the Indemnified Contributor to the +extent caused by the acts or omissions of such Commercial Contributor in +connection with its distribution of the Program in a commercial product +offering. The obligations in this section do not apply to any claims or Losses +relating to any actual or alleged intellectual property infringement. In order +to qualify, an Indemnified Contributor must: a) promptly notify the Commercial +Contributor in writing of such claim, and b) allow the Commercial Contributor to +control, and cooperate with the Commercial Contributor in, the defense and any +related settlement negotiations. The Indemnified Contributor may participate in +any such claim at its own expense. + +For example, a Contributor might include the Program in a commercial product +offering, Product X. That Contributor is then a Commercial Contributor. If that +Commercial Contributor then makes performance claims, or offers warranties +related to Product X, those performance claims and warranties are such +Commercial Contributor's responsibility alone. Under this section, the +Commercial Contributor would have to defend claims against the other +Contributors related to those performance claims and warranties, and if a court +requires any other Contributor to pay any damages as a result, the Commercial +Contributor must pay those damages. + +5. NO WARRANTY + +EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, THE PROGRAM IS PROVIDED ON AN +"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR +IMPLIED INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, +NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each +Recipient is solely responsible for determining the appropriateness of using and +distributing the Program and assumes all risks associated with its exercise of +rights under this Agreement, including but not limited to the risks and costs of +program errors, compliance with applicable laws, damage to or loss of data, +programs or equipment, and unavailability or interruption of operations. + +6. DISCLAIMER OF LIABILITY + +EXCEPT AS EXPRESSLY SET FORTH IN THIS AGREEMENT, NEITHER RECIPIENT NOR ANY +CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY DIRECT, INDIRECT, INCIDENTAL, +SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING WITHOUT LIMITATION LOST +PROFITS), HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, +STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY +OUT OF THE USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS +GRANTED HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + +7. GENERAL + +If any provision of this Agreement is invalid or unenforceable under applicable +law, it shall not affect the validity or enforceability of the remainder of the +terms of this Agreement, and without further action by the parties hereto, such +provision shall be reformed to the minimum extent necessary to make such +provision valid and enforceable. + +If Recipient institutes patent litigation against a Contributor with respect to +a patent applicable to software (including a cross-claim or counterclaim in a +lawsuit), then any patent licenses granted by that Contributor to such Recipient +under this Agreement shall terminate as of the date such litigation is filed. In +addition, if Recipient institutes patent litigation against any entity +(including a cross-claim or counterclaim in a lawsuit) alleging that the Program +itself (excluding combinations of the Program with other software or hardware) +infringes such Recipient's patent(s), then such Recipient's rights granted under +Section 2(b) shall terminate as of the date such litigation is filed. + +All Recipient's rights under this Agreement shall terminate if it fails to +comply with any of the material terms or conditions of this Agreement and does +not cure such failure in a reasonable period of time after becoming aware of +such noncompliance. If all Recipient's rights under this Agreement terminate, +Recipient agrees to cease use and distribution of the Program as soon as +reasonably practicable. However, Recipient's obligations under this Agreement +and any licenses granted by Recipient relating to the Program shall continue and +survive. + +Everyone is permitted to copy and distribute copies of this Agreement, but in +order to avoid inconsistency the Agreement is copyrighted and may only be +modified in the following manner. The Agreement Steward reserves the right to +publish new versions (including revisions) of this Agreement from time to time. +No one other than the Agreement Steward has the right to modify this Agreement. +IBM is the initial Agreement Steward. IBM may assign the responsibility to serve +as the Agreement Steward to a suitable separate entity. Each new version of the +Agreement will be given a distinguishing version number. The Program (including +Contributions) may always be distributed subject to the version of the Agreement +under which it was received. In addition, after a new version of the Agreement +is published, Contributor may elect to distribute the Program (including its +Contributions) under the new version. Except as expressly stated in Sections +2(a) and 2(b) above, Recipient receives no rights or licenses to the +intellectual property of any Contributor under this Agreement, whether +expressly, by implication, estoppel or otherwise. All rights in the Program not +expressly granted under this Agreement are reserved. + +This Agreement is governed by the laws of the State of New York and the +intellectual property laws of the United States of America. No party to this +Agreement will bring a legal action under this Agreement more than one year +after the cause of action arose. Each party waives its rights to a jury trial in +any resulting litigation. diff --git a/liquibase-4.9.1/licenses/epl-1.0.txt b/liquibase-4.9.1/licenses/epl-1.0.txt new file mode 100644 index 0000000..bff9389 --- /dev/null +++ b/liquibase-4.9.1/licenses/epl-1.0.txt @@ -0,0 +1,63 @@ +GNU LESSER GENERAL PUBLIC LICENSE +Version 3, 29 June 2007 + +Copyright (C) 2007 Free Software Foundation, Inc. + +Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. + +This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. + +0. Additional Definitions. + +As used herein, “this License” refers to version 3 of the GNU Lesser General Public License, and the “GNU GPL” refers to version 3 of the GNU General Public License. + +“The Library” refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. + +An “Application” is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. + +A “Combined Work” is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the “Linked Version”. + +The “Minimal Corresponding Source” for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. + +The “Corresponding Application Code” for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. + +1. Exception to Section 3 of the GNU GPL. + +You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. + +2. Conveying Modified Versions. + +If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: + +a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or +b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. +3. Object Code Incorporating Material from Library Header Files. + +The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: + +a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. +b) Accompany the object code with a copy of the GNU GPL and this license document. +4. Combined Works. + +You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: + +a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. +b) Accompany the Combined Work with a copy of the GNU GPL and this license document. +c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. +d) Do one of the following: +0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. +1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. +e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) +5. Combined Libraries. + +You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: + +a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. +b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. +6. Revised Versions of the GNU Lesser General Public License. + +The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License “or any later version” applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. + +If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. diff --git a/liquibase-4.9.1/licenses/isc.txt b/liquibase-4.9.1/licenses/isc.txt new file mode 100644 index 0000000..7161f52 --- /dev/null +++ b/liquibase-4.9.1/licenses/isc.txt @@ -0,0 +1,3 @@ +Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies. + +THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. diff --git a/liquibase-4.9.1/licenses/lgpl-3.0.txt b/liquibase-4.9.1/licenses/lgpl-3.0.txt new file mode 100644 index 0000000..f2598e8 --- /dev/null +++ b/liquibase-4.9.1/licenses/lgpl-3.0.txt @@ -0,0 +1,125 @@ +GNU LESSER GENERAL PUBLIC LICENSE +Version 3, 29 June 2007 + +Copyright (C) 2007 Free Software Foundation, Inc. + +Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. + +This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. + +0. Additional Definitions. + +As used herein, “this License” refers to version 3 of the GNU Lesser General Public License, and the “GNU GPL” refers to version 3 of the GNU General Public License. + +“The Library” refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. + +An “Application” is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. + +A “Combined Work” is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the “Linked Version”. + +The “Minimal Corresponding Source” for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. + +The “Corresponding Application Code” for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. + +1. Exception to Section 3 of the GNU GPL. + +You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. + +2. Conveying Modified Versions. + +If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: + +a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or +b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. +3. Object Code Incorporating Material from Library Header Files. + +The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: + +a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. +b) Accompany the object code with a copy of the GNU GPL and this license document. +4. Combined Works. + +You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: + +a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. +b) Accompany the Combined Work with a copy of the GNU GPL and this license document. +c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. +d) Do one of the following: +0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. +1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. +e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) +5. Combined Libraries. + +You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: + +a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. +b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. +6. Revised Versions of the GNU Lesser General Public License. + +The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License “or any later version” applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. + +If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library.GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + + Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. + + This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, “this License” refers to version 3 of the GNU Lesser General Public License, and the “GNU GPL” refers to version 3 of the GNU General Public License. + + “The Library” refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. + + An “Application” is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. + + A “Combined Work” is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the “Linked Version”. + + The “Minimal Corresponding Source” for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. + + The “Corresponding Application Code” for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: + + a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or + b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. + b) Accompany the object code with a copy of the GNU GPL and this license document. + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: + + a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. + b) Accompany the Combined Work with a copy of the GNU GPL and this license document. + c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. + d) Do one of the following: + 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. + 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. + e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) + 5. Combined Libraries. + + You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. + b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License “or any later version” applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. diff --git a/liquibase-4.9.1/licenses/mit.txt b/liquibase-4.9.1/licenses/mit.txt new file mode 100644 index 0000000..fe45399 --- /dev/null +++ b/liquibase-4.9.1/licenses/mit.txt @@ -0,0 +1,6 @@ +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + diff --git a/liquibase-4.9.1/licenses/plexus.txt b/liquibase-4.9.1/licenses/plexus.txt new file mode 100644 index 0000000..dd4aa9a --- /dev/null +++ b/liquibase-4.9.1/licenses/plexus.txt @@ -0,0 +1,40 @@ + Copyright 2002 (C) The Codehaus. All Rights Reserved. + + Redistribution and use of this software and associated documentation + ("Software"), with or without modification, are permitted provided + that the following conditions are met: + + 1. Redistributions of source code must retain copyright + statements and notices. Redistributions must also contain a + copy of this document. + + 2. Redistributions in binary form must reproduce the + above copyright notice, this list of conditions and the + following disclaimer in the documentation and/or other + materials provided with the distribution. + + 3. The name "classworlds" must not be used to endorse or promote + products derived from this Software without prior written + permission of The Codehaus. For written permission, please + contact bob@codehaus.org. + + 4. Products derived from this Software may not be called "classworlds" + nor may "classworlds" appear in their names without prior written + permission of The Codehaus. "classworlds" is a registered + trademark of The Codehaus. + + 5. Due credit should be given to The Codehaus. + (http://classworlds.codehaus.org/). + + THIS SOFTWARE IS PROVIDED BY THE CODEHAUS AND CONTRIBUTORS + ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT + NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND + FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL + THE CODEHAUS OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, + INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, + STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED + OF THE POSSIBILITY OF SUCH DAMAGE. diff --git a/liquibase-4.9.1/liquibase b/liquibase-4.9.1/liquibase new file mode 100755 index 0000000..4b5b25c --- /dev/null +++ b/liquibase-4.9.1/liquibase @@ -0,0 +1,91 @@ +#!/usr/bin/env bash + +if [ ! -n "${LIQUIBASE_HOME+x}" ]; then + # echo "LIQUIBASE_HOME is not set." + + ## resolve links - $0 may be a symlink + PRG="$0" + while [ -h "$PRG" ] ; do + ls=`ls -ld "$PRG"` + link=`expr "$ls" : '.*-> \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi + done + + + LIQUIBASE_HOME=`dirname "$PRG"` + + # make it fully qualified + LIQUIBASE_HOME=`cd "$LIQUIBASE_HOME" && pwd` + # echo "Liquibase Home: $LIQUIBASE_HOME" +fi + + +# build classpath from all jars in lib +if [ -f /usr/bin/cygpath ]; then + CP=. + for i in "$LIQUIBASE_HOME"/liquibase*.jar; do + i=`cygpath --windows "$i"` + CP="$CP;$i" + done + + # Gather jars from a local liquibase_libs directory + for i in liquibase_libs/*.jar; do + i=`cygpath --windows "$i"` + CP="$CP;$i" + done + + for i in "$LIQUIBASE_HOME"/lib/*.jar; do + i=`cygpath --windows "$i"` + CP="$CP;$i" + done +else + if [[ $(uname) = MINGW* ]]; then + CP_SEPARATOR=";" + else + CP_SEPARATOR=":" + fi + CP=. + for i in "$LIQUIBASE_HOME"/liquibase*.jar; do + CP="$CP""$CP_SEPARATOR""$i" + done + + # Gather jars from a local liquibase_libs directory + CP="$CP""$CP_SEPARATOR""liquibase_libs/" + for i in liquibase_libs/*.jar; do + CP="$CP""$CP_SEPARATOR""$i" + done + + CP="$CP""$CP_SEPARATOR""$LIQUIBASE_HOME/lib/" + for i in "$LIQUIBASE_HOME"/lib/*.jar; do + CP="$CP""$CP_SEPARATOR""$i" + done +fi + +if [ -z "${JAVA_HOME}" ]; then + #JAVA_HOME not set, try to find a bundled version + if [ -d "${LIQUIBASE_HOME}/jre" ]; then + JAVA_HOME="$LIQUIBASE_HOME/jre" + elif [ -d "${LIQUIBASE_HOME}/.install4j/jre.bundle/Contents/Home" ]; then + JAVA_HOME="${LIQUIBASE_HOME}/.install4j/jre.bundle/Contents/Home" + fi +fi + +if [ -z "${JAVA_HOME}" ]; then + JAVA_PATH="$(which java)" + + if [ -z "${JAVA_PATH}" ]; then + echo "Cannot find java in your path. Install java or use the JAVA_HOME environment variable" + fi +else + #Use path in JAVA_HOME + JAVA_PATH="${JAVA_HOME}/bin/java" +fi + +# add any JVM options here +JAVA_OPTS="${JAVA_OPTS-}" + +"${JAVA_PATH}" -cp "$CP" $JAVA_OPTS liquibase.integration.commandline.LiquibaseCommandLine ${1+"$@"} diff --git a/liquibase-4.9.1/liquibase.bat b/liquibase-4.9.1/liquibase.bat new file mode 100644 index 0000000..d49a6f4 --- /dev/null +++ b/liquibase-4.9.1/liquibase.bat @@ -0,0 +1,37 @@ +@echo off +if "%OS%" == "Windows_NT" setlocal + +setlocal enabledelayedexpansion + +rem %~dp0 is expanded pathname of the current script under NT +set LIQUIBASE_HOME="%~dp0" + +set CP=. +for /R %LIQUIBASE_HOME% %%f in (liquibase*.jar) do set CP=!CP!;%%f +for /R liquibase_libs %%f in (*.jar) do set CP=!CP!;%%f +for /R %LIQUIBASE_HOME%\lib %%f in (*.jar) do set CP=!CP!;%%f + +rem remove quotes around LIQUIBASE_HOME +set LIQUIBASE_HOME=%LIQUIBASE_HOME:"=% + +rem remove quotes around JAVA_HOME if set +if NOT "%JAVA_HOME%" == "" set JAVA_HOME=%JAVA_HOME:"=% + +rem set JAVA_HOME to local jre dir if not set +if exist "%LIQUIBASE_HOME%\jre" if "%JAVA_HOME%"=="" ( + set JAVA_HOME=%LIQUIBASE_HOME%\jre +) + + +rem add the lib directory itself to the classpath +set CP=!CP!;!LIQUIBASE_HOME!lib + +rem special characters may be lost +setlocal DISABLEDELAYEDEXPANSION + +IF NOT DEFINED JAVA_OPTS set JAVA_OPTS= + +set JAVA_PATH=java +if NOT "%JAVA_HOME%" == "" set JAVA_PATH=%JAVA_HOME%\bin\java + +"%JAVA_PATH%" -cp "%CP%" %JAVA_OPTS% liquibase.integration.commandline.LiquibaseCommandLine %* diff --git a/liquibase-4.9.1/liquibase.jar b/liquibase-4.9.1/liquibase.jar new file mode 100644 index 0000000..b2b1778 Binary files /dev/null and b/liquibase-4.9.1/liquibase.jar differ diff --git a/liquibase-4.9.1/liquibase.properties b/liquibase-4.9.1/liquibase.properties new file mode 100644 index 0000000..b79d3e2 --- /dev/null +++ b/liquibase-4.9.1/liquibase.properties @@ -0,0 +1,5 @@ +url=jdbc:postgresql://localhost:5432/liquibase_example +username=postgres +password=121314Ma +changeLogFile=db/changelog/db.changelog-master.xml +liquibase.hub.mode=off \ No newline at end of file diff --git a/pom.xml b/pom.xml index 5c00deb..d8aff27 100644 --- a/pom.xml +++ b/pom.xml @@ -5,17 +5,25 @@ org.springframework.boot spring-boot-starter-parent - 2.4.3 + 2.6.7 - org.sadtech.example + + dev.struchkov.example liquibase 0.0.1-SNAPSHOT - liquibase - Demo project for Spring Boot + + Liquibase Examples + Demo project using liquibase + - 1.8 + 17 + ${java.version} + ${java.version} + UTF-8 + UTF-8 + org.springframework.boot @@ -45,11 +53,6 @@ lombok true - - org.springframework.boot - spring-boot-starter-test - test - diff --git a/src/main/resources/application.yaml b/src/main/resources/application.yml similarity index 90% rename from src/main/resources/application.yaml rename to src/main/resources/application.yml index 1e5732d..56df67c 100644 --- a/src/main/resources/application.yaml +++ b/src/main/resources/application.yml @@ -3,6 +3,6 @@ spring: url: jdbc:postgresql://localhost:5432/liquibase_example username: postgres driver-class-name: org.postgresql.Driver - password: 121314Ma + password: liquibase: change-log: classpath:db/changelog/db.changelog-master.xml \ No newline at end of file diff --git a/src/main/resources/db/changelog/db.changelog-master.xml b/src/main/resources/db/changelog/db.changelog-master.xml index 62c76ab..ce01d12 100644 --- a/src/main/resources/db/changelog/db.changelog-master.xml +++ b/src/main/resources/db/changelog/db.changelog-master.xml @@ -1,49 +1,10 @@ + + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.6.xsd"> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - SELECT p.id as person_id, - p.name as person_name, - b.id as book_id, - b.name as book_name - FROM person p - LEFT JOIN book b on p.id = b.author_id - - + + \ No newline at end of file diff --git a/src/main/resources/db/changelog/v.1.0.0/create-table.xml b/src/main/resources/db/changelog/v.1.0.0/create-table.xml new file mode 100644 index 0000000..8d24881 --- /dev/null +++ b/src/main/resources/db/changelog/v.1.0.0/create-table.xml @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/main/resources/db/changelog/v.1.0.0/cumulative-changelog.xml b/src/main/resources/db/changelog/v.1.0.0/cumulative-changelog.xml new file mode 100644 index 0000000..4059715 --- /dev/null +++ b/src/main/resources/db/changelog/v.1.0.0/cumulative-changelog.xml @@ -0,0 +1,13 @@ + + + + + + + + + + \ No newline at end of file diff --git a/src/main/resources/db/changelog/v.2.0.0/create-table-hero.xml b/src/main/resources/db/changelog/v.2.0.0/create-table-hero.xml new file mode 100644 index 0000000..941a386 --- /dev/null +++ b/src/main/resources/db/changelog/v.2.0.0/create-table-hero.xml @@ -0,0 +1,54 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + name = 'Савельич' + + + name = 'Капитанская дочка' + + + first_name = 'Александр' + + + + + \ No newline at end of file diff --git a/src/main/resources/db/changelog/v.2.0.0/cumulative-changelog.xml b/src/main/resources/db/changelog/v.2.0.0/cumulative-changelog.xml new file mode 100644 index 0000000..ddfdd91 --- /dev/null +++ b/src/main/resources/db/changelog/v.2.0.0/cumulative-changelog.xml @@ -0,0 +1,13 @@ + + + + + + + + + + \ No newline at end of file