ora2pg
Hashids.java
ora2pg | Hashids.java | |
---|---|---|
3 | 31 | |
960 | 1,012 | |
- | 0.0% | |
9.0 | 0.0 | |
24 days ago | 7 months ago | |
Perl | Java | |
GNU General Public License v3.0 only | MIT License |
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.
ora2pg
-
Oracle Auto indexes missing after ora2pg migration? Look at CONSTRAINT_INDEX
It seems that Oracle customers started using the Auto Index feature. I can see that when they migrate to YugabyteDB. YugabyteDB Voyager is a tool to ease the migration of schema and data. As YugabyteDB is PostgreSQL compatible, ora2pg is used when the source is Oracle. It extracts the schema and data. Some customers moving from Oracle ATP managed service (Autonomous Transaction Processing) reported that a few indexes were not extracted: the ones that have been created automatically by the Automatic Indexing feature of Oracle 19c.
-
Features I'd Like in PostgreSQL
Have you heard of "ora2pg"? It works for both MySQL and Oracle:
https://github.com/darold/ora2pg
https://ora2pg.darold.net/
- Using Ora2Pg to Migrate Data from Oracle to openGauss
Hashids.java
- Hashids: Generate short unique ids from integers
-
Auto Generate Sequential UIID
You basically want Hashids but sequential? Why not simple convert a base 10 (0-9) number to hex? (0-F)
-
Features I'd Like in PostgreSQL
I found hashids [1] to be a great compromise between integer ids in the database and copyable non-enumerable strings on the client.
[1] https://hashids.org/
- Short, friendly base32 slugs from timestamps
-
We Chose NanoIDs for PlanetScale’s API
I wonder how this might compare to just storing regular autoincrementing ints in the database, and converting to/from hashids (https://hashids.org/) at the edge. It eliminates the collision concern and stores more compactly at the cost of a tiny amount of encode/decode when processing requests. You’d want to push it down as close to the database layer as possible to avoid inadvertent int ID leaks; I added native hashids support to clickhouse but I’m not sure what other database support might entail.
-
How can I generate truly unique slugs?
Since hashids are not really hashes and are not secure at all this is not even achieved. Hashids can be easily decoded without the salt by a simple brute-force attack described by the authors of hashid themselves right on their website: https://hashids.org/
-
How to handle id-based routes with UUID
You don't necessarily need to use UUIDs. You could use something like Hashids to generate random strings from your sequential IDs in a reversible way, so that users can't predict what their values will be, but you can decode them as needed.
-
All of my database models have id replaced with UUID4s. Is there any risk to using these in URLs?
You should not use UUIDv4 as a primary key. You can use normal int values and then use hashids to make them safe for URL. UUIDv7 might be good to use as well once they are more widely supported as well.
- What’s Django’s argument for using 64-bit int as default pk over uuid. Can anyone point me to something I can read?
- Library for generating string IDs from number IDs
What are some alternatives?
pg_plan_guarantee - Postgres Query Optimizer Extension that guarantees your desired plan will not change
BLAKE3 - the official Rust and C implementations of the BLAKE3 cryptographic hash function
pg_ivm - IVM (Incremental View Maintenance) implementation as a PostgreSQL extension
uuid7 - UUID version 7, which are time-sortable (following the Peabody RFC4122 draft)
rum - RUM access method - inverted index with additional information in posting lists
Guava - Google core libraries for Java
OpenLogReplicator - Open Source Oracle database CDC
JGit - JGit project repository (jgit)
gql-sql-pgq-pointers
Embulk - Embulk: Pluggable Bulk Data Loader.
postgres-operator - Postgres operator creates and manages PostgreSQL clusters running in Kubernetes
JADE - a pug implementation written in Java (formerly known as jade)