mirror of https://github.com/AMT-Cheif/drift.git
9.0 KiB
9.0 KiB
0.31.0-dev
- Add
SqlEngine.parseMultiple
to parse multiple statements into one AST.
0.30.3
- Fix
WITH
clauses not being resolved for compound select statements.
0.30.2
- Fix false-positive "unknown table" errors when the same table is used in a join with and then without an alias.
0.30.1
- Report syntax error for
WITH
clauses in triggers.
0.30.0
- Add
previous
andnext
fields for tokens
0.29.0
- Parser support for constructor names in
WITH
drift syntax. - Support resolving
IIF
functions. - Fix a crash when a CTE is used on an insert, update or delete statement.
- Fix wrong column names being reported for references in subqueries and CTEs.
0.28.1
- Fix false-positive warnings about
AS
aliases in subqueries used in triggers.
0.28.0
- Support the
unhex
function added in sqlite 3.41.0 - Support custom keyword sets when formatting SQL.
0.27.0
- Add
mappedBy
toExpressionResultColumn
when parsing in drift mode.
0.26.1
- Fix missing space when formatting aggregate functions.
0.26.0
- Remove token parameter from constructor in
Literal
subclasses andNumberedVariable
.
0.25.0
- Better analysis support for
ANY
columns inSTRICT
tables. - Assign resolved schema columns to synctactical
ResultColumn
in queries.
0.24.0
- Make
Fts5Table
constructor public.
0.23.3
- Analysis support for the spellfix extension.
0.23.2
- Support resolving the
fts5vocab
module whenfts5
is enabled - thanks to @FaFre. - Support the
rtree
extension - also thanks to @FaFre! - Improve references resolving across subqueries.
0.23.1
- Gracefully handle tokenizer errors related to
@
or$
variables.
0.23.0
- Apply type hints for date times on textual datetime functions as well.
0.22.0
- Refactor how tables and columns are resolved internally.
- Lint for
DISTINCT
misuse in aggregate function calls. - Support the
RIGHT
andFULL
join operators added in sqlite 3.39.0. - Support
IS DISTINCT FROM
andIS NOT DISTINCT FROM
syntax added in sqlite 3.39.0. - Fix type inference for
SUM()
calls around int "subtypes" (like booleans).
0.21.0
- Analysis support for new features in sqlite version 3.38.
- Replace internal
moor
references withdrift
references.
0.20.1
- Fix SQL generation for upsert statements with a conflict target.
0.20.0
- Support
LIST
columns for a drift-specific feature.
0.19.2
- Improve handling of drift-specific column types in
STRICT
tables.
0.19.1
- Make the result of
group_concat
nullable.
0.19.0
- Support generated columns.
- Support features introduced in sqlite version 3.37, most notably
STRICT
tables.
0.18.1
- Fix the AST comparator missing errors for different amount of children.
0.18.0
- Fix unecessary errors around
fts5
tables - Merge all moor-specific nodes into a single
visitMoorSpecific
visitor method - Parse
BEGIN
andCOMMIT
statements - Improve type inference around
RETURNING
clauses.
0.17.2
- Fix nullability analysis of
COALESCE
andIFNULL
0.17.1
- Fix nullability analysis of references and star columns
0.17.0
- Refactor how tables and columns are resolved in statements
- The new
ResultSetAvailableInStatement
class describes a result set that has been added to a statement, for instance through a from clause - A
TableOrSubquery
with an alias now introduces aTableAlias
instead of the original table
0.16.0
- New analysis checks for
RETURNING
: Disallowtable.*
syntax and aggregate expressions - Support
RAISE
expressions in triggers - Fix resolving columns when
RETURNING
is used in anUPDATE FROM
statement - Fix aliases to rowid being reported as nullable
0.15.0
- Breaking: Change
InsertStatement.upsert
to a list of upsert clauses- Support multiple upsert clauses
- Do not require a conflict target in the last clause
- Support
RETURNING
clauses in updates, deletes and inserts - Support
FROM
clauses inUPDATE
statements - Support
MATERIALIZED
/NOT MATERIALIZED
hints in common table expressions - Add
BuiltInMathExtension
which corresponds to the-DSQLITE_ENABLE_MATH_FUNCTIONS
compile-time option for sqlite. - Add
EngineOptions.version
argument to specify the desired sqlite version. Using newer features will be reported as analysis warnings. - Fix
rank
columns of fts5 tables being misreported as integers
0.14.0
- Fix views using common table expressions
0.13.0-nullsafety.0
- Parse ordering in table key constraints
- Deprecate
KeyClause.indexedColumns
in favor ofKeyClause.columns
- Deprecate
0.12.0-nullsafety.0
- Migrate to null-safety
- Remove legacy type inference
- Parser support for new moor features
0.11.0
- New
package:sqlparser/utils/node_to_text.dart
library that turns an AST node back into a textual representation. - Fix precedence of
CASE
expressions
0.10.1
- Scan identifiers with
[bracket syntax]
NumericToken
now contains individual lexemes making up the number- Improve error messages in some scenarios
- Fix type inference for binary expressions where the operands have incompatible types
- Improve type inference around
NULL
0.10.0
- Breaking: Made
RecursiveVisitor.visit
,visitList
andvisitExcept
an extension onAstVisitor
. - Support the transformer pattern to modify ast nodes
- Breaking:
FrameBoundary
,DeleteTarget
,UpdateTarget
,DefaultValues
andInsertTarget
are no longer constant - Breaking: Removed
visitQueryable
. UsedefaultQueryable
instead. - Support parsing and analyzing
CREATE VIEW
statements (seeSchemaFromCreateTable.readView
). Thanks to @mqus for their contribution! SqlEngine.parse
will no longer throw when there's a parsing error (useParseResult.errors
instead).- Parse
DEFERRABLE
clauses on foreign key constraints - Parse
NULLS FIRST
andNULLS LAST
onORDER BY
terms
0.9.0
- New
package:sqlparser/utils/find_referenced_tables.dart
library. Use it to easily find all referenced tables in a query. - Support row values 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
- Remove
SqlEngine.withOptions
constructor - the default constructor now takes options - Changed
SelectStatement.from
fromList<Queryable>
toQueryable?
. Selecting from multiple tables with a comma will now be parsed as aJoinClause
. - Changed
SelectStatementAsSource.statement
fromSelectStatement
toBaseSelectStatement
and allow compound select statements to appear in aFROM
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, theuseLegacyTypeInference
flag can be used.
0.7.0
- New feature: Table valued functions.
- Breaking: Removed the
enableJson1
parameter onEngineOptions
. Add aJson1Extension
instance toenabledExtensions
instead. - Parse
rowid
as a valid reference when needed (SELECT rowid FROM tbl
is now parsed correctly) - Parse
CURRENT_TIME
,CURRENT_DATE
andCURRENT_TIMESTAMP
- Parse
UPSERT
clauses for insert statements
0.6.0
- 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 theISNULL
/NOTNULL
postfixes - Support parsing
CREATE TRIGGER
statements - Support parsing
CREATE INDEX
statements
0.5.0
- Optionally support the
json1
module - Optionally support the
fts5
module
0.4.0
- Support common table expressions
- Handle special
rowid
,oid
,__rowid__
references - Support references to
sqlite_master
andsqlite_sequence
tables
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
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 oftable1 CROSS JOIN table2
. - Parser now complains when parsing a query doesn't fully consume the input
0.1.0
Initial version, can parse most statements but not DELETE
, common table expressions and other advanced features.