sqitch VS migrate

Compare sqitch vs migrate and see what are their differences.

InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
sqitch migrate
7 72
2,715 14,062
1.2% 2.4%
7.2 8.0
about 2 months ago 7 days ago
Perl Go
MIT License GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

sqitch

Posts with mentions or reviews of sqitch. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-14.
  • Ask HN: What tool(s) do you use to code review and deploy SQL scripts?
    5 projects | news.ycombinator.com | 14 Apr 2024
    We use https://sqitch.org/ and we’re fairly happy with it. Sqitch manages the files to deploy which are applied fits to a local database.

    We use GitHub actions for deployment and database migrations are just one step of the pipeline. The step invokes sqitch deploy which runs all the pending migration files.

    Then, all the approval process is standard for the environment. We require approvals in pull requests before merging to the main branch.

  • PostgREST: Providing HTML Content Using Htmx
    12 projects | news.ycombinator.com | 18 Dec 2023
    I'm experimenting with it right now using Squitch [1] to make maintenance easier. It still feels like a hack and I also still have my doubts about the viability of this for real-world use. It's fun though and I'm learning about all kinds of advanced Postgres features.

    [1] https://sqitch.org/

  • Modern Perl Catalyst: Docker Setup
    5 projects | dev.to | 2 Aug 2023
    For developing I find the official Perl docker images, running on a lightweight version of Debian, to be perfectly fine. Later on you might hand roll the skinniest possible image but the beauty of this setup is you can do that later and you don't need to change anything else. There's really not a lot going on here. First I declare the base image, which is as I said the official Perl image. I'm not using the latest Perl here because the application uses Sqitch for managing database migrations and that needs an update (there's a PR pending) to run on the most recent Perl so we'll just use a very nearly recent one instead. WORKDIR just defines where your application is installed. You can put it anywhere you want within reason. I like simple things so I use the most simple of all the conventions I've seen around.
  • Database migration tool
    4 projects | /r/golang | 10 Jul 2023
    Also, https://sqitch.org/
  • How do you handle schema migrations?
    2 projects | /r/Database | 9 Jun 2023
  • Announcing codd - a tool to apply postgres SQL migrations
    3 projects | /r/haskell | 3 Mar 2023
    Some possible upsides of codd: - No need to manually write verification SQL. Codd will update schema representation files when you codd add some-migration.sql and will compare those to the actual schema when deploying (I'd say in ways which would be very hard to replicate manually, see an example of what codd checks, giving you the option to rollback if they don't match or proceed but log non-matching db objects. - It seems to be much simpler to set codd up. You need 3 env vars to start, a folder to store your migrations and a self-contained statically linked executable. Just codd add migration.sql your way in after that - This might be very wrong as I couldn't find it explicitly documented, but this GH issue suggests it's not so simple to apply all pending migrations in a single transaction with Sqitch? Maybe it requires some bundling or something along those lines and then it's fine, though. In any case, codd will do this automatically when you run codd up (provided postgresql allows it).

migrate

Posts with mentions or reviews of migrate. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-17.
  • Using migrations with Golang
    5 projects | dev.to | 17 Apr 2024
    Go does not natively support the use of migrations, but we could use the ORM that has this functionality, such as GORM which is the most used by the community, but We can use migrations without using an ORM, for this we will use the golang-migrate package.
  • How to use SQLC with Golang
    1 project | dev.to | 3 Jan 2024
    $ curl -L https://github.com/golang-migrate/migrate/releases/download/$version/migrate.$os-$arch.tar.gz | tar xvz
  • Looking for recommendations for model/schema/migration management in Golang
    2 projects | /r/golang | 7 Dec 2023
  • API completa em Golang - Parte 1
    8 projects | dev.to | 1 Dec 2023
  • Building RESTful API with Hexagonal Architecture in Go
    21 projects | dev.to | 27 Sep 2023
    Golang-migrate is a database migration tool designed for Go applications. It helps manage and apply changes to the database schema as the application grows, ensuring that the code and database structure stay in sync.
  • Python: Just Write SQL
    21 projects | news.ycombinator.com | 14 Aug 2023
    First of all, thank you for SQLAlchemy! If I ever had to make a final choice in how I would interact with a database for a very large project that involves a considerable dev team, I would always bet on SQLAlchemy. Not that I would necessarily like all aspects of it, but when it comes to Python and SQL - “Nobody ever got fired for picking SQLAlchemy.”.

    With that out of the way, despite ORMs doing much more than "just writing SQL", it is exactly on that point that I flinch: Most devs should be exposed to SQL. And if your project allows you to build around simple enough abstractions so that you aren't reinventing the wheel, you should definitely be writing SQL. Especially if you don't know SQL yet - which is the growing case of new devs coming into the job market.

    You can achieve a lot with SQlAlchemy Core, a tool that I absolutely recommend, but my post is just a simple alternative to get developers to think about their approach. If that results in some devs reconsidering using "full fat" SQLAlchemy and to try SQLAlchemy Core, that's a win for me!

    Your gist tries to highlight the difficulty of doing certain things without an ORM. Migrations (as just 1 example) doesn't need to be hard, simple tools like flyway, or migrate (https://github.com/golang-migrate/migrate) achieve a similar result (while also keeping you on the path of writing SQL!). Deep and complex relationships between objects also don't need to be hard - typically people approach this subject with a requirement to be very flexible in the way they want to build queries and objects, but that to me in a sign that maybe they should reconsider their business logic AND reconsider that, just maybe, their project doesn't require all that flexibility, it is fairly straightforward to extend objects and introduce some more complex representations as and when it is needed - will all of this make me write code faster? Absolutely not. That is why you have spent so much time perfecting SQLAlchemy, but then again, I am not advocating for devs to go and replace their usage of ORMs, just presenting an alternative that may or may not fit their needs for a new project + give devs the chance to learn something that the ORM might have taken away.

  • best practices for testing of stored procedure calls?
    1 project | /r/golang | 12 Jul 2023
    Doing this now with a mysql db for my use case. Using sp to take a large chunk of data migration load off my data layer code. I am using migrate (go library) for migrations and hooked it up with a bunch of test suites for all SP and Triggers it creates. I test it against a testDB maintained as part of my CI/CD. Haven’t had an issue with production yet. It does however require quite a bit of initial setup.
  • Database migration tool
    4 projects | /r/golang | 10 Jul 2023
  • REST API with Go, Chi, MySQL and sqlx
    6 projects | dev.to | 23 Jun 2023
    Before we can start using MySQL we need to create a table to store our data. I will be using excellent migrate database migrations tool, it can also be imported as a libraray.
  • Authentication system using Golang and Sveltekit - User registration
    1 project | dev.to | 3 Jun 2023
    We need a database table to store our application's users' data. To generate and migrate a schema, we'll use golang migrate. Kindly follow these instructions to install it on your Operating system. To create a pair of migration files (up and down) for our user table, issue the following command in your terminal and at the root of your project:

What are some alternatives?

When comparing sqitch and migrate you can also consider the following projects:

ContactsDemo - Example Catalyst Application

goose

atlas - Manage your database schema as code

goose - A database migration tool. Supports SQL migrations and Go functions.

maildev - :mailbox: SMTP Server + Web Interface for viewing and testing emails during development.

pgx - PostgreSQL driver and toolkit for Go

git-secret - :busts_in_silhouette: A bash-tool to store your private data inside a git repository.

tern - The SQL Fan's Migrator

docs - Documentation for Docker Official Images in docker-library

gormigrate - Minimalistic database migration helper for Gorm ORM

smoothdb - SmoothDB provides an automatic RESTful API to PostgreSQL databases

sqlx - general purpose extensions to golang's database/sql