-
Notifications
You must be signed in to change notification settings - Fork 0
Update dependency drizzle-orm to ^0.45.0 #12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Open
renovate
wants to merge
1
commit into
main
Choose a base branch
from
renovate/drizzle-orm-0.x
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
|
The latest updates on your projects. Learn more about Vercel for GitHub.
|
79dbb4e to
65159d6
Compare
65159d6 to
1f08dc4
Compare
1f08dc4 to
feced02
Compare
feced02 to
ad4aca2
Compare
ad4aca2 to
80cce44
Compare
80cce44 to
d98c2f4
Compare
d98c2f4 to
a00277c
Compare
a00277c to
d123f23
Compare
d123f23 to
325c512
Compare
325c512 to
029fce9
Compare
029fce9 to
6ce6470
Compare
6ce6470 to
c42afc3
Compare
c42afc3 to
eaa6107
Compare
eaa6107 to
662cb43
Compare
662cb43 to
e6c2927
Compare
e6c2927 to
8cf33b7
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
^0.33.0->^0.45.0Release Notes
drizzle-team/drizzle-orm (drizzle-orm)
v0.45.1Compare Source
require()(#5107)v0.45.0Compare Source
$onUpdatenot handlingSQLvalues (fixes #2388, tests implemented by L-Mario564 in #2911)pgmappers not handlingDateinstances inbun-sql:postgresqldriver responses fordate,timestamptypes (fixes #4493)v0.44.7Compare Source
v0.44.6Compare Source
v0.44.5Compare Source
.one()indurable-sqlitesessionblobcolumnsblobcolumnsblobmappingv0.44.4Compare Source
v0.44.3Compare Source
$clientfor clients created by drizzle functionupdated_atcolumn to theneon_auth.users_synctable definition.v0.44.2Compare Source
tsconfig: #4535, #4457v0.44.1Compare Source
v0.44.0Compare Source
Error handling
Starting from this version, we’ve introduced a new
DrizzleQueryErrorthat wraps all errors from database drivers and provides a set of useful information:Drizzlequery failedDrizzle
cachemoduleDrizzle sends every query straight to your database by default. There are no hidden actions, no automatic caching or invalidation - you’ll always see exactly what runs. If you want caching, you must opt in.
By default, Drizzle uses a explicit caching strategy (i.e.
global: false), so nothing is ever cached unless you ask. This prevents surprises or hidden performance traps in your application. Alternatively, you can flip on all caching (global: true) so that every select will look in cache first.Out first native integration was built together with Upstash team and let you natively use
upstashas a cache for your drizzle queriesYou can also implement your own cache, as Drizzle exposes all the necessary APIs, such as get, put, mutate, etc.
You can find full implementation details on the website
For more usage example you can check our docs
v0.43.1Compare Source
Fixes
v0.43.0Compare Source
Features
cross join(#1414)left,inner,crossjoins toPostgreSQL,MySQL,Gel,SingleStoreSingleStore's driver instancesFixes
full joinfromMySQLselect apiGelcolumns to always have explicit schema & table prefixes due to potential errors caused by lack of such prefix in subquery's selection when there's already a column bearing same name in contextPgTextBuilderInitialtypeIfNotImportedtype check fromSingleStoredriver initializertsconfigs (#2654)nowaitflag (#3554)v0.42.0Compare Source
Features
Duplicate imports removal
When importing from
drizzle-ormusing custom loaders, you may encounter issues such as:SyntaxError: The requested module 'drizzle-orm' does not provide an export named 'eq'This issue arose because there were duplicated exports in
drizzle-orm. To address this, we added a set of tests that checks every file indrizzle-ormto ensure all exports are valid. These tests will fail if any new duplicated exports appear.In this release, we’ve removed all duplicated exports, so you should no longer encounter this issue.
pgEnumandmysqlEnumnow can accept both strings and TS enumsIf you provide a TypeScript enum, all your types will be inferred as that enum - so you can insert and retrieve enum values directly. If you provide a string union, it will work as before.
Improvements
inArrayacceptReadonlyArrayas a value - thanks @Zamiell@planetscale/database's execute - thanks @ayrtonInferEnumtype - thanks @totigmIssues closed
v0.41.0Compare Source
bigint,numbermodes forSQLite,MySQL,PostgreSQL,SingleStoredecimal&numericcolumn typessql-jsquery preparation to query prebuild instead of db-side prepare due to need to manually free prepared queries, removed.free()methodMySQL,SingleStorevarcharallowing not specifyinglengthin configMySQL,SingleStorebinary,varbinarydata\type mismatchesnumeric\decimaldata\type mismatches: #1290, #1453drizzle-studio+AWS Data Apiconnection issue: #3224isConfigutility function checking types of wrong fieldssupportBigNumbersin auto-createdmysql2driver instances1231(numeric[]),1115(timestamp[]),1185(timestamp_with_timezone[]),1187(interval[]),1182(date[]), preventing precision loss and data\type mismatchesSQLitebuffer-modeblobsometimes returningnumber[]v0.40.1Compare Source
Updates to
neon-httpfor@neondatabase/serverless@1.0.0- thanks @jawjStarting from this version, drizzle-orm will be compatible with both
@neondatabase/serverless<1.0 and >1.0v0.40.0Compare Source
New Features
Added
Geldialect support andgel-jsclient supportDrizzle is getting a new
Geldialect with its own types and Gel-specific logic. In this first iteration, almost all query-building features have been copied from thePostgreSQLdialect since Gel is fully PostgreSQL-compatible. The only change in this iteration is the data types. The Gel dialect has a different set of available data types, and all mappings for these types have been designed to avoid any extra conversions on Drizzle's side. This means you will insert and select exactly the same data as supported by the Gel protocol.Drizzle + Gel integration will work only through
drizzle-kit pull. Drizzle won't supportgenerate,migrate, orpushfeatures in this case. Instead, drizzle-kit is used solely to pull the Drizzle schema from the Gel database, which can then be used in yourdrizzle-ormqueries.The Gel + Drizzle workflow:
gelCLI to manage your schema.gelCLI to generate and apply migrations to the database.Here is a small example of how to connect to Gel using Drizzle:
and drizzle-gel schema definition
On the drizzle-kit side you can now use
dialect: "gel"For a complete Get Started tutorial you can use our new guides:
v0.39.3Compare Source
reactfrom peerDependenciesv0.39.2Compare Source
neon_identitytoneon_auth- thanks @pffigueiredov0.39.1Compare Source
aliasedTable()v0.39.0Compare Source
New features
Bun SQL driver support
You can now use the new Bun SQL driver released in Bun v1.2.0 with Drizzle
or you can use Bun SQL instance
Current Limitations:
jsonandjsonbinserts and selects currently perform an additionalJSON.stringifyon the Bun SQL side. Once this is removed, they should work properly. You can always use custom types and redefine the mappers to and from the database.datetime,date, andtimestampwill not work properly when usingmode: stringin Drizzle. This is due to Bun's API limitations, which prevent custom parsers for queries. As a result, Drizzle cannot control the response sent from Bun SQL to Drizzle. Once this feature is added to Bun SQL, it should work as expected.arraytypes currently have issues in Bun SQL.WITH now supports INSERT, UPDATE, DELETE and raw sql template
withandinsertwithandupdatewithanddeletewithandsqlNew tables in
/neonimportIn this release you can use
neon_identityschema andusers_synctable inside this schema by just importing it from/neonUtils and small improvements
getViewNameutil functionBug fixed and GitHub issue closed
v0.38.4Compare Source
vector- thanks @mitchwadairv0.38.3Compare Source
v0.38.2Compare Source
New features
USE INDEX,FORCE INDEXandIGNORE INDEXfor MySQLIn MySQL, the statements USE INDEX, FORCE INDEX, and IGNORE INDEX are hints used in SQL queries to influence how the query optimizer selects indexes. These hints provide fine-grained control over index usage, helping optimize performance when the default behavior of the optimizer is not ideal.
Use Index
The
USE INDEXhint suggests to the optimizer which indexes to consider when processing the query. The optimizer is not forced to use these indexes but will prioritize them if they are suitable.Ignore Index
The
IGNORE INDEXhint tells the optimizer to avoid using specific indexes for the query. MySQL will consider all other indexes (if any) or perform a full table scan if necessary.Force Index
The
FORCE INDEXhint forces the optimizer to use the specified index(es) for the query. If the specified index cannot be used, MySQL will not fall back to other indexes; it might resort to a full table scan instead.You can also combine those hints and use multiple indexes in a query if you need
v0.38.1Compare Source
v0.38.0Compare Source
Types breaking changes
A few internal types were changed and extra generic types for length of column types were added in this release. It won't affect anyone, unless you are using those internal types for some custom wrappers, logic, etc. Here is a list of all types that were changed, so if you are relying on those, please review them before upgrading
MySqlCharBuilderInitialMySqlVarCharBuilderInitialPgCharBuilderInitialPgArrayBuilderPgArrayPgVarcharBuilderInitialPgBinaryVectorBuilderInitialPgBinaryVectorBuilderPgBinaryVectorPgHalfVectorBuilderInitialPgHalfVectorBuilderPgHalfVectorPgVectorBuilderInitialPgVectorBuilderPgVectorSQLiteTextBuilderInitialNew Features
getViewSelectedFields$inferSelectfunction to viewsInferSelectViewModeltype for viewsisViewfunctionValidator packages updates
drizzle-zodhas been completely rewritten. You can find detailed information about it heredrizzle-valibothas been completely rewritten. You can find detailed information about it heredrizzle-typeboxhas been completely rewritten. You can find detailed information about it hereThanks to @L-Mario564 for making more updates than we expected to be shipped in this release. We'll copy his message from a PR regarding improvements made in this release:
And a set of new features
createSelectSchemafunction now also accepts views and enums.createUpdateSchema, for use in updating queries.createSchemaFactory, to provide more advanced options and to avoid bloating the parameters of the other schema functionsBug fixes
v0.37.0Compare Source
New Dialects
🎉
SingleStoredialect is now available in DrizzleThanks to the SingleStore team for creating a PR with all the necessary changes to support the MySQL-compatible part of SingleStore. You can already start using it with Drizzle. The SingleStore team will also help us iterate through updates and make more SingleStore-specific features available in Drizzle
You can check out our Getting started guides to try SingleStore!
New Drivers
🎉
SQLite Durable Objectsdriver is now available in DrizzleYou can now query SQLite Durable Objects in Drizzle!
For the full example, please check our Get Started Section
Bug fixes
v0.36.4Compare Source
New Package:
drizzle-seedFull Reference
The full API reference and package overview can be found in our official documentation
Basic Usage
In this example we will create 10 users with random names and ids
Options
countBy default, the
seedfunction will create 10 entities.However, if you need more for your tests, you can specify this in the seed options object
seedIf you need a seed to generate a different set of values for all subsequent runs, you can define a different number
in the
seedoption. Any new number will generate a unique set of valuesThe full API reference and package overview can be found in our official documentation
Features
Added
OVERRIDING SYSTEM VALUEapi to db.insert()If you want to force you own values for
GENERATED ALWAYS AS IDENTITYcolumns, you can useOVERRIDING SYSTEM VALUEAs PostgreSQL docs mentions
Added
.$withAuth()API for Neon HTTP driverUsing this API, Drizzle will send you an auth token to authorize your query. It can be used with any query available in Drizzle by simply adding
.$withAuth()before it. This token will be used for a specific queryExamples
Bug Fixes
v0.36.3Compare Source
New Features
Support for
UPDATE ... FROMin PostgreSQL and SQLiteAs the SQLite documentation mentions:
Similarly, the PostgreSQL documentation states:
Drizzle also supports this feature starting from this version
For example, current query:
Will generate this sql
You can also alias tables that are joined (in PG, you can also alias the updating table too).
Will generate this sql
In PostgreSQL, you can also return columns from the joined tables.
Will generate this sql
Support for
INSERT INTO ... SELECTin all dialectsAs the SQLite documentation mentions:
As the PostgreSQL documentation mentions:
And as the MySQL documentation mentions:
Drizzle supports the current syntax for all dialects, and all of them share the same syntax. Let's review some common scenarios and API usage.
There are several ways to use select inside insert statements, allowing you to choose your preferred approach:
Query Builder
Callback
SQL template tag
v0.36.2Compare Source
New Features
Bug and typo fixes
Fixed typos in repository: thanks @armandsalle, @masto, @wackbyte, @Asher-JH, @MaxLeiter
Fixed .generated behavior with non-strict tsconfig
Fix Drizzle ORM for expo-sqlite
Fixed lack of schema name on columns in sql
fix: Adjust neon http driver entity kind
Export PgIntegerBuilderInitial type
[MySQL] Correct $returningId() implementation to correctly store selected fields
v0.36.1Compare Source
Bug Fixes
v0.36.0Compare Source
New Features
The third parameter in Drizzle ORM becomes an array
Instead of this
You can now do this
Row-Level Security (RLS)
With Drizzle, you can enable Row-Level Security (RLS) for any Postgres table, create policies with various options, and define and manage the roles those policies apply to.
Drizzle supports a raw representation of Postgres policies and roles that can be used in any way you want. This works with popular Postgres database providers such as
NeonandSupabase.In Drizzle, we have specific predefined RLS roles and functions for RLS with both database providers, but you can also define your own logic.
Enable RLS
If you just want to enable RLS on a table without adding policies, you can use
.enableRLS()As mentioned in the PostgreSQL documentation:
Roles
Currently, Drizzle supports defining roles with a few different options, as shown below. Support for more options will be added in a future release.
If a role already exists in your database, and you don’t want drizzle-kit to ‘see’ it or include it in migrations, you can mark the role as existing.
Policies
To fully leverage RLS, you can define policies within a Drizzle table.
Example of pgPolicy with all available properties
Link Policy to an existing table
There are situations where you need to link a policy to an existing table in your database.
The most common use case is with database providers like
NeonorSupabase, where you need to add a policyto their existing tables. In this case, you can use the
.link()APIMigrations
If you are using drizzle-kit to manage your schema and roles, there may be situations where you want to refer to roles that are not defined in your Drizzle schema. In such cases, you may want drizzle-kit to skip managing these roles without having to define each role in your drizzle schema and marking it with
.existing().In these cases, you can use
entities.rolesindrizzle.config.ts. For a complete reference, refer to the thedrizzle.config.tsdocumentation.By default,
drizzle-kitdoes not manage roles for you, so you will need to enable this feature indrizzle.config.ts.In case you need additional configuration options, let's take a look at a few more examples.
You have an
adminrole and want to exclude it from the list of manageable rolesYou have an
adminrole and want to include it in the list of manageable rolesIf you are using
Neonand want to exclude Neon-defined roles, you can use the provider optionIf you are using
Supabaseand want to exclude Supabase-defined roles, you can use the provider optionRLS on views
With Drizzle, you can also specify RLS policies on views. For this, you need to use
security_invokerin the view's WITH options. Here is a small example:Using with Neon
The Neon Team helped us implement their vision of a wrapper on top of our raw policies API. We defined a specific
/neonimport with thecrudPolicyfunction that includes predefined functions and Neon's default roles.Here's an example of how to use the
crudPolicyfunction:This policy is equivalent to:
Neonexposes predefinedauthenticatedandanaonymousroles and related functions. If you are usingNeonfor RLS, you can use these roles, which are marked as existing, and the related functions in your RLS queries.For example, you can use the
Neonpredefined roles and functions like this: