Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Add database specific string concatenation | Keenan Brock | 2016-01-05 | 3 | -2/+27 |
| | |||||
* | Implement CASE Conditional Expression | Felix Bünemann | 2016-01-05 | 2 | -0/+72 |
| | |||||
* | Merge pull request #369 from codeodor/patch-1 | Rafael França | 2015-12-17 | 1 | -3/+3 |
|\ | | | | | Improve error message when passed unsupported type | ||||
| * | Use a specific exception for unsupported visits | Sammy Larbi | 2015-07-14 | 1 | -3/+3 |
| | | |||||
* | | Merge pull request #390 from yahonda/expr_oracle12 | Rafael França | 2015-12-17 | 1 | -2/+2 |
|\ \ | | | | | | | No need to quote limit for Oracle12 visitor | ||||
| * | | No need to quote limit for Oracle12 visitor | Yasuo Honda | 2015-09-01 | 1 | -2/+2 |
| |/ | |||||
* | | test match predicate case sensitivity attribute | Keenan Brock | 2015-12-05 | 1 | -0/+6 |
| | | |||||
* | | introduce predicate {does_not_}matches_regexp | Keenan Brock | 2015-12-05 | 1 | -6/+13 |
| | | |||||
* | | use valid regular expression in regexp test | Keenan Brock | 2015-12-05 | 1 | -12/+12 |
| | | |||||
* | | Add case sensitive regexp | Keenan Brock | 2015-12-05 | 1 | -0/+14 |
| | | | | | | | | | | | | | | Explicitly declare if this is case sensitive or not currently postgres assumes case insensitive regexp no other databases support regexps | ||||
* | | Add case sensitive match | Keenan Brock | 2015-12-05 | 1 | -0/+14 |
|/ | | | | | | | Explicitly declare if this is case sensitive or not most implementation assume case sensitive postgres assumes case insensitive | ||||
* | Merge pull request #337 from yahonda/support_oracle12_top_n_2 | Aaron Patterson | 2015-07-14 | 1 | -0/+47 |
|\ | | | | | Support Oracle 12c top-N query | ||||
| * | Create Arel::Visitors::Oracle12 to provide better top-N query | Yasuo Honda | 2015-06-19 | 1 | -0/+47 |
| | | | | | | | | to support `FETCH FIRST n ROWS` and `OFFSET` for Oracle 12c database | ||||
* | | Follow up #370 for Oracle, to fix undefined method `expr' for 10:Fixnum bug. | Eric Guo | 2015-07-14 | 1 | -2/+2 |
|/ | |||||
* | Special limited delete handling in MSSQL | Tamir Duberstein | 2015-02-23 | 1 | -0/+9 |
| | | | | | Refernce: https://technet.microsoft.com/en-us/library/ms175486%28v=sql.105%29.aspx | ||||
* | Change the interface of `having` to match that of `where` | Sean Griffin | 2015-01-27 | 2 | -4/+2 |
| | | | | | | These two clauses have nearly identical semantics with regards to how they would be constructed as an AST. It doesn't make sense for their interfaces to be separate. | ||||
* | {Matches,DoesNotMatch} support the ESCAPE clause with PostgreSQL | Kazuya NUMATA | 2014-12-25 | 1 | -0/+14 |
| | | | | | to_SQL already has supported the ESCAPE clause in #318. PostgreSQL can use the ESCAPE clause too. | ||||
* | Remove `engine` from `TreeManager` and subclasses | Sean Griffin | 2014-11-29 | 1 | -1/+1 |
| | | | | | | This constructor parameter was unused for everything except the convenience methods `to_sql` and `where_sql`. We can pass the engine into those methods directly. | ||||
* | Remove deprecated method "Table#primary_key" | Sean Griffin | 2014-11-26 | 1 | -0/+19 |
| | | | | | | | The only place this method was still used is on the MSSQL visitor. The visitor has all of the objects required to inline this lookup there. Since the `primary_key` method on the connection adapter will perform a query when called, we can cache the result on the visitor. | ||||
* | remove extra space before 'ORDER BY' | Nihad Abbasov | 2014-11-26 | 1 | -1/+8 |
| | |||||
* | Support Oracle bind parameter value | Yasuo Honda | 2014-11-20 | 1 | -1/+12 |
| | |||||
* | Use class objects rather than strings for the dispatch cache | Sean Griffin | 2014-11-18 | 1 | -1/+1 |
| | | | | | | | | The only reason we're using strings is to pre-populate the cache, but `Class#name` returns a new string instance on every call. This is a pretty major source of memory usage. We don't technically need to pre-populate the cache, and not doing so allows us to go back to using cache objects | ||||
* | Add order to BindParams in the ToSql collector | Sean Griffin | 2014-11-17 | 3 | -4/+21 |
| | | | | | | | | | | | | This removes the need for us to do the re-ordering by walking the AST in ActiveRecord. We're using a block to communicate with the collector, since the collector needs to be the thing which knows about the index, while the visitor is the thing that needs to know the syntax. The BindParam needs to know about neither of these things, so it's been changed to stop being a subclass of SqlLiteral I could also see an alternative implementation using format strings if for some reason blocks cause a problem. | ||||
* | Deprecate passing ranges to `#in` and `#not_in` | Sean Griffin | 2014-10-25 | 1 | -12/+12 |
| | | | | | | | The goal of these methods should be to generate in nodes, not handle every possible permutation of more than one value. The `#between` and `#not_between` methods have been extracted, which better represent the semantics of handling ranges in SQL. | ||||
* | `#not_in` with a range should respect proper precedence | Sean Griffin | 2014-10-24 | 1 | -6/+6 |
| | | | | | | | | | | | | | | | | | | Currently, doing ```ruby relation[:id].not_eq(4).and(relation[:id].not_in(1..3)) ``` will generate ```sql "id" != 4 AND "id" < 1 OR "id" > 3 ``` Which would incorrectly include records with an id of 4, as the OR statement has higher precidence than the AND statement. The `or` method on `Node` properly groups the statement in parenthesis. | ||||
* | {Matches,DoesNotMatch} support the ESCAPE clause | Tamir Duberstein | 2014-09-25 | 1 | -0/+14 |
| | |||||
* | move the dispatch table to be per-instance | Aaron Patterson | 2014-09-22 | 2 | -7/+1 |
| | | | | | | | visitors are not shared among threads, so any mutations to the cache should be OK. The cache is also pre-populated on construction, but we should pull that out so we can share the cache among visitors in the future. | ||||
* | Fix set visiting spec | Dimko | 2014-09-17 | 1 | -1/+1 |
| | |||||
* | Merge pull request #167 from pparidans/informix-v9-support | Rafael Mendonça França | 2014-09-17 | 1 | -6/+6 |
|\ | | | | | Informix versions < 10 use 'FIRST' keyword instead of 'LIMIT' | ||||
| * | Informix versions < 10 use 'FIRST' keyword instead of 'LIMIT' | Pierre Paridans | 2014-09-16 | 1 | -6/+6 |
| | | | | | | | | Still supported in versions 10+ | ||||
* | | Merge pull request #137 from dimko/visit_set | Rafael Mendonça França | 2014-09-17 | 2 | -0/+13 |
|\ \ | |/ |/| | Added a visitor for Set objects | ||||
| * | added a visitor for Set objects | Dimko | 2012-09-18 | 2 | -0/+13 |
| | | |||||
* | | Wrap group_by sql with a subquery for limiting rows in Oracle. | Chris Dinger | 2014-09-16 | 1 | -0/+10 |
| | | | | | | | | Fixes #128 | ||||
* | | Merge pull request #277 from sergey-alekseev/wrap-nested-gropings-only-once | Rafael Mendonça França | 2014-09-12 | 1 | -0/+7 |
|\ \ | | | | | | | Wrap nested Nodes::Grouping in brackets only once | ||||
| * | | Wrap nested Nodes::Grouping in brackets only once | Sergey Alekseev | 2014-05-26 | 1 | -0/+7 |
| | | | |||||
* | | | Modify Visitors::Dot's API to use collectors | Jiri Pospisil | 2014-06-14 | 1 | -4/+4 |
| | | | |||||
* | | | - Fix ambiguous argument warning | Vipul A M | 2014-05-31 | 1 | -1/+1 |
| | | | | | | | | | | | | - Fix typo: `test_opertaion_ordering` => `test_operation_ordering` | ||||
* | | | Asserting on error message | Brock Trappitt | 2014-05-28 | 1 | -3/+2 |
| | | | |||||
* | | | Test which checks the error being raised by #unsupported in ToSql Visitor | Brock Trappitt | 2014-05-27 | 1 | -0/+6 |
|/ / | |||||
* | | Support to add the casting node to the AST at build time | Yasuo Honda | 2014-05-05 | 1 | -2/+2 |
| | | | | | | | | Ref https://github.com/rails/arel/commit/93d72131bcc24ccb5536bec672d2dac94f8de651 | ||||
* | | Test quoting integers when comparing a string column with integers. | Dylan Smith | 2014-04-28 | 1 | -2/+14 |
| | | | | | | | | | | | | | | | | | | | | An equality with a string column and integer like SELECT * FROM `users` WHERE `login_token` = 0 LIMIT 1; will match match any string that doesn't start with a digit in certain databases, like mysql. Make sure we quote the integer to avoid this problem in a database independant way. | ||||
* | | make the bindvalue visitor backwards compatible | Aaron Patterson | 2014-04-09 | 1 | -3/+3 |
| | | |||||
* | | fixing bind value tests | Aaron Patterson | 2014-04-08 | 1 | -5/+3 |
| | | |||||
* | | fixing ibm db | Aaron Patterson | 2014-04-08 | 1 | -2/+6 |
| | | |||||
* | | informix is working | Aaron Patterson | 2014-04-08 | 1 | -6/+10 |
| | | |||||
* | | mssql visitor is working | Aaron Patterson | 2014-04-08 | 1 | -8/+12 |
| | | |||||
* | | fixing mysql visitor | Aaron Patterson | 2014-04-08 | 1 | -7/+11 |
| | | |||||
* | | oracle tests passing | Aaron Patterson | 2014-04-08 | 1 | -19/+23 |
| | | |||||
* | | postgresql visitor is working | Aaron Patterson | 2014-04-08 | 2 | -15/+18 |
| | | |||||
* | | fix sqlite visitor | Aaron Patterson | 2014-04-08 | 1 | -2/+2 |
| | |