-
Notifications
You must be signed in to change notification settings - Fork 31
feat: avoid adding dummy WHERE clause into UPDATE and DELETE queires #516
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
Changes from 3 commits
d6c7687
07c182a
a924e90
b58acf6
285dda5
50f45d6
164669f
7d7ec73
fe89045
e488292
3d04571
dc060c1
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -8,6 +8,7 @@ | |
|
|
||
| import datetime | ||
| import decimal | ||
| import os | ||
| import re | ||
| from functools import reduce | ||
|
|
||
|
|
@@ -53,6 +54,105 @@ | |
|
|
||
| RE_PYFORMAT = re.compile(r"(%s|%\([^\(\)]+\)s)+", re.DOTALL) | ||
|
|
||
| SPANNER_RESERVED_KEYWORDS = { | ||
| "ALL", | ||
| "AND", | ||
| "ANY", | ||
| "ARRAY", | ||
| "AS", | ||
| "ASC", | ||
| "ASSERT_ROWS_MODIFIED", | ||
| "AT", | ||
| "BETWEEN", | ||
| "BY", | ||
| "CASE", | ||
| "CAST", | ||
| "COLLATE", | ||
| "CONTAINS", | ||
| "CREATE", | ||
| "CROSS", | ||
| "CUBE", | ||
| "CURRENT", | ||
| "DEFAULT", | ||
| "DEFINE", | ||
| "DESC", | ||
| "DISTINCT", | ||
| "DROP", | ||
| "ELSE", | ||
| "END", | ||
| "ENUM", | ||
| "ESCAPE", | ||
| "EXCEPT", | ||
| "EXCLUDE", | ||
| "EXISTS", | ||
| "EXTRACT", | ||
| "FALSE", | ||
| "FETCH", | ||
| "FOLLOWING", | ||
| "FOR", | ||
| "FROM", | ||
| "FULL", | ||
| "GROUP", | ||
| "GROUPING", | ||
| "GROUPS", | ||
| "HASH", | ||
| "HAVING", | ||
| "IF", | ||
| "IGNORE", | ||
| "IN", | ||
| "INNER", | ||
| "INTERSECT", | ||
| "INTERVAL", | ||
| "INTO", | ||
| "IS", | ||
| "JOIN", | ||
| "LATERAL", | ||
| "LEFT", | ||
| "LIKE", | ||
| "LIMIT", | ||
| "LOOKUP", | ||
| "MERGE", | ||
| "NATURAL", | ||
| "NEW", | ||
| "NO", | ||
| "NOT", | ||
| "NULL", | ||
| "NULLS", | ||
| "OF", | ||
| "ON", | ||
| "OR", | ||
| "ORDER", | ||
| "OUTER", | ||
| "OVER", | ||
| "PARTITION", | ||
| "PRECEDING", | ||
| "PROTO", | ||
| "RANGE", | ||
| "RECURSIVE", | ||
| "RESPECT", | ||
| "RIGHT", | ||
| "ROLLUP", | ||
| "ROWS", | ||
| "SELECT", | ||
| "SET", | ||
| "SOME", | ||
| "STRUCT", | ||
| "TABLESAMPLE", | ||
| "THEN", | ||
| "TO", | ||
| "TREAT", | ||
| "TRUE", | ||
| "UNBOUNDED", | ||
| "UNION", | ||
| "UNNEST", | ||
| "USING", | ||
| "WHEN", | ||
| "WHERE", | ||
| "WINDOW", | ||
| "WITH", | ||
| "WITHIN", | ||
| } | ||
|
|
||
|
|
||
| def classify_stmt(query): | ||
| """Determine SQL query type. | ||
|
|
@@ -402,107 +502,13 @@ def ensure_where_clause(sql): | |
| for token in sqlparse.parse(sql)[0] | ||
| ): | ||
| return sql | ||
| return sql + " WHERE 1=1" | ||
|
|
||
| if os.environ.get("RUNNING_SPANNER_BACKEND_TESTS") == "1": | ||
| return sql + " WHERE 1=1" | ||
|
|
||
| SPANNER_RESERVED_KEYWORDS = { | ||
| "ALL", | ||
| "AND", | ||
| "ANY", | ||
| "ARRAY", | ||
| "AS", | ||
| "ASC", | ||
| "ASSERT_ROWS_MODIFIED", | ||
| "AT", | ||
| "BETWEEN", | ||
| "BY", | ||
| "CASE", | ||
| "CAST", | ||
| "COLLATE", | ||
| "CONTAINS", | ||
| "CREATE", | ||
| "CROSS", | ||
| "CUBE", | ||
| "CURRENT", | ||
| "DEFAULT", | ||
| "DEFINE", | ||
| "DESC", | ||
| "DISTINCT", | ||
| "DROP", | ||
| "ELSE", | ||
| "END", | ||
| "ENUM", | ||
| "ESCAPE", | ||
| "EXCEPT", | ||
| "EXCLUDE", | ||
| "EXISTS", | ||
| "EXTRACT", | ||
| "FALSE", | ||
| "FETCH", | ||
| "FOLLOWING", | ||
| "FOR", | ||
| "FROM", | ||
| "FULL", | ||
| "GROUP", | ||
| "GROUPING", | ||
| "GROUPS", | ||
| "HASH", | ||
| "HAVING", | ||
| "IF", | ||
| "IGNORE", | ||
| "IN", | ||
| "INNER", | ||
| "INTERSECT", | ||
| "INTERVAL", | ||
| "INTO", | ||
| "IS", | ||
| "JOIN", | ||
| "LATERAL", | ||
| "LEFT", | ||
| "LIKE", | ||
| "LIMIT", | ||
| "LOOKUP", | ||
| "MERGE", | ||
| "NATURAL", | ||
| "NEW", | ||
| "NO", | ||
| "NOT", | ||
| "NULL", | ||
| "NULLS", | ||
| "OF", | ||
| "ON", | ||
| "OR", | ||
| "ORDER", | ||
| "OUTER", | ||
| "OVER", | ||
| "PARTITION", | ||
| "PRECEDING", | ||
| "PROTO", | ||
| "RANGE", | ||
| "RECURSIVE", | ||
| "RESPECT", | ||
| "RIGHT", | ||
| "ROLLUP", | ||
| "ROWS", | ||
| "SELECT", | ||
| "SET", | ||
| "SOME", | ||
| "STRUCT", | ||
| "TABLESAMPLE", | ||
| "THEN", | ||
| "TO", | ||
| "TREAT", | ||
| "TRUE", | ||
| "UNBOUNDED", | ||
| "UNION", | ||
| "UNNEST", | ||
| "USING", | ||
| "WHEN", | ||
| "WHERE", | ||
| "WINDOW", | ||
| "WITH", | ||
| "WITHIN", | ||
| } | ||
| raise ProgrammingError( | ||
| "Cloud Spanner requires a WHERE clause when executing DELETE or UPDATE query" | ||
| ) | ||
|
||
|
|
||
|
|
||
| def escape_name(name): | ||
|
|
||
Uh oh!
There was an error while loading. Please reload this page.