shadiakiki1986 / db-diff
Requires
- ext-pdo: *
- ext-pdo_odbc: *
- ext-yaml: *
- shadiakiki1986/git-rest-api-client: *
- symfony/console: ^3.2
- twig/twig: ^2.0
Requires (Dev)
- jakub-onderka/php-parallel-lint: ^0.9.2
- php-mock/php-mock: ^1.0
- phpunit/phpunit: ^5.7
This package is auto-updated.
Last update: 2024-12-27 03:23:30 UTC
README
Console application to version control database table contents and show their daily diff
Does it in 3 steps
- Set up PHP-ODBC connections and store your database connection in
/etc/odbc.ini
- export table from database via ODBC connection to git via git-rest-api server
- export table again after edits
- get
git diff
results
Running periodic exports gives more points in time to diff
against
Similar tools (didn't try them)
- Red gate: similar to this repo, can version control "static data"
- git-sql: diff of sql data dumps
- Nayjest/db-diff: diff of two tables with the same structure
- PM-Connect/db-diff: diff of two database structures
Usage
(Example usage: docker-db-diff )
-
Requirements:
-
PDO-ODBC driver and a ready connection
-
a node-git-rest-api server with
deep-diff-yml
configured for yml files -
Set env var for
git-rest-api
server
export DBDIFF_GRAPI_HOST=http://localhost:8082
- Synopsis
./bin/pdo-git export [--init] <DSN> <DB>..<TABLE> ./bin/pdo-git post-commit --format [html,console,json] -- <DSN> <DB>..<TABLE>
Note: the <DB>..<TABLE>
notation is SQLServer-specific. For MySql, use <DB>.<TABLE>
(single dot)
Reset:
./bin/pdo-git admin git:deleteAll
Testing
- (optional) Set up a mysql database to test against locally:
docker run \
-e MYSQL_RANDOM_ROOT_PASSWORD=yes \
-e MYSQL_DATABASE=mf \
-e MYSQL_USER=user \
-e MYSQL_PASSWORD=password \
-v $PWD/tests/initdb.d:/docker-entrypoint-initdb.d \
-p 3306:3306 \
mysql:8
Test with
mysql --host 127.0.0.1 --user user --password > use mf; > select * from t1
- (optional) Run the
git-rest-api
server locally:
docker-compose up git
- (optional) Set up dev env using option 1 or 2 below
- Install dependencies:
composer install
- Run tests:
composer test
Option 1: Dev env with vagrant
cd exporter vagrant up VAGRANT> composer test
Option 2: Manually
Install odbc
drivers like docker-php7...:
[sudo] apt-get unixodbc unixodbc-dev tdsodbc php7.0-odbc
Test installation with : php -i|grep odbc
Install mysql-odbc drivers
- ubuntu 13.04:
apt-get install libmyodbc
- ubuntu 16.04:
wget https://cdn.mysql.com//Downloads/Connector-ODBC/5.3/mysql-connector-odbc-5.3.7-linux-ubuntu16.04-x86-64bit.tar.gz tar -xzf mysql-connector-odbc-5.3.7-linux-ubuntu16.04-x86-64bit.tar.gz cd mysql.../lib cp * /usr/lib/x86_64.../odbc/
Set up odbc configuration
cp etc/odbc.dev.ini /etc/ cp etc/odbcinst.dev.ini /etc/
Test with
isql MarketflowAcc user password