arel_extensions 0.9.5 → 0.9.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +7 -5
- data/README.md +351 -2
- data/SQL_Challenges.md +0 -1
- data/TODO +2 -0
- data/functions.html +186 -184
- data/gemfiles/rails4.gemfile +5 -5
- data/gemfiles/rails5.gemfile +5 -5
- data/init/sqlite.sql +0 -1
- data/lib/arel_extensions.rb +2 -0
- data/lib/arel_extensions/math.rb +28 -2
- data/lib/arel_extensions/nodes/coalesce.rb +17 -0
- data/lib/arel_extensions/nodes/substring.rb +21 -0
- data/lib/arel_extensions/railtie.rb +9 -0
- data/lib/arel_extensions/string_functions.rb +15 -0
- data/lib/arel_extensions/tasks.rb +18 -0
- data/lib/arel_extensions/version.rb +1 -1
- data/lib/arel_extensions/visitors/ibm_db.rb +10 -11
- data/lib/arel_extensions/visitors/mssql.rb +15 -0
- data/lib/arel_extensions/visitors/oracle.rb +21 -1
- data/lib/arel_extensions/visitors/postgresql.rb +10 -0
- data/lib/arel_extensions/visitors/sqlite.rb +39 -1
- data/lib/arel_extensions/visitors/to_sql.rb +10 -0
- data/test/with_ar/all_agnostic_test.rb +27 -4
- metadata +5 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 709b543bdf84952b555236ce66c94f37e33b4183
|
4
|
+
data.tar.gz: 053561c6aa304247471bf9effb7712eb913ec281
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 72d08bc341ea513e51f0650cc1677b781929f4af3a2aff55af45c5044643cecd9d7fd82caaa353e4cf8a807477d46c8c2fe394d741d607df9726eb29c623c0a9
|
7
|
+
data.tar.gz: 647156dfc77c72a0bef98112815ed16b050a7523402608c439ddbb704345bea69d990a4df8bc08600426bf92de24f2358cdd0196e1c423166d59378ea20719da
|
data/Gemfile
CHANGED
@@ -3,17 +3,19 @@ source "https://rubygems.org"
|
|
3
3
|
gemspec
|
4
4
|
|
5
5
|
group :development, :test do
|
6
|
-
gem "sqlite3", :platforms => [:mri, :mswin, :mingw
|
7
|
-
gem "mysql2", :platforms => [:mri, :mswin, :mingw
|
8
|
-
gem "pg", :platforms => [:mri, :mingw, :
|
6
|
+
gem "sqlite3", :platforms => [:mri, :mswin, :mingw]
|
7
|
+
gem "mysql2", :platforms => [:mri, :mswin, :mingw]
|
8
|
+
gem "pg", :platforms => [:mri, :mingw, :mswin]
|
9
9
|
|
10
10
|
gem "jdbc-sqlite3", :platforms => :jruby
|
11
11
|
gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby
|
12
12
|
gem "activerecord-jdbcmysql-adapter", :platforms => :jruby
|
13
13
|
gem "activerecord-jdbcpostgresql-adapter", :platforms => :jruby
|
14
14
|
|
15
|
-
|
16
|
-
|
15
|
+
if RUBY_PLATFORM =~ /[^r]win\d\d/
|
16
|
+
gem "tiny_tds", :require => false, :platforms => [:mri, :mingw, :mswin]
|
17
|
+
gem "activerecord-sqlserver-adapter", '~> 4.2.0', :platforms => [:mri, :mingw, :mswin]
|
18
|
+
end
|
17
19
|
|
18
20
|
gem 'activesupport', '~> 4.0'
|
19
21
|
gem 'activemodel', '~> 4.0'
|
data/README.md
CHANGED
@@ -73,7 +73,7 @@ Other functions : ABS, RAND, ROUND, FLOOR, CEIL, FORMAT
|
|
73
73
|
# => my_table.name REGEXP '\^[a-d_]+'
|
74
74
|
```
|
75
75
|
|
76
|
-
Other functions : SOUNDEX, LENGTH, REPLACE, LOCATE, TRIM
|
76
|
+
Other functions : SOUNDEX, LENGTH, REPLACE, LOCATE, SUBSTRING, TRIM
|
77
77
|
|
78
78
|
### String Array operations
|
79
79
|
|
@@ -138,4 +138,353 @@ Arel Extensions improves InsertManager by adding bulk_insert method, which allow
|
|
138
138
|
insert_manager = Arel::InsertManager.new(User).into(User.arel_table)
|
139
139
|
insert_manager.bulk_insert(@cols, @data)
|
140
140
|
User.connection.execute(insert_manager.to_sql)
|
141
|
-
```
|
141
|
+
```
|
142
|
+
|
143
|
+
## New Arel Functions
|
144
|
+
|
145
|
+
<table class="tg arel-functions" style="font-size:80%">
|
146
|
+
<thead>
|
147
|
+
<tr>
|
148
|
+
<th></th>
|
149
|
+
<th class="tg-by3v">Function / Example<br/>ToSql</th>
|
150
|
+
<th class="tg-pjz5">MySQL / MariaDB</th>
|
151
|
+
<th class="tg-pjz5">PostgreSQL</th>
|
152
|
+
<th class="tg-pjz5">SQLite</th>
|
153
|
+
<th class="tg-pjz5">Oracle</th>
|
154
|
+
<th class="tg-pjz5">MS SQL</th>
|
155
|
+
<th class="tg-pjz5">DB2<br/>(not tested on real DB)</th>
|
156
|
+
</tr>
|
157
|
+
</thead>
|
158
|
+
<tbody>
|
159
|
+
<tr>
|
160
|
+
<th class="tg-82sq" rowspan="6"><div>Number functions</div></th>
|
161
|
+
<td class="tg-yw4l">ABS<br>column.abs<br></td>
|
162
|
+
<td class="ok">✔</td>
|
163
|
+
<td class="ok">✔</td>
|
164
|
+
<td class="ok">✔</td>
|
165
|
+
<td class="ok">✔</td>
|
166
|
+
<td class="ok">✔</td>
|
167
|
+
<td class="ok">✔</td>
|
168
|
+
</tr>
|
169
|
+
<tr>
|
170
|
+
<td class="tg-yw4l">CEIL<br>column.ceil</td>
|
171
|
+
<td class="ok">✔</td>
|
172
|
+
<td class="ok">✔</td>
|
173
|
+
<td class="tg-j6lv">CASE + ROUND</td>
|
174
|
+
<td class="ok">✔</td>
|
175
|
+
<td class="tg-j6lv">CEILING()</td>
|
176
|
+
<td class="tg-j6lv">CEILING()</td>
|
177
|
+
</tr>
|
178
|
+
<tr>
|
179
|
+
<td class="tg-yw4l">FLOOR<br>column.floor</td>
|
180
|
+
<td class="ok">✔</td>
|
181
|
+
<td class="ok">✔</td>
|
182
|
+
<td class="tg-j6lv">CASE + ROUND</td>
|
183
|
+
<td class="ok">✔</td>
|
184
|
+
<td class="ok">✔</td>
|
185
|
+
<td class="ok">✔</td>
|
186
|
+
</tr>
|
187
|
+
<tr>
|
188
|
+
<td class="tg-yw4l">RAND<br>Arel.rand</td>
|
189
|
+
<td class="ok">✔</td>
|
190
|
+
<td class="ok">✔</td>
|
191
|
+
<td class="tg-j6lv">RANDOM()</td>
|
192
|
+
<td class="tg-j6lv">dbms_random.value()</td>
|
193
|
+
<td class="ok">✔</td>
|
194
|
+
<td class="ok">✔</td>
|
195
|
+
</tr>
|
196
|
+
<tr>
|
197
|
+
<td class="tg-yw4l">ROUND<br>column.round(precision = 0)</td>
|
198
|
+
<td class="ok">✔</td>
|
199
|
+
<td class="ok">✔</td>
|
200
|
+
<td class="ok">✔</td>
|
201
|
+
<td class="ok">✔</td>
|
202
|
+
<td class="ok">✔</td>
|
203
|
+
<td class="ok">✔</td>
|
204
|
+
</tr>
|
205
|
+
<tr>
|
206
|
+
<td class="tg-yw4l">SUM / AVG / MIN / MAX + x<br>column.sum + 42</td>
|
207
|
+
<td class="ok">✔</td>
|
208
|
+
<td class="ok">✔</td>
|
209
|
+
<td class="ok">✔</td>
|
210
|
+
<td class="ok">✔</td>
|
211
|
+
<td class="ok">✔</td>
|
212
|
+
<td class="ok">✔</td>
|
213
|
+
</tr>
|
214
|
+
<tr>
|
215
|
+
<th class="tg-ffjm" rowspan="12"><div>String functions</div></th>
|
216
|
+
<td class="tg-yw4l">CONCAT<br>column + "string"</td>
|
217
|
+
<td class="ok">✔</td>
|
218
|
+
<td class="ok">✔</td>
|
219
|
+
<td class="tg-j6lv"> ||</td>
|
220
|
+
<td class="ok">✔</td>
|
221
|
+
<td class="tg-j6lv">+</td>
|
222
|
+
<td class="ok">✔</td>
|
223
|
+
</tr>
|
224
|
+
<tr>
|
225
|
+
<td class="tg-yw4l">LENGTH<br>column.length</td>
|
226
|
+
<td class="ok">✔</td>
|
227
|
+
<td class="ok">✔</td>
|
228
|
+
<td class="ok">✔</td>
|
229
|
+
<td class="ok">✔</td>
|
230
|
+
<td class="tg-j6lv">LEN()</td>
|
231
|
+
<td class="ok">✔</td>
|
232
|
+
</tr>
|
233
|
+
<tr>
|
234
|
+
<td class="tg-yw4l">LOCATE<br>column.locate("string")</td>
|
235
|
+
<td class="ok">✔</td>
|
236
|
+
<td class="ok">✔</td>
|
237
|
+
<td class="tg-j6lv">INSTR()</td>
|
238
|
+
<td class="ok">✔</td>
|
239
|
+
<td class="tg-j6lv">CHARINDEX()</td>
|
240
|
+
<td class="ok">✔</td>
|
241
|
+
</tr>
|
242
|
+
<tr>
|
243
|
+
<td class="tg-yw4l">SUBSTRING<br/>column[1..2]<br/>column.substring(1)<br/>column.substring(1, 1)</td>
|
244
|
+
<td class="ok">✔</td>
|
245
|
+
<td class="tg-j6lv">SUBSTR()</td>
|
246
|
+
<td class="tg-j6lv">SUBSTR()</td>
|
247
|
+
<td class="tg-j6lv">SUBSTR()</td>
|
248
|
+
<td class="ok">✔</td>
|
249
|
+
<td class="ok">✔</td>
|
250
|
+
</tr>
|
251
|
+
<tr>
|
252
|
+
<td class="tg-yw4l">FIND_IN_SET<br>column & ("l")</td>
|
253
|
+
<td class="ok">✔</td>
|
254
|
+
<td class="ok">✔</td>
|
255
|
+
<td class="tg-orpl">db.create_function( "find_in_set", 1 ) <br>do |func, value1, value2|,<br>func.result =value1.index(value2)<br>end <br></td>
|
256
|
+
<td class="ok">✔</td>
|
257
|
+
<td class="ok">✔</td>
|
258
|
+
<td class="ok">✔</td>
|
259
|
+
</tr>
|
260
|
+
<tr>
|
261
|
+
<td class="tg-yw4l">SOUNDEX<br>column.soundex</td>
|
262
|
+
<td class="ok">✔</td>
|
263
|
+
<td class="tg-3oug">require fuzzystrmatch</td>
|
264
|
+
<td class="ok">✔</td>
|
265
|
+
<td class="ok">✔</td>
|
266
|
+
<td class="ok">✔</td>
|
267
|
+
<td class="ok">✔</td>
|
268
|
+
</tr>
|
269
|
+
<tr>
|
270
|
+
<td class="tg-yw4l">REPLACE<br>column.replace("s","X")</td>
|
271
|
+
<td class="ok">✔</td>
|
272
|
+
<td class="ok">✔</td>
|
273
|
+
<td class="ok">✔</td>
|
274
|
+
<td class="ok">✔</td>
|
275
|
+
<td class="ok">✔</td>
|
276
|
+
<td class="ok">✔</td>
|
277
|
+
</tr>
|
278
|
+
<tr>
|
279
|
+
<td class="tg-yw4l">REGEXP<br>column =~ "pattern"<br></td>
|
280
|
+
<td class="ok">✔</td>
|
281
|
+
<td class="ok">✔</td>
|
282
|
+
<td class="tg-3oug">require pcre.so</td>
|
283
|
+
<td class="tg-j6lv">REGEXP_LIKE</td>
|
284
|
+
<td class="tg-j6lv">LIKE</td>
|
285
|
+
<td class="ok">✔</td>
|
286
|
+
</tr>
|
287
|
+
<tr>
|
288
|
+
<td class="tg-yw4l">NOT_REGEXP<br>column != "pattern"</td>
|
289
|
+
<td class="ok">✔</td>
|
290
|
+
<td class="ok">✔<br></td>
|
291
|
+
<td class="tg-3oug">require pcre.so</td>
|
292
|
+
<td class="tg-j6lv">NOT REGEXP_LIKE </td>
|
293
|
+
<td class="tg-j6lv">NOT LIKE</td>
|
294
|
+
<td class="ok">✔</td>
|
295
|
+
</tr>
|
296
|
+
<tr>
|
297
|
+
<td class="tg-yw4l">ILIKE (in Arel6)<br/>column.imatches('%pattern')</td>
|
298
|
+
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
299
|
+
<td class="ok">✔</td>
|
300
|
+
<td class="ok">✔</td>
|
301
|
+
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
302
|
+
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
303
|
+
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
304
|
+
</tr>
|
305
|
+
<tr>
|
306
|
+
<td class="tg-yw4l">TRIM (leading)<br>column.trim("LEADING","M")</td>
|
307
|
+
<td class="ok">✔</td>
|
308
|
+
<td class="tg-j6lv">LTRIM()</td>
|
309
|
+
<td class="tg-j6lv">LTRIM()</td>
|
310
|
+
<td class="ok">✔</td>
|
311
|
+
<td class="ok">✔</td>
|
312
|
+
<td class="tg-j6lv">LTRIM()</td>
|
313
|
+
</tr>
|
314
|
+
<tr>
|
315
|
+
<td class="tg-yw4l">TRIM (trailing)<br>column.trim("TRAILING","g")</td>
|
316
|
+
<td class="ok">✔</td>
|
317
|
+
<td class="tg-j6lv">RTRIM()</td>
|
318
|
+
<td class="tg-j6lv">RTRIM()</td>
|
319
|
+
<td class="ok">✔</td>
|
320
|
+
<td class="ok">✔</td>
|
321
|
+
<td class="tg-j6lv">Rtrim()</td>
|
322
|
+
</tr>
|
323
|
+
<tr>
|
324
|
+
<td class="tg-yw4l">TRIM (both)<br>column.trim("BOTH","e")</td>
|
325
|
+
<td class="ok">✔</td>
|
326
|
+
<td class="tg-j6lv">TRIM()<br></td>
|
327
|
+
<td class="tg-j6lv">TRIM()</td>
|
328
|
+
<td class="ok">✔</td>
|
329
|
+
<td class="tg-j6lv">LTRIM(RTRIM())</td>
|
330
|
+
<td class="tg-j6lv">TRIM()</td>
|
331
|
+
</tr>
|
332
|
+
<tr>
|
333
|
+
<th class="tg-4rp9" rowspan="6"><div>Date functions</div></th>
|
334
|
+
<td class="tg-yw4l">DATEADD<br>column + 2.year<br></td>
|
335
|
+
<td class="tg-j6lv">DATE_ADD()<br></td>
|
336
|
+
<td class="ok">✔</td>
|
337
|
+
<td class="ok">✔</td>
|
338
|
+
<td class="ok">✔</td>
|
339
|
+
<td class="ok">✔</td>
|
340
|
+
<td class="tg-j6lv">+</td>
|
341
|
+
</tr>
|
342
|
+
<tr>
|
343
|
+
<td class="tg-yw4l">DATEDIFF<br>column - date<br></td>
|
344
|
+
<td class="tg-j6lv">DATEDIFF()<br></td>
|
345
|
+
<td class="ok">✔</td>
|
346
|
+
<td class="tg-j6lv">JULIANDAY() - JULIANDAY()</td>
|
347
|
+
<td class="tg-j6lv"> -</td>
|
348
|
+
<td class="ok">✔</td>
|
349
|
+
<td class="tg-j6lv">DAY()</td>
|
350
|
+
</tr>
|
351
|
+
<tr>
|
352
|
+
<td class="tg-yw4l">DAY<br>column.day<br></td>
|
353
|
+
<td class="ok">✔</td>
|
354
|
+
<td class="ok">✔</td>
|
355
|
+
<td class="tg-j6lv">STRFTIME()</td>
|
356
|
+
<td class="ok">✔</td>
|
357
|
+
<td class="ok">✔</td>
|
358
|
+
<td class="ok">✔</td>
|
359
|
+
</tr>
|
360
|
+
<tr>
|
361
|
+
<td class="tg-yw4l">MONTH<br>column.month<br></td>
|
362
|
+
<td class="ok">✔</td>
|
363
|
+
<td class="ok">✔</td>
|
364
|
+
<td class="tg-j6lv">STRFTIME()</td>
|
365
|
+
<td class="ok">✔</td>
|
366
|
+
<td class="ok">✔</td>
|
367
|
+
<td class="ok">✔</td>
|
368
|
+
</tr>
|
369
|
+
<tr>
|
370
|
+
<td class="tg-yw4l">WEEK<br>column.week</td>
|
371
|
+
<td class="ok">✔</td>
|
372
|
+
<td class="ok">✔</td>
|
373
|
+
<td class="tg-j6lv">STRFTIME()</td>
|
374
|
+
<td class="ok">✔</td>
|
375
|
+
<td class="ok">✔</td>
|
376
|
+
<td class="ok">✔</td>
|
377
|
+
</tr>
|
378
|
+
<tr>
|
379
|
+
<td class="tg-yw4l">YEAR<br>column.year</td>
|
380
|
+
<td class="ok">✔</td>
|
381
|
+
<td class="ok">✔</td>
|
382
|
+
<td class="tg-j6lv">STRFTIME()</td>
|
383
|
+
<td class="ok">✔</td>
|
384
|
+
<td class="ok">✔</td>
|
385
|
+
<td class="ok">✔</td>
|
386
|
+
</tr>
|
387
|
+
<tr>
|
388
|
+
<th class="tg-72dn" rowspan="8"><div>Comparators functions</div></th>
|
389
|
+
<td class="tg-yw4l">COALESCE<br>column.coalesce(var)</td>
|
390
|
+
<td class="ok">✔</td>
|
391
|
+
<td class="ok">✔</td>
|
392
|
+
<td class="ok">✔</td>
|
393
|
+
<td class="ok">✔</td>
|
394
|
+
<td class="ok">✔</td>
|
395
|
+
<td class="ok">✔</td>
|
396
|
+
</tr>
|
397
|
+
<tr>
|
398
|
+
<td class="tg-yw4l">ISNULL<br>column.isnull()</td>
|
399
|
+
<td class="tg-j6lv">IFNULL()</td>
|
400
|
+
<td class="ok">✔</td>
|
401
|
+
<td class="ok">✔</td>
|
402
|
+
<td class="tg-j6lv">NVC()</td>
|
403
|
+
<td class="ok">✔</td>
|
404
|
+
<td class="ok">✔</td>
|
405
|
+
</tr>
|
406
|
+
<tr>
|
407
|
+
<td class="tg-yw4l">==<br>column == integer</td>
|
408
|
+
<td class="ok">✔</td>
|
409
|
+
<td class="ok">✔</td>
|
410
|
+
<td class="ok">✔</td>
|
411
|
+
<td class="ok">✔</td>
|
412
|
+
<td class="ok">✔</td>
|
413
|
+
<td class="ok">✔</td>
|
414
|
+
</tr>
|
415
|
+
<tr>
|
416
|
+
<td class="tg-yw4l">!=<br>column != integer</td>
|
417
|
+
<td class="ok">✔</td>
|
418
|
+
<td class="ok">✔</td>
|
419
|
+
<td class="ok">✔</td>
|
420
|
+
<td class="ok">✔</td>
|
421
|
+
<td class="ok">✔</td>
|
422
|
+
<td class="ok">✔</td>
|
423
|
+
</tr>
|
424
|
+
<tr>
|
425
|
+
<td class="tg-yw4l">><br>column > integer</td>
|
426
|
+
<td class="ok">✔</td>
|
427
|
+
<td class="ok">✔</td>
|
428
|
+
<td class="ok">✔</td>
|
429
|
+
<td class="ok">✔</td>
|
430
|
+
<td class="ok">✔</td>
|
431
|
+
<td class="ok">✔</td>
|
432
|
+
</tr>
|
433
|
+
<tr>
|
434
|
+
<td class="tg-yw4l">>=<br>column >= integer</td>
|
435
|
+
<td class="ok">✔</td>
|
436
|
+
<td class="ok">✔</td>
|
437
|
+
<td class="ok">✔</td>
|
438
|
+
<td class="ok">✔</td>
|
439
|
+
<td class="ok">✔</td>
|
440
|
+
<td class="ok">✔</td>
|
441
|
+
</tr>
|
442
|
+
<tr>
|
443
|
+
<td class="tg-yw4l">< <br>column < integer</td>
|
444
|
+
<td class="ok">✔</td>
|
445
|
+
<td class="ok">✔</td>
|
446
|
+
<td class="ok">✔</td>
|
447
|
+
<td class="ok">✔</td>
|
448
|
+
<td class="ok">✔</td>
|
449
|
+
<td class="ok">✔</td>
|
450
|
+
</tr>
|
451
|
+
<tr>
|
452
|
+
<td class="tg-yw4l"><=<br>column <= integer</td>
|
453
|
+
<td class="ok">✔</td>
|
454
|
+
<td class="ok">✔</td>
|
455
|
+
<td class="ok">✔</td>
|
456
|
+
<td class="ok">✔</td>
|
457
|
+
<td class="ok">✔</td>
|
458
|
+
<td class="ok">✔</td>
|
459
|
+
</tr>
|
460
|
+
<tr>
|
461
|
+
<th class="tg-9hbo" rowspan="2"><div>Boolean <br/> functions</div></th>
|
462
|
+
<td class="tg-yw4l">OR ( ⋁ )<br>column.eq(var).⋁(column.eq(var))</td>
|
463
|
+
<td class="ok">✔</td>
|
464
|
+
<td class="ok">✔</td>
|
465
|
+
<td class="ok">✔</td>
|
466
|
+
<td class="ok">✔</td>
|
467
|
+
<td class="ok">✔</td>
|
468
|
+
<td class="ok">✔</td>
|
469
|
+
</tr>
|
470
|
+
<tr>
|
471
|
+
<td class="tg-yw4l">AND ( ⋀ )<br>column.eq(var).⋀(column.eq(var))</td>
|
472
|
+
<td class="ok">✔</td>
|
473
|
+
<td class="ok">✔</td>
|
474
|
+
<td class="ok">✔</td>
|
475
|
+
<td class="ok">✔</td>
|
476
|
+
<td class="ok">✔</td>
|
477
|
+
<td class="ok">✔</td>
|
478
|
+
</tr>
|
479
|
+
<tr>
|
480
|
+
<th class="bulk_insert" rowspan="1"><div>Bulk <br/> Insert</div></th>
|
481
|
+
<td class="tg-yw4l">insert_manager.bulk_insert(@cols, @data)</td>
|
482
|
+
<td class="ok">✔</td>
|
483
|
+
<td class="ok">✔</td>
|
484
|
+
<td class="ok">✔</td>
|
485
|
+
<td class="ok">✔</td>
|
486
|
+
<td class="ok">✔</td>
|
487
|
+
<td class="ok">✔</td>
|
488
|
+
</tr>
|
489
|
+
</tbody>
|
490
|
+
</table>
|
data/SQL_Challenges.md
CHANGED
data/TODO
CHANGED
data/functions.html
CHANGED
@@ -3,12 +3,10 @@
|
|
3
3
|
<head>
|
4
4
|
<meta charset="utf-8" />
|
5
5
|
<title>Arel Extensions Features</title>
|
6
|
-
|
6
|
+
<style type="text/css">
|
7
7
|
.tg {border-collapse:collapse;border-spacing:0;}
|
8
|
-
.tg
|
9
|
-
.tg
|
10
|
-
.tg th{font-family:Arial, sans-serif;font-size:14px;padding:10px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;}
|
11
|
-
.tg .tg-baqh{text-align:center;vertical-align:top}
|
8
|
+
.tg td{font-family:Arial, sans-serif;font-size:14px;padding:5px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;}
|
9
|
+
.tg th{font-family:Arial, sans-serif;font-size:14px;padding:5px 5px;border-style:solid;border-width:1px;overflow:hidden;word-break:normal;}
|
12
10
|
.tg .tg-3oug{background-color:#fd6864;text-align:center;vertical-align:top}
|
13
11
|
.tg .tg-by3v{font-weight:bold;font-size:14px;text-align:center}
|
14
12
|
.tg .tg-jogk{font-style:italic;vertical-align:top}
|
@@ -21,343 +19,347 @@
|
|
21
19
|
.tg .tg-4rp9{font-weight:bold;background-color:#ffffc7;vertical-align:top}
|
22
20
|
.tg .tg-72dn{font-weight:bold;background-color:#f7f6cd;vertical-align:top}
|
23
21
|
.tg .tg-9hbo{font-weight:bold;vertical-align:top}
|
24
|
-
|
22
|
+
.arel-functions th { font-weight:bold; }
|
23
|
+
.arel-functions th[rowspan] { vertical-align: middle; width:3em;}
|
24
|
+
.arel-functions th[rowspan] > div { transform:rotate(-90deg); transform-origin: center center; white-space: nowrap; }
|
25
|
+
.arel-functions td.ok { color:green; text-align:center; }
|
26
|
+
</style>
|
25
27
|
</head>
|
26
28
|
<body>
|
27
|
-
<table class="tg">
|
29
|
+
<table class="tg arel-functions">
|
28
30
|
<thead>
|
29
31
|
<tr>
|
30
|
-
<th
|
32
|
+
<th></th>
|
31
33
|
<th class="tg-by3v">Function / Example<br/>ToSql</th>
|
32
|
-
<th class="tg-pjz5">MySQL/MariaDB</th>
|
34
|
+
<th class="tg-pjz5">MySQL / MariaDB</th>
|
33
35
|
<th class="tg-pjz5">PostgreSQL</th>
|
34
36
|
<th class="tg-pjz5">SQLite</th>
|
35
37
|
<th class="tg-pjz5">Oracle</th>
|
36
38
|
<th class="tg-pjz5">MS SQL</th>
|
37
|
-
<th class="tg-pjz5">DB2</th>
|
39
|
+
<th class="tg-pjz5">DB2<br/>(not tested on real DB)</th>
|
38
40
|
</tr>
|
39
41
|
</thead>
|
40
42
|
<tbody>
|
41
43
|
<tr>
|
42
|
-
<th class="tg-82sq" rowspan="6"><
|
44
|
+
<th class="tg-82sq" rowspan="6"><div>Number functions</div></th>
|
43
45
|
<td class="tg-yw4l">ABS<br>column.abs<br></td>
|
44
|
-
<td class="
|
45
|
-
<td class="
|
46
|
-
<td class="
|
47
|
-
<td class="
|
48
|
-
<td class="
|
49
|
-
<td class="
|
46
|
+
<td class="ok">✔</td>
|
47
|
+
<td class="ok">✔</td>
|
48
|
+
<td class="ok">✔</td>
|
49
|
+
<td class="ok">✔</td>
|
50
|
+
<td class="ok">✔</td>
|
51
|
+
<td class="ok">✔</td>
|
50
52
|
</tr>
|
51
53
|
<tr>
|
52
54
|
<td class="tg-yw4l">CEIL<br>column.ceil</td>
|
53
|
-
<td class="
|
54
|
-
<td class="
|
55
|
-
<td class="tg-
|
56
|
-
<td class="
|
55
|
+
<td class="ok">✔</td>
|
56
|
+
<td class="ok">✔</td>
|
57
|
+
<td class="tg-j6lv">CASE + ROUND</td>
|
58
|
+
<td class="ok">✔</td>
|
57
59
|
<td class="tg-j6lv">CEILING()</td>
|
58
60
|
<td class="tg-j6lv">CEILING()</td>
|
59
61
|
</tr>
|
60
62
|
<tr>
|
61
63
|
<td class="tg-yw4l">FLOOR<br>column.floor</td>
|
62
|
-
<td class="
|
63
|
-
<td class="
|
64
|
-
<td class="tg-
|
65
|
-
<td class="
|
66
|
-
<td class="
|
67
|
-
<td class="
|
64
|
+
<td class="ok">✔</td>
|
65
|
+
<td class="ok">✔</td>
|
66
|
+
<td class="tg-j6lv">CASE + ROUND</td>
|
67
|
+
<td class="ok">✔</td>
|
68
|
+
<td class="ok">✔</td>
|
69
|
+
<td class="ok">✔</td>
|
68
70
|
</tr>
|
69
71
|
<tr>
|
70
72
|
<td class="tg-yw4l">RAND<br>Arel.rand</td>
|
71
|
-
<td class="
|
72
|
-
<td class="
|
73
|
+
<td class="ok">✔</td>
|
74
|
+
<td class="ok">✔</td>
|
73
75
|
<td class="tg-j6lv">RANDOM()</td>
|
74
76
|
<td class="tg-j6lv">dbms_random.value()</td>
|
75
|
-
<td class="
|
76
|
-
<td class="
|
77
|
+
<td class="ok">✔</td>
|
78
|
+
<td class="ok">✔</td>
|
77
79
|
</tr>
|
78
80
|
<tr>
|
79
81
|
<td class="tg-yw4l">ROUND<br>column.round(precision = 0)</td>
|
80
|
-
<td class="
|
81
|
-
<td class="
|
82
|
-
<td class="
|
83
|
-
<td class="
|
84
|
-
<td class="
|
85
|
-
<td class="
|
82
|
+
<td class="ok">✔</td>
|
83
|
+
<td class="ok">✔</td>
|
84
|
+
<td class="ok">✔</td>
|
85
|
+
<td class="ok">✔</td>
|
86
|
+
<td class="ok">✔</td>
|
87
|
+
<td class="ok">✔</td>
|
86
88
|
</tr>
|
87
89
|
<tr>
|
88
90
|
<td class="tg-yw4l">SUM / AVG / MIN / MAX + x<br>column.sum + 42</td>
|
89
|
-
<td class="
|
90
|
-
<td class="
|
91
|
-
<td class="
|
92
|
-
<td class="
|
93
|
-
<td class="
|
94
|
-
<td class="
|
91
|
+
<td class="ok">✔</td>
|
92
|
+
<td class="ok">✔</td>
|
93
|
+
<td class="ok">✔</td>
|
94
|
+
<td class="ok">✔</td>
|
95
|
+
<td class="ok">✔</td>
|
96
|
+
<td class="ok">✔</td>
|
95
97
|
</tr>
|
96
98
|
<tr>
|
97
|
-
<th class="tg-ffjm" rowspan="12"><
|
99
|
+
<th class="tg-ffjm" rowspan="12"><div>String functions</div></th>
|
98
100
|
<td class="tg-yw4l">CONCAT<br>column + "string"</td>
|
99
|
-
<td class="
|
100
|
-
<td class="
|
101
|
+
<td class="ok">✔</td>
|
102
|
+
<td class="ok">✔</td>
|
101
103
|
<td class="tg-j6lv"> ||</td>
|
102
|
-
<td class="
|
104
|
+
<td class="ok">✔</td>
|
103
105
|
<td class="tg-j6lv">+</td>
|
104
|
-
<td class="
|
106
|
+
<td class="ok">✔</td>
|
105
107
|
</tr>
|
106
108
|
<tr>
|
107
109
|
<td class="tg-yw4l">LENGTH<br>column.length</td>
|
108
|
-
<td class="
|
109
|
-
<td class="
|
110
|
-
<td class="
|
111
|
-
<td class="
|
110
|
+
<td class="ok">✔</td>
|
111
|
+
<td class="ok">✔</td>
|
112
|
+
<td class="ok">✔</td>
|
113
|
+
<td class="ok">✔</td>
|
112
114
|
<td class="tg-j6lv">LEN()</td>
|
113
|
-
<td class="
|
115
|
+
<td class="ok">✔</td>
|
114
116
|
</tr>
|
115
117
|
<tr>
|
116
118
|
<td class="tg-yw4l">LOCATE<br>column.locate("string")</td>
|
117
|
-
<td class="
|
118
|
-
<td class="
|
119
|
+
<td class="ok">✔</td>
|
120
|
+
<td class="ok">✔</td>
|
119
121
|
<td class="tg-j6lv">INSTR()</td>
|
120
|
-
<td class="
|
122
|
+
<td class="ok">✔</td>
|
121
123
|
<td class="tg-j6lv">CHARINDEX()</td>
|
122
|
-
<td class="
|
124
|
+
<td class="ok">✔</td>
|
123
125
|
</tr>
|
124
126
|
<tr>
|
125
127
|
<td class="tg-yw4l">FIND_IN_SET<br>column & ("l")</td>
|
126
|
-
<td class="
|
127
|
-
<td class="
|
128
|
+
<td class="ok">✔</td>
|
129
|
+
<td class="ok">✔</td>
|
128
130
|
<td class="tg-orpl">db.create_function( "find_in_set", 1 ) <br>do |func, value1, value2|,<br>func.result =value1.index(value2)<br>end <br></td>
|
129
|
-
<td class="
|
130
|
-
<td class="
|
131
|
-
<td class="
|
131
|
+
<td class="ok">✔</td>
|
132
|
+
<td class="ok">✔</td>
|
133
|
+
<td class="ok">✔</td>
|
132
134
|
</tr>
|
133
135
|
<tr>
|
134
136
|
<td class="tg-yw4l">SOUNDEX<br>column.soundex</td>
|
135
|
-
<td class="
|
137
|
+
<td class="ok">✔</td>
|
136
138
|
<td class="tg-3oug">require fuzzystrmatch</td>
|
137
|
-
<td class="
|
138
|
-
<td class="
|
139
|
-
<td class="
|
140
|
-
<td class="
|
139
|
+
<td class="ok">✔</td>
|
140
|
+
<td class="ok">✔</td>
|
141
|
+
<td class="ok">✔</td>
|
142
|
+
<td class="ok">✔</td>
|
141
143
|
</tr>
|
142
144
|
<tr>
|
143
145
|
<td class="tg-yw4l">REPLACE<br>column.replace("s","X")</td>
|
144
|
-
<td class="
|
145
|
-
<td class="
|
146
|
-
<td class="
|
147
|
-
<td class="
|
148
|
-
<td class="
|
149
|
-
<td class="
|
146
|
+
<td class="ok">✔</td>
|
147
|
+
<td class="ok">✔</td>
|
148
|
+
<td class="ok">✔</td>
|
149
|
+
<td class="ok">✔</td>
|
150
|
+
<td class="ok">✔</td>
|
151
|
+
<td class="ok">✔</td>
|
150
152
|
</tr>
|
151
153
|
<tr>
|
152
154
|
<td class="tg-yw4l">REGEXP<br>column =~ "pattern"<br></td>
|
153
|
-
<td class="
|
154
|
-
<td class="
|
155
|
+
<td class="ok">✔</td>
|
156
|
+
<td class="ok">✔</td>
|
155
157
|
<td class="tg-3oug">require pcre.so</td>
|
156
158
|
<td class="tg-j6lv">REGEXP_LIKE</td>
|
157
159
|
<td class="tg-j6lv">LIKE</td>
|
158
|
-
<td class="
|
160
|
+
<td class="ok">✔</td>
|
159
161
|
</tr>
|
160
162
|
<tr>
|
161
163
|
<td class="tg-yw4l">NOT_REGEXP<br>column != "pattern"</td>
|
162
|
-
<td class="
|
163
|
-
<td class="
|
164
|
+
<td class="ok">✔</td>
|
165
|
+
<td class="ok">✔<br></td>
|
164
166
|
<td class="tg-3oug">require pcre.so</td>
|
165
167
|
<td class="tg-j6lv">NOT REGEXP_LIKE </td>
|
166
168
|
<td class="tg-j6lv">NOT LIKE</td>
|
167
|
-
<td class="
|
169
|
+
<td class="ok">✔</td>
|
168
170
|
</tr>
|
169
171
|
<tr>
|
170
172
|
<td class="tg-yw4l">ILIKE (in Arel6)<br/>column.imatches('%pattern')</td>
|
171
173
|
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
172
|
-
<td class="
|
173
|
-
<td class="
|
174
|
+
<td class="ok">✔</td>
|
175
|
+
<td class="ok">✔</td>
|
174
176
|
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
175
177
|
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
176
178
|
<td class="tg-j6lv">LOWER() LIKE LOWER()</td>
|
177
179
|
</tr>
|
178
180
|
<tr>
|
179
181
|
<td class="tg-yw4l">TRIM (leading)<br>column.trim("LEADING","M")</td>
|
180
|
-
<td class="
|
182
|
+
<td class="ok">✔</td>
|
181
183
|
<td class="tg-j6lv">LTRIM()</td>
|
182
184
|
<td class="tg-j6lv">LTRIM()</td>
|
183
|
-
<td class="
|
184
|
-
<td class="
|
185
|
+
<td class="ok">✔</td>
|
186
|
+
<td class="ok">✔</td>
|
185
187
|
<td class="tg-j6lv">LTRIM()</td>
|
186
188
|
</tr>
|
187
189
|
<tr>
|
188
190
|
<td class="tg-yw4l">TRIM (trailing)<br>column.trim("TRAILING","g")</td>
|
189
|
-
<td class="
|
191
|
+
<td class="ok">✔</td>
|
190
192
|
<td class="tg-j6lv">RTRIM()</td>
|
191
193
|
<td class="tg-j6lv">RTRIM()</td>
|
192
|
-
<td class="
|
193
|
-
<td class="
|
194
|
+
<td class="ok">✔</td>
|
195
|
+
<td class="ok">✔</td>
|
194
196
|
<td class="tg-j6lv">Rtrim()</td>
|
195
197
|
</tr>
|
196
198
|
<tr>
|
197
199
|
<td class="tg-yw4l">TRIM (both)<br>column.trim("BOTH","e")</td>
|
198
|
-
<td class="
|
200
|
+
<td class="ok">✔</td>
|
199
201
|
<td class="tg-j6lv">TRIM()<br></td>
|
200
202
|
<td class="tg-j6lv">TRIM()</td>
|
201
|
-
<td class="
|
202
|
-
<td class="tg-
|
203
|
+
<td class="ok">✔</td>
|
204
|
+
<td class="tg-j6lv">LTRIM(RTRIM())</td>
|
203
205
|
<td class="tg-j6lv">TRIM()</td>
|
204
206
|
</tr>
|
205
207
|
<tr>
|
206
|
-
<th class="tg-4rp9" rowspan="6"><
|
208
|
+
<th class="tg-4rp9" rowspan="6"><div>Date functions</div></th>
|
207
209
|
<td class="tg-yw4l">DATEADD<br>column + 2.year<br></td>
|
208
210
|
<td class="tg-j6lv">DATE_ADD()<br></td>
|
209
|
-
<td class="
|
210
|
-
<td class="
|
211
|
-
<td class="
|
212
|
-
<td class="
|
211
|
+
<td class="ok">✔</td>
|
212
|
+
<td class="ok">✔</td>
|
213
|
+
<td class="ok">✔</td>
|
214
|
+
<td class="ok">✔</td>
|
213
215
|
<td class="tg-j6lv">+</td>
|
214
216
|
</tr>
|
215
217
|
<tr>
|
216
218
|
<td class="tg-yw4l">DATEDIFF<br>column - date<br></td>
|
217
219
|
<td class="tg-j6lv">DATEDIFF()<br></td>
|
218
|
-
<td class="
|
220
|
+
<td class="ok">✔</td>
|
219
221
|
<td class="tg-j6lv">JULIANDAY() - JULIANDAY()</td>
|
220
222
|
<td class="tg-j6lv"> -</td>
|
221
|
-
<td class="
|
223
|
+
<td class="ok">✔</td>
|
222
224
|
<td class="tg-j6lv">DAY()</td>
|
223
225
|
</tr>
|
224
226
|
<tr>
|
225
227
|
<td class="tg-yw4l">DAY<br>column.day<br></td>
|
226
|
-
<td class="
|
227
|
-
<td class="
|
228
|
+
<td class="ok">✔</td>
|
229
|
+
<td class="ok">✔</td>
|
228
230
|
<td class="tg-j6lv">STRFTIME()</td>
|
229
|
-
<td class="
|
230
|
-
<td class="
|
231
|
-
<td class="
|
231
|
+
<td class="ok">✔</td>
|
232
|
+
<td class="ok">✔</td>
|
233
|
+
<td class="ok">✔</td>
|
232
234
|
</tr>
|
233
235
|
<tr>
|
234
236
|
<td class="tg-yw4l">MONTH<br>column.month<br></td>
|
235
|
-
<td class="
|
236
|
-
<td class="
|
237
|
+
<td class="ok">✔</td>
|
238
|
+
<td class="ok">✔</td>
|
237
239
|
<td class="tg-j6lv">STRFTIME()</td>
|
238
|
-
<td class="
|
239
|
-
<td class="
|
240
|
-
<td class="
|
240
|
+
<td class="ok">✔</td>
|
241
|
+
<td class="ok">✔</td>
|
242
|
+
<td class="ok">✔</td>
|
241
243
|
</tr>
|
242
244
|
<tr>
|
243
245
|
<td class="tg-yw4l">WEEK<br>column.week</td>
|
244
|
-
<td class="
|
245
|
-
<td class="
|
246
|
+
<td class="ok">✔</td>
|
247
|
+
<td class="ok">✔</td>
|
246
248
|
<td class="tg-j6lv">STRFTIME()</td>
|
247
|
-
<td class="
|
248
|
-
<td class="
|
249
|
-
<td class="
|
249
|
+
<td class="ok">✔</td>
|
250
|
+
<td class="ok">✔</td>
|
251
|
+
<td class="ok">✔</td>
|
250
252
|
</tr>
|
251
253
|
<tr>
|
252
254
|
<td class="tg-yw4l">YEAR<br>column.year</td>
|
253
|
-
<td class="
|
254
|
-
<td class="
|
255
|
+
<td class="ok">✔</td>
|
256
|
+
<td class="ok">✔</td>
|
255
257
|
<td class="tg-j6lv">STRFTIME()</td>
|
256
|
-
<td class="
|
257
|
-
<td class="
|
258
|
-
<td class="
|
258
|
+
<td class="ok">✔</td>
|
259
|
+
<td class="ok">✔</td>
|
260
|
+
<td class="ok">✔</td>
|
259
261
|
</tr>
|
260
262
|
<tr>
|
261
|
-
<th class="tg-72dn" rowspan="8"><
|
263
|
+
<th class="tg-72dn" rowspan="8"><div>Comparators functions</div></th>
|
262
264
|
<td class="tg-yw4l">COALESCE<br>column.coalesce(var)</td>
|
263
|
-
<td class="
|
264
|
-
<td class="
|
265
|
-
<td class="
|
266
|
-
<td class="
|
267
|
-
<td class="
|
268
|
-
<td class="
|
265
|
+
<td class="ok">✔</td>
|
266
|
+
<td class="ok">✔</td>
|
267
|
+
<td class="ok">✔</td>
|
268
|
+
<td class="ok">✔</td>
|
269
|
+
<td class="ok">✔</td>
|
270
|
+
<td class="ok">✔</td>
|
269
271
|
</tr>
|
270
272
|
<tr>
|
271
273
|
<td class="tg-yw4l">ISNULL<br>column.isnull()</td>
|
272
274
|
<td class="tg-j6lv">IFNULL()</td>
|
273
|
-
<td class="
|
274
|
-
<td class="
|
275
|
+
<td class="ok">✔</td>
|
276
|
+
<td class="ok">✔</td>
|
275
277
|
<td class="tg-j6lv">NVC()</td>
|
276
|
-
<td class="
|
277
|
-
<td class="
|
278
|
+
<td class="ok">✔</td>
|
279
|
+
<td class="ok">✔</td>
|
278
280
|
</tr>
|
279
281
|
<tr>
|
280
282
|
<td class="tg-yw4l">==<br>column == integer</td>
|
281
|
-
<td class="
|
282
|
-
<td class="
|
283
|
-
<td class="
|
284
|
-
<td class="
|
285
|
-
<td class="
|
286
|
-
<td class="
|
283
|
+
<td class="ok">✔</td>
|
284
|
+
<td class="ok">✔</td>
|
285
|
+
<td class="ok">✔</td>
|
286
|
+
<td class="ok">✔</td>
|
287
|
+
<td class="ok">✔</td>
|
288
|
+
<td class="ok">✔</td>
|
287
289
|
</tr>
|
288
290
|
<tr>
|
289
291
|
<td class="tg-yw4l">!=<br>column != integer</td>
|
290
|
-
<td class="
|
291
|
-
<td class="
|
292
|
-
<td class="
|
293
|
-
<td class="
|
294
|
-
<td class="
|
295
|
-
<td class="
|
292
|
+
<td class="ok">✔</td>
|
293
|
+
<td class="ok">✔</td>
|
294
|
+
<td class="ok">✔</td>
|
295
|
+
<td class="ok">✔</td>
|
296
|
+
<td class="ok">✔</td>
|
297
|
+
<td class="ok">✔</td>
|
296
298
|
</tr>
|
297
299
|
<tr>
|
298
300
|
<td class="tg-yw4l">><br>column > integer</td>
|
299
|
-
<td class="
|
300
|
-
<td class="
|
301
|
-
<td class="
|
302
|
-
<td class="
|
303
|
-
<td class="
|
304
|
-
<td class="
|
301
|
+
<td class="ok">✔</td>
|
302
|
+
<td class="ok">✔</td>
|
303
|
+
<td class="ok">✔</td>
|
304
|
+
<td class="ok">✔</td>
|
305
|
+
<td class="ok">✔</td>
|
306
|
+
<td class="ok">✔</td>
|
305
307
|
</tr>
|
306
308
|
<tr>
|
307
309
|
<td class="tg-yw4l">>=<br>column >= integer</td>
|
308
|
-
<td class="
|
309
|
-
<td class="
|
310
|
-
<td class="
|
311
|
-
<td class="
|
312
|
-
<td class="
|
313
|
-
<td class="
|
310
|
+
<td class="ok">✔</td>
|
311
|
+
<td class="ok">✔</td>
|
312
|
+
<td class="ok">✔</td>
|
313
|
+
<td class="ok">✔</td>
|
314
|
+
<td class="ok">✔</td>
|
315
|
+
<td class="ok">✔</td>
|
314
316
|
</tr>
|
315
317
|
<tr>
|
316
318
|
<td class="tg-yw4l">< <br>column < integer</td>
|
317
|
-
<td class="
|
318
|
-
<td class="
|
319
|
-
<td class="
|
320
|
-
<td class="
|
321
|
-
<td class="
|
322
|
-
<td class="
|
319
|
+
<td class="ok">✔</td>
|
320
|
+
<td class="ok">✔</td>
|
321
|
+
<td class="ok">✔</td>
|
322
|
+
<td class="ok">✔</td>
|
323
|
+
<td class="ok">✔</td>
|
324
|
+
<td class="ok">✔</td>
|
323
325
|
</tr>
|
324
326
|
<tr>
|
325
327
|
<td class="tg-yw4l"><=<br>column <= integer</td>
|
326
|
-
<td class="
|
327
|
-
<td class="
|
328
|
-
<td class="
|
329
|
-
<td class="
|
330
|
-
<td class="
|
331
|
-
<td class="
|
328
|
+
<td class="ok">✔</td>
|
329
|
+
<td class="ok">✔</td>
|
330
|
+
<td class="ok">✔</td>
|
331
|
+
<td class="ok">✔</td>
|
332
|
+
<td class="ok">✔</td>
|
333
|
+
<td class="ok">✔</td>
|
332
334
|
</tr>
|
333
335
|
<tr>
|
334
|
-
<th class="tg-9hbo" rowspan="2">Boolean <br
|
336
|
+
<th class="tg-9hbo" rowspan="2"><div>Boolean <br/> functions</div></th>
|
335
337
|
<td class="tg-yw4l">OR ( ⋁ )<br>column.eq(var).⋁(column.eq(var))</td>
|
336
|
-
<td class="
|
337
|
-
<td class="
|
338
|
-
<td class="
|
339
|
-
<td class="
|
340
|
-
<td class="
|
341
|
-
<td class="
|
338
|
+
<td class="ok">✔</td>
|
339
|
+
<td class="ok">✔</td>
|
340
|
+
<td class="ok">✔</td>
|
341
|
+
<td class="ok">✔</td>
|
342
|
+
<td class="ok">✔</td>
|
343
|
+
<td class="ok">✔</td>
|
342
344
|
</tr>
|
343
345
|
<tr>
|
344
346
|
<td class="tg-yw4l">AND ( ⋀ )<br>column.eq(var).⋀(column.eq(var))</td>
|
345
|
-
<td class="
|
346
|
-
<td class="
|
347
|
-
<td class="
|
348
|
-
<td class="
|
349
|
-
<td class="
|
350
|
-
<td class="
|
347
|
+
<td class="ok">✔</td>
|
348
|
+
<td class="ok">✔</td>
|
349
|
+
<td class="ok">✔</td>
|
350
|
+
<td class="ok">✔</td>
|
351
|
+
<td class="ok">✔</td>
|
352
|
+
<td class="ok">✔</td>
|
351
353
|
</tr>
|
352
354
|
<tr>
|
353
|
-
<th class="bulk_insert">Bulk Insert</th>
|
355
|
+
<th class="bulk_insert" rowspan="1"><div>Bulk <br/> Insert</div></th>
|
354
356
|
<td class="tg-yw4l">insert_manager.bulk_insert(@cols, @data)</td>
|
355
|
-
<td class="
|
356
|
-
<td class="
|
357
|
-
<td class="
|
358
|
-
<td class="
|
359
|
-
<td class="
|
360
|
-
<td class="
|
357
|
+
<td class="ok">✔</td>
|
358
|
+
<td class="ok">✔</td>
|
359
|
+
<td class="ok">✔</td>
|
360
|
+
<td class="ok">✔</td>
|
361
|
+
<td class="ok">✔</td>
|
362
|
+
<td class="ok">✔</td>
|
361
363
|
</tr>
|
362
364
|
</tbody>
|
363
365
|
</table>
|