Presto Mismatched Domain types: date vs integer












0















I am facing this error when I am trying to query the date type column in my table



select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;


ERROR



com.facebook.presto.spi.PrestoException:
Error opening Hive split s3://oyo/room_nights/year=2018/month=11/part-00016-59e12a09-bed9-4234-88d0-098df6d926bb-c000 (offset=0, length=1446668): Mismatched Domain types: date vs integer
at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:220
at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createPageSource(ParquetPageSourceFactory.java:115)
at com.facebook.presto.hive.HivePageSourceProvider.createHivePageSource(HivePageSourceProvider.java:160)
at com.facebook.presto.hive.HivePageSourceProvider.createPageSource(HivePageSourceProvider.java:93)
at com.facebook.presto.spi.connector.classloader.ClassLoaderSafeConnectorPageSourceProvider.createPageSource(ClassLoaderSafeConnectorPageSourceProvider.java:44)
at com.facebook.presto.split.PageSourceManager.createPageSource(PageSourceManager.java:56)
at com.facebook.presto.operator.ScanFilterAndProjectOperator.getOutput(ScanFilterAndProjectOperator.java:216)
at com.facebook.presto.operator.Driver.processInternal(Driver.java:373)
at com.facebook.presto.operator.Driver.lambda$processFor$8(Driver.java:282)
at com.facebook.presto.operator.Driver.tryWithLock(Driver.java:672)
at com.facebook.presto.operator.Driver.processFor(Driver.java:276)
at com.facebook.presto.execution.SqlTaskExecution$DriverSplitRunner.processFor(SqlTaskExecution.java:973)
at com.facebook.presto.execution.executor.PrioritizedSplitRunner.process(PrioritizedSplitRunner.java:162)
at com.facebook.presto.execution.executor.TaskExecutor$TaskRunner.run(TaskExecutor.java:495)
at com.facebook.presto.$gen.Presto_0_208_x_0_10____20181124_123813_1.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.IllegalArgumentException: Mismatched Domain types: date vs integer
at com.facebook.presto.spi.predicate.Domain.checkCompatibility(Domain.java:229)
at com.facebook.presto.spi.predicate.Domain.intersect(Domain.java:184)
at com.facebook.presto.spi.predicate.TupleDomain.intersect(TupleDomain.java:197)
at com.facebook.presto.spi.predicate.TupleDomain.overlaps(TupleDomain.java:300)
at com.facebook.presto.hive.parquet.predicate.TupleDomainParquetPredicate.matches(TupleDomainParquetPredicate.java:94)
at com.facebook.presto.hive.parquet.predicate.ParquetPredicateUtils.predicateMatches(ParquetPredicateUtils.java:116)
at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.lambda$createParquetPageSource$3(ParquetPageSourceFactory.java:181)
at java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:174)
at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1382)
at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499)
at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:182)


Show create table command return the type of field 'd' as date



CREATE TABLE hive.aggregatedb.room_nights (    other columns,    d date,    other columns,    year integer,    month integer ) WITH (    external_location = 's3://oyo/room_nights',    format = 'PARQUET',    partitioned_by = ARRAY['year','month'] )


Heres the query plan of the above-mentioned query:-



EXPLAIN select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;

- Output[d] => [d:date]
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- Limit[10] => [d:date]
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- LocalExchange[SINGLE] () => d:date
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- RemoteExchange[GATHER] => d:date
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- LimitPartial[10] => [d:date]
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
- ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = ("d" = DATE '2018-11-26'), filterPred
Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
LAYOUT: aggregatedb.room_nights
d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
:: [[2018-11-26]]
HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
:: [[2016], [2017], [2018], [2019]]
HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
:: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]


But I am able to run the query if I convert the column 'd' to timestamp



EXPLAIN select d from aggregatedb.room_nights where cast(d as timestamp) = cast(current_date as timestamp) limit 10;

- Output[d] => [d:date]
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- Limit[10] => [d:date]
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- LocalExchange[SINGLE] () => d:date
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- RemoteExchange[GATHER] => d:date
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
- LimitPartial[10] => [d:date]
Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
- ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = (CAST("d" AS timestamp) = "$literal$t
Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
LAYOUT: aggregatedb.room_nights
d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
:: [[2016], [2017], [2018], [2019]]
HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
:: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]









