drift/sqlparser/CHANGELOG.md

88 lines
3.7 KiB
Markdown
Raw Normal View History

## 0.10.0
- Breaking: Made `RecursiveVisitor.visit`, `visitList` and `visitExcept` an extension on `AstVisitor`.
2020-05-24 13:30:25 -07:00
- Support the transformer pattern to modify ast nodes
- Breaking: `FrameBoundary`, `DeleteTarget`, `UpdateTarget`, `DefaultValues` and `InsertTarget` are no longer constant
- Breaking: Removed `visitQueryable`. Use `defaultQueryable` instead.
- Support parsing and analyzing `CREATE VIEW` statements (see `SchemaFromCreateTable.readView`).
Thanks to [@mqus](https://github.com/mqus) for their contribution!
- `SqlEngine.parse` will no longer throw when there's a parsing error (use `ParseResult.errors` instead).
## 0.9.0
- New `package:sqlparser/utils/find_referenced_tables.dart` library. Use it to easily find all referenced tables
in a query.
2020-05-06 12:08:47 -07:00
- Support [row values](https://www.sqlite.org/rowvalue.html) including warnings about misuse
## 0.8.1
- Support collate expressions in the new type inference ([#533](htt
ps://github.com/simolus3/moor/issues/533))
- Added `visitCollateExpression` to the visitor classes
## 0.8.0
2020-05-02 05:17:49 -07:00
- Remove `SqlEngine.withOptions` constructor - the default constructor now takes options
- Changed `SelectStatement.from` from `List<Queryable>` to `Queryable?`. Selecting from multiple
tables with a comma will now be parsed as a `JoinClause`.
- Changed `SelectStatementAsSource.statement` from `SelectStatement` to `BaseSelectStatement` and allow
compound select statements to appear in a `FROM` clause
- Support the `VALUES` clause as select statement
- The new type inference engine is now enabled by default and the `enableExperimentalTypeInference` option
has been removed. To continue using the old engine, the `useLegacyTypeInference` flag can be used.
2020-02-10 10:46:27 -08:00
## 0.7.0
- New feature: Table valued functions.
- __Breaking__: Removed the `enableJson1` parameter on `EngineOptions`. Add a `Json1Extension` instance
to `enabledExtensions` instead.
- Parse `rowid` as a valid reference when needed (`SELECT rowid FROM tbl` is now parsed correctly)
- Parse `CURRENT_TIME`, `CURRENT_DATE` and `CURRENT_TIMESTAMP`
2020-02-03 12:54:49 -08:00
- Parse `UPSERT` clauses for insert statements
## 0.6.0
2019-12-26 03:35:29 -08:00
- __Breaking:__ Added an argument type and argument to the visitor classes
- Experimental new type inference algorithm
(`SqlEngine.withOptions(EngineOptions(enableExperimentalTypeInference: true))`)
- Support `CAST` expressions and the `ISNULL` / `NOTNULL` postfixes
2019-12-31 06:07:08 -08:00
- Support parsing `CREATE TRIGGER` statements
- Support parsing `CREATE INDEX` statements
2019-12-26 03:35:29 -08:00
## 0.5.0
- Optionally support the `json1` module
2019-12-04 06:36:23 -08:00
- Optionally support the `fts5` module
2019-11-13 12:14:38 -08:00
## 0.4.0
2019-10-23 09:03:24 -07:00
- Support common table expressions
- Handle special `rowid`, `oid`, `__rowid__` references
- Support references to `sqlite_master` and `sqlite_sequence` tables
2019-09-25 11:19:39 -07:00
## 0.3.0
- parse compound select statements
- scan comment tokens
- experimental auto-complete engine (only supports a tiny subset based on the grammar only)
- some features that are specific to moor
__0.3.0+1__: Accept `\r` characters as whitespace
2019-08-22 03:27:39 -07:00
## 0.2.0
- Parse `CREATE TABLE` statements
- Extract schema information from parsed create table statements with `SchemaFromCreateTable`.
## 0.1.2
- parse `COLLATE` expressions
- fix wrong order in parsed `LIMIT` clauses
## 0.1.1
Attempt to recognize when a bound variable should be an array (eg. in `WHERE x IN ?`).
Also fixes a number of parsing bugs:
- Parses tuples, proper type resolution for `IN` expressions
- Don't resolve references to tables that don't appear in the surrounding statement.
- Parse joins without any additional operator, e.g. `table1 JOIN table2` instead of
`table1 CROSS JOIN table2`.
- Parser now complains when parsing a query doesn't fully consume the input
## 0.1.0
2019-07-01 06:04:17 -07:00
Initial version, can parse most statements but not `DELETE`, common table expressions and other
advanced features.