-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Upcoming release: 0.6.0 #252
Conversation
/me waits with baited breath. |
Alright. Forget whatever's "left", I'm just going to get migrations working, docs and cut a release by the end of the day, and then we can just 0.6.x features from there. |
Very nice! Next up is getting Bookshelf to work with 0.6.x right? Sent from my iPhone
|
It should bookshelf/bookshelf#330 |
@tgriesser awesome. As soon as this stuff is live I'm gonna swing through every project we're using knex/bookshelf on and update them. |
* Build documentation for 0.17.0 (#198) * Add documentation for migrate:down (#197) * add missing function to sidebar (#199) * Add notes around usage with typescript * Generate assets * Fix documentation for migration extension (#204) * Improve dev workflow (#201) * Mark generated files as binary so they don't clobber the diff * Tweak build scripts - Replace child-process-promise with execa which already handles SIGINT propagation & PATHEXT normalization - Read CHANGELOG from node_modules/knex so that it works well with npm/yarn link and nodemon can pickup changes - Tweak nodemon to auto restart when CHANGELOG changes - Remove misleading log that rs will restart nodemon which doesn't work with spawn * fix typo (#206) * add intersect method (#173) * Document transaction execution promise (#205) * Generate documentatino for 0.18.0 (#207) * Fix typo (#209) Remove unnecessary parentheses * CLI: documentation on migration:make --stub option (#208) * Update dependencies (#210) * Build documentation for 0.18.3 (#211) * Add docs for seed:run --specific (#213) * Build documentation for 0.18.4 (#215) * Update docs for aggregation queries to include information about #3354 (#221) Closes #219 * Document "skipLocked()" and "noWait()" (#186) * Remove bluebird-specific methods from documentation (#222) * Add documentation for transaction .isCompleted() (#223) * Add extends queryBuilder documentation - related to #3334 (#218) * Build documentation for 0.19.1 (#224) * fix(syntax error): small issue with docs displaying invalid JS code. (#225) * correct and clarify how to alias an identifier (#226) * noted that aliasing uses a suffix, not a prefix * added an example * Fix small type (#229) * CLI Migrations List CMD Documentation (#231) * Support specifying schema for enums (#232) * Release documentation for 0.19.3 * update docs as per #3416 (#233) * Docs for disableValidateMigrationsList (#237) * fix docs for knex.migrate.up & knex.migrate.down (#238) * Edit table names in example to be plural (#236) Change table names to be plural to match the style in the rest of the documentation. * fix: repair hitchhikers guide to the galaxy update docs (#230) * Fix broken travis badge and links after relocation of project (#240) * replace deprecated oracle package with oracledb (#239) * Release documentation for 0.20.0 * Documentation for #3497 (#242) * Release documentation for 0.20.1 * Update to Babel 7, bump a couple of other dependencies * Release documentation for 0.20.4 * Release documentation for 0.20.5 * updated transactions docs with async/await examples (#247) * "esm module interop flag" reflects knex #3571 (#251) * Release documentation for 0.20.10 * Release documentation for 0.20.10 - follow-up * delete Promise.return (#256) * Adds documentation for async knex (#259) * Add clearGroup method documentation (#261) * Add entry for onDistinct (#257) * Add join to sidebar (#264) * Change notNull to notNullable for consistency (#252) * Release documentation for 0.20.15 * Release documentation for 0.21.0 * Add documentation about liftoff and its dependencies. Resolves #3807 (#265) * Add docs for new migrate:unlock command (#266) Corresponding knex PR: #3822 Co-authored-by: Zach McElrath <[email protected]> * Release documentation for 0.21.1 * remove broken link from sidebar (#269) * pronounced /kəˈnɛks/ (#275) * Typo fix in schema.js (#279) * Add array of paths and sortDirsSeparately for seeds (#282) related to #3967 and knex/documentation#220 * Release documentation for 0.21.3 * Add recursive option for seeds (#284) Related to #3974 * Release documentation for 0.21.4 * Esm interop documentation update (#285) * Release documentation for 0.21.5 * Typo in index.html (#291) * add documentation for isTransaction property (#293) closes knex/documentation#235 * docs(QueryBuilder): add method .clear(statement) (#289) * Release documentation for 0.21.9 * Documentation for augmented table interfaces (#292) * Initial documentation on .onConflict, .ignore, and .merge (#260) * Release documentation for 0.21.10 * Fix spelling error (#296) * Add documentation on "upsert" WHERE clause for PostgreSQL/Sqlite (#300) Co-authored-by: Igor Savin <[email protected]> * Release documentation for 0.21.13 * Add documentation for "includeTriggerModifications" (#301) * Release documentation for 0.21.14 * Minor tweaks on the main page * Release documentation for 0.21.15 * var -> const http -> https Minor tweaks * Add setIsolationLevel docs (#302) Co-authored-by: Igor Savin <[email protected]> * Update TypeScript documentation (#303) * Doc for analytic functions (#5) Co-authored-by: Igor Savin <[email protected]> * Document optimizer hints (#306) * Added documentation for increments primaryKey option (#308) Co-authored-by: Igor Savin <[email protected]> * Added docs for new conflict merge strategies. (#307) Co-authored-by: Matt Goodson <[email protected]> * fix WebpackMigrationSource example (#192) (#304) * Add example for WebpackMigrationSource with webpack 5 (#310) * DOCS Add constraintName option to defaultTo for mssql driver (#311) * DOCS Add constraintName option to defaultTo for mssql driver * Update schema.js Co-authored-by: Igor Savin <[email protected]> * columnInfo: Fix bulleted list rendering (#312) * include enlightenment about composite typing (#298) * Add documentation for generateDdlCommands update TOC * Publish documentation for 0.95.0 * Fix migrate parameter (#313) latestVersion becomes latest * Docs for #3678: allow running multiple specific seed files (#316) * Add documentation for "Add support for file open flags for sqlite3" (#320) Signed-off-by: Boelensman1 <[email protected]> * fixed typescript example of extending QueryBuilder (#321) * Publish documentation for 0.95.5 * fix(docs): migration from mssql to tedious (#317) * Fix mssql driver description * Fix typo (#328) * add documentation for deferrable constraint support (#330) * Fix Sidebar element link to same section (#331) * Publish documentation for 0.95.8 * Add documentation for partitionBy and clean up some spacings and child assigns (#333) * Fix example for batch insert with conflict merge (#325) * add port option to connection (#324) * Adds a missing "the" (#318) * Add documentation for schema nullability manipulation (#334) * Publish documentation for 0.95.11 * feat(builder): Describe optional columnList arg to with/Recurisve [#4514] (#335) * Add missing documentation for whereRecursive * Adding notes about pg-native (#336) * Add table.double to documentation (#295) * Fix havingRaw signature (#297) * Add dropSchema and dropSchemaIfExists doc (#4713) (#338) * Add 'is null' support in order by documentation (#339) * Missing comma (#340) * Add Create table like documentation (#1373) (#341) * Add CockroachDB (#342) * Migrations: Fix code formatting (#343) * View support doc (#4748) (#344) Co-authored-by: Olivier CAVADENTI <[email protected]> * Add storage engine index type doc #4756 (#345) * Add docs for forNoKeyUpdate() and forKeyShare() (#346) * skiplocked and nowait in mariadb (#348) Nowait was added in 10.3 - https://mariadb.com/kb/en/wait-and-nowait/ skiplocked was added in 10.6 - https://mariadb.com/kb/en/select/#skip-locked * feat: add builder method upsert (#349) * Add partial index doc #4768 (#350) * github url fix to github.com/knex/knex (#347) * Publish documentation for 0.95.12 * Add documentation fromRaw #4781 (#354) * Add documentation whereLike/whereILike #4779 (#353) * Add doc for Delete joins and using syntax in Postgres * Add skipBinding option for offset and limit (#356) * Add callback doc for create table like (#359) * Update builder.js (#360) * Remove dead link in sidebar (#361) * Added a note about enumerations not being editable after creation (without knex.raw), as per #1699 (#314) * Document custom seed sources (#364) * Webpack 5 update (#365) * remove -p parameter of webpack command * React, Babel and more updates (#366) * Add binary uuid doc (#368) * docs: added some small additions about supporting `better-sqlite3` (#369) Signed-off-by: blam <[email protected]> * Add useCamelCase doc (#358) * Add geo columns doc (#370) * Add alter table and fixes (#371) * fix typo in `dropView` (#372) * Added MSSQL unique constraint documentation (#373) * Json Support documentation (#374) * Multiple PKs with increments doc (#375) * Add checks documentation (#377) * Update returning doc (#378) * Create or replace view doc (#376) * add docs aout smallint, integer, biginteger, tinyint, mediumint (#363) * href Schema.index vs column.index (#355) * Publish documentation for 1.0.1 * Fix 1.0.1 documentation * Update SQLite driver documentation (#381) * Add with materialized doc (#382) * Add onConflict raw doc (#384) * docs: add built assets * Add alterNullable doc (#385) * Add alterType documentation (#387) * Publish documentation for 1.0.2 * Publish documentation for 1.0.3 * Add whereLike functions doc (#392) * Update CNAME * Delete CNAME * Create CNAME * Publish documentation for 1.0.3\4 * Update CNAME * Wrong doc reference for table.index (#394) * Update Migrations doc for overrides cli (#395) * Publish documentation for 1.0.5 * Publish documentation for 1.0.6 * Publish documentation for 1.0.7 * Update esm-interop.js (#398) * Update doc for sqlite3 restore (#399) * Publish documentation for 2.0.0 * Delete everything * Migrate documentation to vitepress (#400) Co-authored-by: Benicio Cardozo <[email protected]> * feat: add deployment workflow (#404) * Update schema-builder.md (#405) * Update deploy.yml (#407) * Added recommendation to set pool.min to 0 (#409) * Fix Algolia Search Box redirecting to a 404 page (#411) * Update transactions.md (#416) * restore sqlite3 as the version to install for sqlite db (#418) * docs: document primaryKey option on uuid type (#419) * Typo (#422) * Fix typo (#426) * Fix a few broken links (#430) Propably the consequence of a change in structure * uuidToBin and binToUuid are switched (#434) The code examples of uuidToBin and binToUuid where in the wrong order. I switched the heading and description of both so the createTable and select statements are still correct. I also changed 'convert a uuid (char(16))' to 'convert a string uuid (char(36))' in uuidToBin to match the description of binToUuid and the corresponding code example. In addition I changed the specified language of the binToUuid code example from ts to js to match the language definitions of the other code examples. * add documentation about compileSqlOnError (#436) * Update .returning documentation to include SQLite support (#438) This documentation update corresponds to the changes implemented in [knex/knex pull request #5285](#5285). * add documentation for mapBinding (#440) * docs: explicit jsonb suppor for custom pg clients (#423) * fix a link reference (#451) * docs: update predicate, useConstraint options in unique() (#449) * Updated index.md (#460) removed word 'the' before 'any' in migrations section * fix documentation about compileSqlOnError (#463) * raw.md typo fix (#452) * Fix invalid bold (#461) There was another `*` stopping a line from going bold. I fixed that. * fix parameter order in function example (#446) * Updating port (#470) * Fix typo `unqiue` (#477) * Add documentation on comment. (#450) * Document Better-SQLite3 nativeBinding option (#504) * Bump knex from 2.0.0 to 2.4.0 (#485) Bumps [knex](https://github.com/knex/knex) from 2.0.0 to 2.4.0. - [Release notes](https://github.com/knex/knex/releases) - [Changelog](https://github.com/knex/knex/blob/master/CHANGELOG.md) - [Commits](2.0.0...2.4.0) --- updated-dependencies: - dependency-name: knex dependency-type: direct:development ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Update Changelog and fix deadlinks (#506) * Bump vite from 2.9.9 to 2.9.15 (#448) Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 2.9.9 to 2.9.15. - [Release notes](https://github.com/vitejs/vite/releases) - [Changelog](https://github.com/vitejs/vite/blob/v2.9.15/packages/vite/CHANGELOG.md) - [Commits](https://github.com/vitejs/vite/commits/v2.9.15/packages/vite) --- updated-dependencies: - dependency-name: vite dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Typo/Grammar (#491) Documentation grammar. `An` not required in this case--even though it precedes a vowel. * fix doc typo (#482) * Fix spacing typos (#467) * Fix erroneous basic config example (#443) Fixes the example of how to use an async function to get connection details. The current example shows you can export an async function returning an entire [`Config`](https://github.com/knex/knex/blob/2dadde4214d9ee333adccfa517089647e94d23be/types/index.d.ts#L2698) object. However, the [type definition](https://github.com/knex/knex/blob/2dadde4214d9ee333adccfa517089647e94d23be/types/index.d.ts#L2703) shows that the `connection` property can be an async function. I can confirm that TypeScript won't compile when following the current example. * Improve documentation for extending QueryBuilder (#462) Changes made: 1. Changed variable where `QueryBuilder` class is located at. `Knex.QueryBuilder` is a typescript interface defined in `Knex` namespace. `QueryBuilder` class is located at `knex.QueryBuilder`. 2. Changed `QueryBuilder` interface to `QueryInterface` in custom typescript definitions. To make the custom method appear at `knex()` object, we should augment `QueryInterface`, since it's the type `Knex` interface extends. * adds documentation about how to group and order inputs to a union (#500) * adds documentation about how to group and order inputs to a union * provide links to query lab for example * docs: reference to issues in changelog (#420) * docs: reference to issues in changelog * reference issues in last changelogs --------- Co-authored-by: Olivier Cavadenti <[email protected]> * Update all remaining issues links in changelog (#507) * Fix issues links (#508) * Fix links (#509) Co-authored-by: Garrit Franke <[email protected]> * Fix url esm-interop (#517) * Document Better-SQLite3 readonly option (#505) * Update transactions.md (#489) * docs(pg): document QueryBuilder#updateFrom (#476) * docs: document uuid utility function (#527) * Update changelog for 2.5.0 (cherry picked from commit 063b380c76f6990b0c3a1470876e0781dbc98d6a) * Fix changelog title release * docs(pg): terminate code block in query-builder.md (#528) * docs: provide more usage patterns for Knex configuration object (#529) * Update changelog for 2.5.1 * Bump vite from 2.9.15 to 2.9.16 (#523) Bumps [vite](https://github.com/vitejs/vite/tree/HEAD/packages/vite) from 2.9.15 to 2.9.16. - [Release notes](https://github.com/vitejs/vite/releases) - [Changelog](https://github.com/vitejs/vite/blob/v2.9.16/packages/vite/CHANGELOG.md) - [Commits](https://github.com/vitejs/vite/commits/v2.9.16/packages/vite) --- updated-dependencies: - dependency-name: vite dependency-type: indirect ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Add note regarding timestamps() for Postgres users (#475) * fix doc typo (#474) * Adding ability to have a custom getNewMigrationName function. (#484) * add stream as iterator part (#454) * Update documentation to include except keyword (#468) * Update schema-builder.md (#432) * Added extending docs (#414) * docs: add TypeScript module augmentation help (#531) * Move website deployment to root and run only on docs changes * run format on the docs folder * update links * Update CONTRIBUTING.md Co-authored-by: Igor Savin <[email protected]> * use npm instead of yarn --------- Signed-off-by: Boelensman1 <[email protected]> Signed-off-by: blam <[email protected]> Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: Igor Savin <[email protected]> Co-authored-by: Lee Allen <[email protected]> Co-authored-by: Daniel Mills <[email protected]> Co-authored-by: Lorefnon <[email protected]> Co-authored-by: EthanHur <[email protected]> Co-authored-by: Matthew Kuo <[email protected]> Co-authored-by: Daniel Norman <[email protected]> Co-authored-by: Vamp <[email protected]> Co-authored-by: Felix Mosheev <[email protected]> Co-authored-by: Ricardo Maes <[email protected]> Co-authored-by: Matthew Kuo <[email protected]> Co-authored-by: Joe Warner <[email protected]> Co-authored-by: julescubtree <[email protected]> Co-authored-by: Anton Sitnikov <[email protected]> Co-authored-by: Vithalreddy.M.B <[email protected]> Co-authored-by: Taras Ozarko <[email protected]> Co-authored-by: Nekrasov Ilya <[email protected]> Co-authored-by: Nima Boscarino <[email protected]> Co-authored-by: Micheal Winger <[email protected]> Co-authored-by: maximelkin <[email protected]> Co-authored-by: Oran Epelbaum <[email protected]> Co-authored-by: Igor Savin <[email protected]> Co-authored-by: Jan Swist <[email protected]> Co-authored-by: Mr D <[email protected]> Co-authored-by: Florent Vilmart <[email protected]> Co-authored-by: Edvaldo Szymonek <[email protected]> Co-authored-by: Jonas Gebhardt <[email protected]> Co-authored-by: Niek <[email protected]> Co-authored-by: Matthew Leffler <[email protected]> Co-authored-by: Zach McElrath <[email protected]> Co-authored-by: Zach McElrath <[email protected]> Co-authored-by: Danial Malik <[email protected]> Co-authored-by: Rico Kahler <[email protected]> Co-authored-by: Eli Geller <[email protected]> Co-authored-by: Mathieu DARTIGUES <[email protected]> Co-authored-by: Ludovic HOCHET <[email protected]> Co-authored-by: Tizian Adam <[email protected]> Co-authored-by: Ivan Zhuravlev <[email protected]> Co-authored-by: Arturs Vonda <[email protected]> Co-authored-by: Nico Burns <[email protected]> Co-authored-by: Jess Martin <[email protected]> Co-authored-by: Mark Boyd <[email protected]> Co-authored-by: Kkmatt11 <[email protected]> Co-authored-by: Ben Lu <[email protected]> Co-authored-by: CorvusCorrax <[email protected]> Co-authored-by: martinmacko47 <[email protected]> Co-authored-by: George Petrov <[email protected]> Co-authored-by: Matt <[email protected]> Co-authored-by: Matt Goodson <[email protected]> Co-authored-by: Joshua Weiss <[email protected]> Co-authored-by: Daniel Ferenc Balogh <[email protected]> Co-authored-by: Daniel Hensby <[email protected]> Co-authored-by: Jeremy W. Sherman <[email protected]> Co-authored-by: Isaac Batista <[email protected]> Co-authored-by: Jérémy Lal <[email protected]> Co-authored-by: Benedict Tesha <[email protected]> Co-authored-by: Wigger Boelens <[email protected]> Co-authored-by: Jonathan <[email protected]> Co-authored-by: Huseyin ELMAS <[email protected]> Co-authored-by: Bruno P. Kinoshita <[email protected]> Co-authored-by: zeotuan <[email protected]> Co-authored-by: wolfcomp <[email protected]> Co-authored-by: Mathias Lundell <[email protected]> Co-authored-by: Ahacad <[email protected]> Co-authored-by: Alan Andrade <[email protected]> Co-authored-by: Matt Machuga <[email protected]> Co-authored-by: Dustin Wheeler <[email protected]> Co-authored-by: Orhan Toy <[email protected]> Co-authored-by: Olivier Cavadenti <[email protected]> Co-authored-by: Flleeppyy <[email protected]> Co-authored-by: Adam Burgess <[email protected]> Co-authored-by: Olivier CAVADENTI <[email protected]> Co-authored-by: Dominik Krejcik <[email protected]> Co-authored-by: Daniel Black <[email protected]> Co-authored-by: Jiří Hofman <[email protected]> Co-authored-by: Seth Holladay <[email protected]> Co-authored-by: Jeremy Walker <[email protected]> Co-authored-by: Ben Lambert <[email protected]> Co-authored-by: Shane A. Stillwell <[email protected]> Co-authored-by: Marat Levit <[email protected]> Co-authored-by: Manda Putra <[email protected]> Co-authored-by: Richard <[email protected]> Co-authored-by: Tim Griesser <[email protected]> Co-authored-by: Alex Pavlovich <[email protected]> Co-authored-by: Owen Allen <[email protected]> Co-authored-by: Sacha STAFYNIAK <[email protected]> Co-authored-by: Benicio Cardozo <[email protected]> Co-authored-by: Peiman Nourani <[email protected]> Co-authored-by: Andres Kalle <[email protected]> Co-authored-by: 찰스 <[email protected]> Co-authored-by: Lucas Bickel <[email protected]> Co-authored-by: Felix Wehnert <[email protected]> Co-authored-by: Phạm Thành Trung <[email protected]> Co-authored-by: Bruno Enten <[email protected]> Co-authored-by: Tobias Jäger <[email protected]> Co-authored-by: Jakob Joonas <[email protected]> Co-authored-by: Simon Plenderleith <[email protected]> Co-authored-by: Kelly Bourg <[email protected]> Co-authored-by: Hasnae <[email protected]> Co-authored-by: Woosik Kim <[email protected]> Co-authored-by: abal <[email protected]> Co-authored-by: Tejas Dhamecha <[email protected]> Co-authored-by: Arthur Tabatchnic <[email protected]> Co-authored-by: TheUntraceable <[email protected]> Co-authored-by: Maurice Doepke <[email protected]> Co-authored-by: Keyu Ubi <[email protected]> Co-authored-by: Tom <[email protected]> Co-authored-by: François de Metz <[email protected]> Co-authored-by: Erin Dees <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: duckboy81 <[email protected]> Co-authored-by: Arpit Pandey <[email protected]> Co-authored-by: will ye <[email protected]> Co-authored-by: Craig Blackburn <[email protected]> Co-authored-by: aiven715 <[email protected]> Co-authored-by: Justin Schoen <[email protected]> Co-authored-by: Mohamed Emad <[email protected]> Co-authored-by: Benjamin Chodoroff <[email protected]> Co-authored-by: Garrit Franke <[email protected]> Co-authored-by: Alpha Vylly <[email protected]> Co-authored-by: Erin Dees <[email protected]> Co-authored-by: Omar Abdelkader <[email protected]> Co-authored-by: Warren Seymour <[email protected]> Co-authored-by: André Ricardo <[email protected]> Co-authored-by: Liran Tal <[email protected]> Co-authored-by: Ashot Nazaryan <[email protected]> Co-authored-by: Aleix Morgadas <[email protected]> Co-authored-by: Salvatore Garbesi <[email protected]> Co-authored-by: Kévin Berthommier <[email protected]> Co-authored-by: Deirdre Sweeney <[email protected]> Co-authored-by: StefanAvra <[email protected]> Co-authored-by: Dominic Vonk <[email protected]> Co-authored-by: Calvin <[email protected]>
Still need to fix up the migrations and clean up a few other things, but I wanted to create a ticket that details the new minor release so people can take a look and give any feedback, because the internal changes are pretty significant and exciting.
The library will still take the "Batteries Included" approach: calling
Knex.initialize(config)
will make sure everything is taken care of for you. The entire library has been refactored such that a "client" object is now the central piece of the library, with a set of constructors conditionally attached, independent to each client instance (i.e.client.QueryBuilder
):Always loaded:
Added conditionally if you've specified a connection:
Added conditionally if any of the schema methods are called:
...and in SQLite3, where anything related to DDL is a complete mess:
Added conditionally if the migration utilities are used:
It helps makes things super obvious as to where features should be added, and what the model should be when adding new clients. Also, since each client has independent constructors, it's totally fine to write plugins/modify things as needed without potentially running into issues with others' instances.
Some of the main issues that have come up deal with raw queries and the fact that you can't specify bound parameters when injecting raw statements within a knex query. The solution to this was pretty in-depth, it involved rewriting most of the structure of the entire builder, each call to a query builder pushes the arguments onto a
statements
array, rather than try to add the bindings as the methods are called.This allows us to do things like:
or to re-use queries by placing them in other queries (see #162 for a neat use):
This works because everything now follows a "Builder" -> "Compiler" sequence, where the query is first built, and then "compiled", where the compiler uses its own formatter object, keeping track of the position of the bindings as the query is compiled rather than as it is built.
This new structure also make it super straightforward on how to add new features, for example facilities for view creation. In fact I've taken the liberty of putting a viewbuilder.js & viewcompiler.js in the schema directory, they're empty, anyone can feel free to take that one on :)
Also, as you may have noticed, all methods can be chained from the
knex
object, and don't need to start withknex(tableName)
though that behavior is still supported,knex.insert(values).into(table)
orknex.table(name).update(values)
orknex.select(columns).from(table)
all work as you'd expect, making query composition a nicer experience.There are also major number of unit tests added, adapted from laravel's suite :)
The new structure should also make it really obvious how to add additional adapters, @tybenz if you want to take a look for mssql, that'd be great. There's also a number of unit tests to start you off that are commented out from laravel's suite.
Other features:
.references(tableName.columnName)
as shorthand for.references(columnName).inTable(tableName)
.join('table.column', 'otherTable.column')
as shorthand for.join('table.column', '=', 'otherTable.column')
Deprecated:
join
's with the trailing argument, e.g.join('table.id', '=', 'otherTable.table_id', 'left outer')
are now.leftOuterJoin('table.id', '=', 'otherTable.table_id')
or more succinctly.leftOuterJoin('table.id', 'otherTable.table_id')
whereRaw
,orWhereRaw
,havingRaw
,orHavingRaw
are now just.where(knex.raw(rawQuery, bindings))
, etc.Still left to-to:
A simple bench against building a simple query with a few where's showed about a 4x improvement from 0.5
Interested to hear any questions/thoughts people have on this, feel free to take a look through and let me know what you think. Hoping to get this out by the end of the month.
/cc @tkellen and @neilk