share|improve this question



























    0















    I am facing this error when I am trying to query the date type column in my table



    select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;


    ERROR



    com.facebook.presto.spi.PrestoException:
    Error opening Hive split s3://oyo/room_nights/year=2018/month=11/part-00016-59e12a09-bed9-4234-88d0-098df6d926bb-c000 (offset=0, length=1446668): Mismatched Domain types: date vs integer
    at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:220
    at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createPageSource(ParquetPageSourceFactory.java:115)
    at com.facebook.presto.hive.HivePageSourceProvider.createHivePageSource(HivePageSourceProvider.java:160)
    at com.facebook.presto.hive.HivePageSourceProvider.createPageSource(HivePageSourceProvider.java:93)
    at com.facebook.presto.spi.connector.classloader.ClassLoaderSafeConnectorPageSourceProvider.createPageSource(ClassLoaderSafeConnectorPageSourceProvider.java:44)
    at com.facebook.presto.split.PageSourceManager.createPageSource(PageSourceManager.java:56)
    at com.facebook.presto.operator.ScanFilterAndProjectOperator.getOutput(ScanFilterAndProjectOperator.java:216)
    at com.facebook.presto.operator.Driver.processInternal(Driver.java:373)
    at com.facebook.presto.operator.Driver.lambda$processFor$8(Driver.java:282)
    at com.facebook.presto.operator.Driver.tryWithLock(Driver.java:672)
    at com.facebook.presto.operator.Driver.processFor(Driver.java:276)
    at com.facebook.presto.execution.SqlTaskExecution$DriverSplitRunner.processFor(SqlTaskExecution.java:973)
    at com.facebook.presto.execution.executor.PrioritizedSplitRunner.process(PrioritizedSplitRunner.java:162)
    at com.facebook.presto.execution.executor.TaskExecutor$TaskRunner.run(TaskExecutor.java:495)
    at com.facebook.presto.$gen.Presto_0_208_x_0_10____20181124_123813_1.run(Unknown Source)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)
    Caused by: java.lang.IllegalArgumentException: Mismatched Domain types: date vs integer
    at com.facebook.presto.spi.predicate.Domain.checkCompatibility(Domain.java:229)
    at com.facebook.presto.spi.predicate.Domain.intersect(Domain.java:184)
    at com.facebook.presto.spi.predicate.TupleDomain.intersect(TupleDomain.java:197)
    at com.facebook.presto.spi.predicate.TupleDomain.overlaps(TupleDomain.java:300)
    at com.facebook.presto.hive.parquet.predicate.TupleDomainParquetPredicate.matches(TupleDomainParquetPredicate.java:94)
    at com.facebook.presto.hive.parquet.predicate.ParquetPredicateUtils.predicateMatches(ParquetPredicateUtils.java:116)
    at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.lambda$createParquetPageSource$3(ParquetPageSourceFactory.java:181)
    at java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:174)
    at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1382)
    at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
    at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
    at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
    at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
    at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499)
    at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:182)


    Show create table command return the type of field 'd' as date



    CREATE TABLE hive.aggregatedb.room_nights (    other columns,    d date,    other columns,    year integer,    month integer ) WITH (    external_location = 's3://oyo/room_nights',    format = 'PARQUET',    partitioned_by = ARRAY['year','month'] )


    Heres the query plan of the above-mentioned query:-



    EXPLAIN select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;

    - Output[d] => [d:date]
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - Limit[10] => [d:date]
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - LocalExchange[SINGLE] () => d:date
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - RemoteExchange[GATHER] => d:date
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - LimitPartial[10] => [d:date]
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
    - ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = ("d" = DATE '2018-11-26'), filterPred
    Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
    LAYOUT: aggregatedb.room_nights
    d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
    :: [[2018-11-26]]
    HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
    :: [[2016], [2017], [2018], [2019]]
    HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
    :: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]


    But I am able to run the query if I convert the column 'd' to timestamp



    EXPLAIN select d from aggregatedb.room_nights where cast(d as timestamp) = cast(current_date as timestamp) limit 10;

    - Output[d] => [d:date]
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - Limit[10] => [d:date]
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - LocalExchange[SINGLE] () => d:date
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - RemoteExchange[GATHER] => d:date
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
    - LimitPartial[10] => [d:date]
    Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
    - ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = (CAST("d" AS timestamp) = "$literal$t
    Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
    LAYOUT: aggregatedb.room_nights
    d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
    HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
    :: [[2016], [2017], [2018], [2019]]
    HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
    :: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]









    share|improve this question

























      0












      0








      0








      I am facing this error when I am trying to query the date type column in my table



      select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;


      ERROR



      com.facebook.presto.spi.PrestoException:
      Error opening Hive split s3://oyo/room_nights/year=2018/month=11/part-00016-59e12a09-bed9-4234-88d0-098df6d926bb-c000 (offset=0, length=1446668): Mismatched Domain types: date vs integer
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:220
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createPageSource(ParquetPageSourceFactory.java:115)
      at com.facebook.presto.hive.HivePageSourceProvider.createHivePageSource(HivePageSourceProvider.java:160)
      at com.facebook.presto.hive.HivePageSourceProvider.createPageSource(HivePageSourceProvider.java:93)
      at com.facebook.presto.spi.connector.classloader.ClassLoaderSafeConnectorPageSourceProvider.createPageSource(ClassLoaderSafeConnectorPageSourceProvider.java:44)
      at com.facebook.presto.split.PageSourceManager.createPageSource(PageSourceManager.java:56)
      at com.facebook.presto.operator.ScanFilterAndProjectOperator.getOutput(ScanFilterAndProjectOperator.java:216)
      at com.facebook.presto.operator.Driver.processInternal(Driver.java:373)
      at com.facebook.presto.operator.Driver.lambda$processFor$8(Driver.java:282)
      at com.facebook.presto.operator.Driver.tryWithLock(Driver.java:672)
      at com.facebook.presto.operator.Driver.processFor(Driver.java:276)
      at com.facebook.presto.execution.SqlTaskExecution$DriverSplitRunner.processFor(SqlTaskExecution.java:973)
      at com.facebook.presto.execution.executor.PrioritizedSplitRunner.process(PrioritizedSplitRunner.java:162)
      at com.facebook.presto.execution.executor.TaskExecutor$TaskRunner.run(TaskExecutor.java:495)
      at com.facebook.presto.$gen.Presto_0_208_x_0_10____20181124_123813_1.run(Unknown Source)
      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
      at java.lang.Thread.run(Thread.java:748)
      Caused by: java.lang.IllegalArgumentException: Mismatched Domain types: date vs integer
      at com.facebook.presto.spi.predicate.Domain.checkCompatibility(Domain.java:229)
      at com.facebook.presto.spi.predicate.Domain.intersect(Domain.java:184)
      at com.facebook.presto.spi.predicate.TupleDomain.intersect(TupleDomain.java:197)
      at com.facebook.presto.spi.predicate.TupleDomain.overlaps(TupleDomain.java:300)
      at com.facebook.presto.hive.parquet.predicate.TupleDomainParquetPredicate.matches(TupleDomainParquetPredicate.java:94)
      at com.facebook.presto.hive.parquet.predicate.ParquetPredicateUtils.predicateMatches(ParquetPredicateUtils.java:116)
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.lambda$createParquetPageSource$3(ParquetPageSourceFactory.java:181)
      at java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:174)
      at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1382)
      at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
      at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
      at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
      at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
      at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499)
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:182)


      Show create table command return the type of field 'd' as date



      CREATE TABLE hive.aggregatedb.room_nights (    other columns,    d date,    other columns,    year integer,    month integer ) WITH (    external_location = 's3://oyo/room_nights',    format = 'PARQUET',    partitioned_by = ARRAY['year','month'] )


      Heres the query plan of the above-mentioned query:-



      EXPLAIN select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;

      - Output[d] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - Limit[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LocalExchange[SINGLE] () => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - RemoteExchange[GATHER] => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LimitPartial[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
      - ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = ("d" = DATE '2018-11-26'), filterPred
      Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
      LAYOUT: aggregatedb.room_nights
      d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
      :: [[2018-11-26]]
      HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[2016], [2017], [2018], [2019]]
      HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]


      But I am able to run the query if I convert the column 'd' to timestamp



      EXPLAIN select d from aggregatedb.room_nights where cast(d as timestamp) = cast(current_date as timestamp) limit 10;

      - Output[d] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - Limit[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LocalExchange[SINGLE] () => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - RemoteExchange[GATHER] => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LimitPartial[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
      - ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = (CAST("d" AS timestamp) = "$literal$t
      Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
      LAYOUT: aggregatedb.room_nights
      d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
      HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[2016], [2017], [2018], [2019]]
      HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]









      share|improve this question














      I am facing this error when I am trying to query the date type column in my table



      select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;


      ERROR



      com.facebook.presto.spi.PrestoException:
      Error opening Hive split s3://oyo/room_nights/year=2018/month=11/part-00016-59e12a09-bed9-4234-88d0-098df6d926bb-c000 (offset=0, length=1446668): Mismatched Domain types: date vs integer
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:220
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createPageSource(ParquetPageSourceFactory.java:115)
      at com.facebook.presto.hive.HivePageSourceProvider.createHivePageSource(HivePageSourceProvider.java:160)
      at com.facebook.presto.hive.HivePageSourceProvider.createPageSource(HivePageSourceProvider.java:93)
      at com.facebook.presto.spi.connector.classloader.ClassLoaderSafeConnectorPageSourceProvider.createPageSource(ClassLoaderSafeConnectorPageSourceProvider.java:44)
      at com.facebook.presto.split.PageSourceManager.createPageSource(PageSourceManager.java:56)
      at com.facebook.presto.operator.ScanFilterAndProjectOperator.getOutput(ScanFilterAndProjectOperator.java:216)
      at com.facebook.presto.operator.Driver.processInternal(Driver.java:373)
      at com.facebook.presto.operator.Driver.lambda$processFor$8(Driver.java:282)
      at com.facebook.presto.operator.Driver.tryWithLock(Driver.java:672)
      at com.facebook.presto.operator.Driver.processFor(Driver.java:276)
      at com.facebook.presto.execution.SqlTaskExecution$DriverSplitRunner.processFor(SqlTaskExecution.java:973)
      at com.facebook.presto.execution.executor.PrioritizedSplitRunner.process(PrioritizedSplitRunner.java:162)
      at com.facebook.presto.execution.executor.TaskExecutor$TaskRunner.run(TaskExecutor.java:495)
      at com.facebook.presto.$gen.Presto_0_208_x_0_10____20181124_123813_1.run(Unknown Source)
      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
      at java.lang.Thread.run(Thread.java:748)
      Caused by: java.lang.IllegalArgumentException: Mismatched Domain types: date vs integer
      at com.facebook.presto.spi.predicate.Domain.checkCompatibility(Domain.java:229)
      at com.facebook.presto.spi.predicate.Domain.intersect(Domain.java:184)
      at com.facebook.presto.spi.predicate.TupleDomain.intersect(TupleDomain.java:197)
      at com.facebook.presto.spi.predicate.TupleDomain.overlaps(TupleDomain.java:300)
      at com.facebook.presto.hive.parquet.predicate.TupleDomainParquetPredicate.matches(TupleDomainParquetPredicate.java:94)
      at com.facebook.presto.hive.parquet.predicate.ParquetPredicateUtils.predicateMatches(ParquetPredicateUtils.java:116)
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.lambda$createParquetPageSource$3(ParquetPageSourceFactory.java:181)
      at java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:174)
      at java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1382)
      at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
      at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
      at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
      at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
      at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499)
      at com.facebook.presto.hive.parquet.ParquetPageSourceFactory.createParquetPageSource(ParquetPageSourceFactory.java:182)


      Show create table command return the type of field 'd' as date



      CREATE TABLE hive.aggregatedb.room_nights (    other columns,    d date,    other columns,    year integer,    month integer ) WITH (    external_location = 's3://oyo/room_nights',    format = 'PARQUET',    partitioned_by = ARRAY['year','month'] )


      Heres the query plan of the above-mentioned query:-



      EXPLAIN select d from aggregatedb.room_nights where d = cast(current_date as date) limit 10;

      - Output[d] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - Limit[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LocalExchange[SINGLE] () => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - RemoteExchange[GATHER] => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LimitPartial[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
      - ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = ("d" = DATE '2018-11-26'), filterPred
      Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
      LAYOUT: aggregatedb.room_nights
      d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
      :: [[2018-11-26]]
      HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[2016], [2017], [2018], [2019]]
      HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]


      But I am able to run the query if I convert the column 'd' to timestamp



      EXPLAIN select d from aggregatedb.room_nights where cast(d as timestamp) = cast(current_date as timestamp) limit 10;

      - Output[d] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - Limit[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LocalExchange[SINGLE] () => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - RemoteExchange[GATHER] => d:date
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 50.00}
      - LimitPartial[10] => [d:date]
      Cost: {rows: 10 (50B), cpu: ?, memory: 0.00, network: 0.00}
      - ScanFilter[table = hive:aggregatedb:room_nights, originalConstraint = (CAST("d" AS timestamp) = "$literal$t
      Cost: {rows: ? (?), cpu: ?, memory: 0.00, network: 0.00}/{rows: ? (?), cpu: ?, memory: 0.00, network:
      LAYOUT: aggregatedb.room_nights
      d := HiveColumnHandle{name=d, hiveType=date, hiveColumnIndex=23, columnType=REGULAR}
      HiveColumnHandle{name=year, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[2016], [2017], [2018], [2019]]
      HiveColumnHandle{name=month, hiveType=int, hiveColumnIndex=-1, columnType=PARTITION_KEY}
      :: [[1], [2], [3], [4], [5], [6], [7], [8], [9], [10], [11], [12]]






      amazon-s3 prestodb






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 26 '18 at 5:32









      Ayush ChauhanAyush Chauhan

      11415




      11415
























          1 Answer
          1






          active

          oldest

          votes


















          0














          This was a bug in Presto and it has been fixed by https://github.com/prestosql/presto/commit/7e65ddc830219053044411ee39d7a8f47d51b071.






          share|improve this answer

























            Your Answer






            StackExchange.ifUsing("editor", function () {
            StackExchange.using("externalEditor", function () {
            StackExchange.using("snippets", function () {
            StackExchange.snippets.init();
            });
            });
            }, "code-snippets");

            StackExchange.ready(function() {
            var channelOptions = {
            tags: "".split(" "),
            id: "1"
            };
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function() {
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled) {
            StackExchange.using("snippets", function() {
            createEditor();
            });
            }
            else {
            createEditor();
            }
            });

            function createEditor() {
            StackExchange.prepareEditor({
            heartbeatType: 'answer',
            autoActivateHeartbeat: false,
            convertImagesToLinks: true,
            noModals: true,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            imageUploader: {
            brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
            contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
            allowUrls: true
            },
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            });


            }
            });














            draft saved

            draft discarded


















            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53475227%2fpresto-mismatched-domain-types-date-vs-integer%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown

























            1 Answer
            1






            active

            oldest

            votes








            1 Answer
            1






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes









            0














            This was a bug in Presto and it has been fixed by https://github.com/prestosql/presto/commit/7e65ddc830219053044411ee39d7a8f47d51b071.






            share|improve this answer






























              0














              This was a bug in Presto and it has been fixed by https://github.com/prestosql/presto/commit/7e65ddc830219053044411ee39d7a8f47d51b071.






              share|improve this answer




























                0












                0








                0







                This was a bug in Presto and it has been fixed by https://github.com/prestosql/presto/commit/7e65ddc830219053044411ee39d7a8f47d51b071.






                share|improve this answer















                This was a bug in Presto and it has been fixed by https://github.com/prestosql/presto/commit/7e65ddc830219053044411ee39d7a8f47d51b071.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Feb 1 at 17:52

























                answered Dec 10 '18 at 8:10









                Piotr FindeisenPiotr Findeisen

                5,49211644




                5,49211644
































                    draft saved

                    draft discarded




















































                    Thanks for contributing an answer to Stack Overflow!


                    • Please be sure to answer the question. Provide details and share your research!

                    But avoid



                    • Asking for help, clarification, or responding to other answers.

                    • Making statements based on opinion; back them up with references or personal experience.


                    To learn more, see our tips on writing great answers.




                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function () {
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53475227%2fpresto-mismatched-domain-types-date-vs-integer%23new-answer', 'question_page');
                    }
                    );

                    Post as a guest















                    Required, but never shown





















































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown

































                    Required, but never shown














                    Required, but never shown












                    Required, but never shown







                    Required, but never shown







                    Popular posts from this blog

                    Costa Masnaga

                    Fotorealismo

                    Sidney Franklin