Harshavardhana
7e1661f4fa
Performance improvements to SELECT API on certain query operations ( #6752 )
...
This improves the performance of certain queries dramatically,
such as 'count(*)' etc.
Without this PR
```
~ time mc select --query "select count(*) from S3Object" myminio/sjm-airlines/star2000.csv.gz
2173762
real 0m42.464s
user 0m0.071s
sys 0m0.010s
```
With this PR
```
~ time mc select --query "select count(*) from S3Object" myminio/sjm-airlines/star2000.csv.gz
2173762
real 0m17.603s
user 0m0.093s
sys 0m0.008s
```
Almost a 250% improvement in performance. This PR avoids a lot of type
conversions and instead relies on raw sequences of data and interprets
them lazily.
```
benchcmp old new
benchmark old ns/op new ns/op delta
BenchmarkSQLAggregate_100K-4 551213 259782 -52.87%
BenchmarkSQLAggregate_1M-4 6981901985 2432413729 -65.16%
BenchmarkSQLAggregate_2M-4 13511978488 4536903552 -66.42%
BenchmarkSQLAggregate_10M-4 68427084908 23266283336 -66.00%
benchmark old allocs new allocs delta
BenchmarkSQLAggregate_100K-4 2366 485 -79.50%
BenchmarkSQLAggregate_1M-4 47455492 21462860 -54.77%
BenchmarkSQLAggregate_2M-4 95163637 43110771 -54.70%
BenchmarkSQLAggregate_10M-4 476959550 216906510 -54.52%
benchmark old bytes new bytes delta
BenchmarkSQLAggregate_100K-4 1233079 1086024 -11.93%
BenchmarkSQLAggregate_1M-4 2607984120 557038536 -78.64%
BenchmarkSQLAggregate_2M-4 5254103616 1128149168 -78.53%
BenchmarkSQLAggregate_10M-4 26443524872 5722715992 -78.36%
```
2018-11-14 15:55:10 -08:00
..
2018-10-19 10:50:52 -07:00
2018-11-14 10:23:44 -08:00
2018-10-31 15:31:42 -07:00
2018-11-02 18:40:08 -07:00
2018-10-04 17:44:06 -07:00
2018-09-05 16:47:14 -07:00
2018-11-12 11:07:43 -08:00
2018-11-14 10:23:44 -08:00
2018-11-12 11:07:43 -08:00
2018-11-12 11:07:43 -08:00
2018-10-17 17:25:16 -07:00
2018-08-17 18:51:34 -07:00
2018-09-21 16:04:11 -07:00
2018-09-21 16:04:11 -07:00
2018-10-22 12:12:22 -07:00
2018-11-12 11:07:43 -08:00
2018-11-14 15:55:10 -08:00
2017-03-18 11:28:41 -07:00
2018-09-28 09:06:17 +05:30
2018-10-18 07:31:46 -07:00
2018-10-18 07:31:46 -07:00
2018-03-02 15:23:04 -08:00
2018-11-12 11:07:43 -08:00
2018-11-04 19:24:16 -08:00
2018-08-15 03:30:19 -07:00
2018-11-12 11:07:43 -08:00
2018-11-13 15:53:06 -08:00
2018-09-10 09:42:43 -07:00
2018-08-06 15:14:08 -07:00
2018-09-13 21:42:50 -07:00
2018-06-06 18:10:51 -07:00
2018-08-06 10:26:40 -07:00
2018-09-20 19:22:09 -07:00
2018-11-12 11:07:43 -08:00
2018-11-12 11:07:43 -08:00
2018-11-12 11:07:43 -08:00
2018-09-20 19:22:09 -07:00
2018-11-12 11:07:43 -08:00
2018-06-18 12:04:46 -07:00
2018-03-07 22:16:28 +05:30
2018-10-28 06:21:00 +05:30
2018-11-02 18:40:08 -07:00
2018-10-12 11:32:18 -07:00
2018-11-07 10:23:13 -08:00
2018-11-07 10:23:13 -08:00
2018-08-15 10:11:47 +05:30
2018-10-09 14:00:01 -07:00
2018-11-07 10:23:13 -08:00
2018-11-07 10:23:13 -08:00
2018-10-09 14:00:01 -07:00
2018-09-27 15:24:07 +05:30
2018-09-27 15:24:07 +05:30
2018-04-21 19:23:54 -07:00
2017-01-16 17:05:00 -08:00
2018-09-28 09:06:17 +05:30
2018-07-03 16:54:10 -07:00
2018-07-18 11:22:29 -07:00
2018-09-28 09:06:17 +05:30
2018-10-17 10:57:12 -07:00
2018-06-05 18:53:44 -07:00
2018-09-20 19:22:09 -07:00
2018-09-28 09:06:17 +05:30
2017-08-31 14:43:59 -07:00
2017-09-14 10:23:23 -07:00
2018-11-14 10:23:44 -08:00
2018-11-12 11:07:43 -08:00
2018-05-08 19:04:36 -07:00
2018-11-14 10:23:44 -08:00
2018-08-15 16:35:21 -07:00
2018-09-17 18:28:34 -07:00
2018-08-23 23:35:37 -07:00
2018-08-23 23:35:37 -07:00
2018-08-23 23:35:37 -07:00
2018-09-13 21:42:50 -07:00
2018-08-23 23:35:37 -07:00
2018-08-23 23:35:37 -07:00
2018-08-23 23:35:37 -07:00
2018-10-17 15:52:18 -07:00
2018-08-23 23:35:37 -07:00
2017-01-16 17:05:00 -08:00
2017-01-16 17:05:00 -08:00
2016-10-29 12:44:44 -07:00
2018-04-15 19:26:04 +05:30
2018-04-15 19:26:04 +05:30
2018-04-05 15:04:40 -07:00
2018-07-20 23:37:43 +05:30
2018-07-18 20:17:35 -07:00
2018-07-18 20:17:35 -07:00
2018-11-02 11:31:55 -07:00
2018-09-10 09:42:43 -07:00
2018-06-26 06:54:00 +05:30
2018-08-16 12:57:49 -07:00
2018-09-10 09:42:43 -07:00
2018-10-02 11:48:17 +05:30
2018-09-10 09:42:43 -07:00
2018-10-22 07:36:30 -07:00
2017-08-12 19:25:43 -07:00
2018-08-06 10:26:40 -07:00
2018-11-09 10:34:59 -08:00
2018-10-17 21:50:58 +05:30
2017-12-05 17:58:09 -08:00
2018-11-02 18:40:08 -07:00
2018-02-09 15:19:30 -08:00
2018-08-15 10:11:47 +05:30
2018-10-16 13:19:12 -07:00
2018-11-09 14:03:37 -08:00
2018-10-26 18:03:17 -07:00
2018-11-12 11:07:43 -08:00
2018-10-09 14:00:01 -07:00
2018-11-02 11:32:18 -07:00
2018-11-07 20:10:03 +05:30
2018-04-15 19:26:04 +05:30
2018-03-12 11:46:53 +05:30
2018-09-11 13:44:10 -07:00
2018-06-07 10:41:13 -07:00
2018-08-30 14:17:58 +05:30
2018-09-20 19:22:09 -07:00
2018-09-20 19:22:09 -07:00
2018-10-29 11:08:59 -07:00
2018-10-09 14:00:01 -07:00
2018-11-07 20:10:03 +05:30
2017-03-18 11:28:41 -07:00
2018-08-17 18:51:34 -07:00
2018-09-18 16:46:35 -07:00
2018-06-06 14:21:56 +05:30
2018-06-06 14:21:56 +05:30
2018-06-06 14:21:56 +05:30
2018-08-15 10:11:47 +05:30
2017-08-12 19:25:43 -07:00
2018-06-06 14:21:56 +05:30
2018-09-21 16:04:11 -07:00
2017-08-31 14:43:59 -07:00
2018-02-28 20:13:33 -08:00
2018-05-09 01:38:27 -07:00
2018-08-23 23:35:37 -07:00
2018-10-23 09:44:20 -07:00
2018-09-21 16:04:11 -07:00
2018-11-14 19:48:35 +05:30
2017-10-10 02:14:42 -07:00
2018-05-09 15:11:24 -07:00
2018-11-14 10:23:44 -08:00
2018-09-10 09:42:43 -07:00
2018-10-04 17:44:06 -07:00
2018-10-15 11:07:36 -07:00
2018-09-10 09:42:43 -07:00
2018-10-12 11:32:18 -07:00
2018-09-10 09:42:43 -07:00
2018-09-10 09:42:43 -07:00
2018-08-16 12:57:49 -07:00
2018-09-28 09:06:17 +05:30
2018-09-10 09:42:43 -07:00
2018-11-14 10:23:44 -08:00
2018-11-14 10:23:44 -08:00
2018-09-28 09:06:17 +05:30
2018-09-28 09:06:17 +05:30
2018-11-12 11:07:43 -08:00
2018-07-02 14:40:18 -07:00
2018-11-14 15:55:10 -08:00
2018-04-10 09:36:37 -07:00
2018-08-06 10:26:40 -07:00
2018-11-14 10:23:44 -08:00
2018-09-21 16:04:11 -07:00
2018-09-21 16:04:11 -07:00
2018-04-24 15:53:30 -07:00
2018-10-09 14:00:01 -07:00
2018-08-06 15:14:08 -07:00
2018-06-07 12:31:40 +05:30
2018-06-28 16:02:02 -07:00
2016-08-18 16:23:42 -07:00
2016-08-18 16:23:42 -07:00
2017-01-18 12:24:34 -08:00
2018-08-06 10:26:40 -07:00
2018-08-09 14:52:29 -07:00
2018-05-09 01:38:21 -07:00
2018-08-09 14:52:29 -07:00
2018-08-09 14:52:29 -07:00
2018-11-14 19:48:35 +05:30
2018-09-10 09:42:43 -07:00
2018-01-01 07:28:10 +05:30
2018-08-06 10:26:40 -07:00
2018-09-13 21:42:50 -07:00
2017-02-07 02:16:29 -08:00
2018-06-06 14:21:56 +05:30
2018-10-16 19:22:09 -07:00
2018-06-06 14:21:56 +05:30
2018-08-03 18:57:00 -07:00
2018-10-23 09:44:20 -07:00
2018-02-20 12:21:12 -08:00
2018-11-02 11:53:45 -07:00
2018-02-02 10:17:13 -08:00
2018-08-23 23:35:37 -07:00
2018-10-16 13:19:12 -07:00
2017-07-12 16:33:21 -07:00
2017-04-11 15:44:27 -07:00
2018-11-12 15:07:16 -08:00
2018-10-09 14:00:01 -07:00
2018-11-07 20:10:03 +05:30
2018-08-15 10:11:47 +05:30
2018-09-11 11:17:23 -07:00
2018-11-07 20:10:03 +05:30
2018-06-05 10:48:51 -07:00
2018-11-07 20:10:03 +05:30
2018-11-07 20:10:03 +05:30
2018-09-10 09:42:43 -07:00
2018-07-31 00:23:29 -07:00
2016-11-13 11:48:02 -08:00
2018-08-06 15:14:08 -07:00
2018-11-14 19:48:35 +05:30
2018-10-04 17:44:06 -07:00
2018-11-14 19:48:35 +05:30
2018-11-14 19:48:35 +05:30
2018-11-14 19:48:35 +05:30
2016-10-10 01:42:32 -07:00
2018-11-07 20:10:03 +05:30
2018-10-09 14:00:01 -07:00
2018-10-29 11:08:59 -07:00
2018-11-12 11:07:43 -08:00
2018-07-27 15:32:19 -07:00
2016-08-18 16:23:42 -07:00
2016-08-18 16:23:42 -07:00
2018-07-27 15:32:19 -07:00
2018-10-17 16:23:09 -07:00
2018-05-09 13:29:37 -07:00
2018-09-28 09:06:17 +05:30
2017-12-15 12:33:42 -08:00
2018-11-14 13:18:55 +05:30
2018-08-17 18:51:34 -07:00
2018-08-06 18:16:49 +05:30
2018-10-04 17:44:06 -07:00
2018-10-15 11:13:19 -07:00
2017-10-10 02:14:42 -07:00
2018-05-21 11:11:57 -07:00
2018-10-17 16:23:09 -07:00
2018-11-02 18:40:08 -07:00
2018-06-07 10:41:13 -07:00
2018-08-15 10:11:47 +05:30
2018-10-26 10:25:52 -07:00
2018-05-23 17:30:25 -07:00
2018-10-26 14:41:25 -07:00
2018-09-10 09:42:43 -07:00
2018-08-16 12:57:49 -07:00
2018-04-09 22:55:41 +05:30
2018-09-10 09:42:43 -07:00
2018-10-02 17:13:51 -07:00
2018-10-02 17:13:51 -07:00
2018-10-28 14:13:17 -07:00
2018-03-15 16:28:25 -07:00
2018-07-27 15:32:19 -07:00
2018-09-28 09:06:17 +05:30
2018-11-14 19:48:35 +05:30
2018-09-10 09:42:43 -07:00
2018-10-26 14:41:25 -07:00
2018-09-10 09:42:43 -07:00
2018-10-30 16:07:57 -07:00
2018-09-28 09:06:17 +05:30
2018-11-13 11:57:03 -08:00
2018-09-13 21:42:50 -07:00