Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wallymathieu/mejram
Database analysis by using information tables and conventions
https://github.com/wallymathieu/mejram
analysis conventions database postgresql referential-constraints sql-server
Last synced: 3 months ago
JSON representation
Database analysis by using information tables and conventions
- Host: GitHub
- URL: https://github.com/wallymathieu/mejram
- Owner: wallymathieu
- License: mit
- Created: 2012-03-31T19:43:15.000Z (almost 13 years ago)
- Default Branch: master
- Last Pushed: 2024-06-14T16:16:57.000Z (7 months ago)
- Last Synced: 2024-10-29T23:09:56.151Z (3 months ago)
- Topics: analysis, conventions, database, postgresql, referential-constraints, sql-server
- Language: F#
- Homepage: http://assertfail.gewalli.se/2012/03/18/domain-analysis-of-application-database.html
- Size: 396 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Mejram
## The name
Mejram is the swedish name for Marjoram. Like any spice it is intended to give flavor to the analysis of sql databases.
## Goal
The goal is to be able to analyse relational databases with a large number of tables. Many of the databases I've seen related to managing a specific domain (enterprise system) have around 200-300 tables. Even though this is not to large to analyse by hand, it can definitelly be to cumbersome. If you use sql server and the relations are well maintained. That is: The referential constraints are present where they should be. Then you don't need to use this tool. You can use sql server manager. The problem is that it's often a mixture of well maintained referential constraints and implied (i.e. can be gleaned by the naming convention in the database) but not formal.
## Setup
I've found that the best way to get started is to copy paste Mejram.Console into your own repository and do some small changes (remember to change ProjectReference on Mejram to a PackageReference).
## Testing
You need to either install postgresql locally or use docker. The easiest way is to use docker.
Make sure to create your own .env file. You can use the .env.example file as a template. Make sure to change the passwords.
```sh
cp .env.sample .env
```Then you can start the database.
```sh
docker-compose up pg -d
```Make sure to import the database.
```sh
./pg/import-pagila-data.sh
```Then you can run the tests by having an environment variable with the right connection string.
```sh
source .env
export SAKILA_TEST_CONN=$LOCAL_PG_CONN
dotnet test csharp
```