limitations.asciidoc 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. [role="xpack"]
  2. [testenv="basic"]
  3. [[sql-limitations]]
  4. == SQL Limitations
  5. [float]
  6. === Nested fields in `SYS COLUMNS` and `DESCRIBE TABLE`
  7. {es} has a special type of relationship fields called `nested` fields. In {es-sql} they can be used by referencing their inner
  8. sub-fields. Even though `SYS COLUMNS` in non-driver mode (in the CLI and in REST calls) and `DESCRIBE TABLE` will still display
  9. them as having the type `NESTED`, they cannot be used in a query. One can only reference its sub-fields in the form:
  10. [source, sql]
  11. --------------------------------------------------
  12. [nested_field_name].[sub_field_name]
  13. --------------------------------------------------
  14. For example:
  15. [source, sql]
  16. --------------------------------------------------
  17. SELECT dep.dep_name.keyword FROM test_emp GROUP BY languages;
  18. --------------------------------------------------
  19. [float]
  20. === Multi-nested fields
  21. {es-sql} doesn't support multi-nested documents, so a query cannot reference more than one nested field in an index.
  22. This applies to multi-level nested fields, but also multiple nested fields defined on the same level. For example, for this index:
  23. [source, sql]
  24. ----------------------------------------------------
  25. column | type | mapping
  26. ----------------------+---------------+-------------
  27. nested_A |STRUCT |NESTED
  28. nested_A.nested_X |STRUCT |NESTED
  29. nested_A.nested_X.text|VARCHAR |KEYWORD
  30. nested_A.text |VARCHAR |KEYWORD
  31. nested_B |STRUCT |NESTED
  32. nested_B.text |VARCHAR |KEYWORD
  33. ----------------------------------------------------
  34. `nested_A` and `nested_B` cannot be used at the same time, nor `nested_A`/`nested_B` and `nested_A.nested_X` combination.
  35. For such situations, {es-sql} will display an error message.
  36. [float]
  37. === Paginating nested inner hits
  38. When SELECTing a nested field, pagination will not work as expected, {es-sql} will return __at least__ the page size records.
  39. This is because of the way nested queries work in {es}: the root nested field will be returned and it's matching inner nested fields as well,
  40. pagination taking place on the **root nested document and not on its inner hits**.
  41. [float]
  42. === Normalized `keyword` fields
  43. `keyword` fields in {es} can be normalized by defining a `normalizer`. Such fields are not supported in {es-sql}.
  44. [float]
  45. === Array type of fields
  46. Array fields are not supported due to the "invisible" way in which {es} handles an array of values: the mapping doesn't indicate whether
  47. a field is an array (has multiple values) or not, so without reading all the data, {es-sql} cannot know whether a field is a single or multi value.
  48. [float]
  49. === Sorting by aggregation
  50. When doing aggregations (`GROUP BY`) {es-sql} relies on {es}'s `composite` aggregation for its support for paginating results.
  51. However this type of aggregation does come with a limitation: sorting can only be applied on the key used for the aggregation's buckets.
  52. {es-sql} overcomes this limitation by doing client-side sorting however as a safety measure, allows only up to *512* rows.
  53. It is recommended to use `LIMIT` for queries that use sorting by aggregation, essentially indicating the top N results that are desired:
  54. [source, sql]
  55. --------------------------------------------------
  56. SELECT * FROM test GROUP BY age ORDER BY COUNT(*) LIMIT 100;
  57. --------------------------------------------------
  58. It is possible to run the same queries without a `LIMIT` however in that case if the maximum size (*512*) is passed, an exception will be
  59. returned as {es-sql} is unable to track (and sort) all the results returned.
  60. [float]
  61. === Using aggregation functions on top of scalar functions
  62. Aggregation functions like <<sql-functions-aggs-min,`MIN`>>, <<sql-functions-aggs-max,`MAX`>>, etc. can only be used
  63. directly on fields, and so queries like `SELECT MAX(abs(age)) FROM test` are not possible.
  64. [float]
  65. === Using a sub-select
  66. Using sub-selects (`SELECT X FROM (SELECT Y)`) is **supported to a small degree**: any sub-select that can be "flattened" into a single
  67. `SELECT` is possible with {es-sql}. For example:
  68. ["source","sql",subs="attributes,macros"]
  69. --------------------------------------------------
  70. include-tagged::{sql-specs}/docs.csv-spec[limitationSubSelect]
  71. --------------------------------------------------
  72. The query above is possible because it is equivalent with:
  73. ["source","sql",subs="attributes,macros"]
  74. --------------------------------------------------
  75. include-tagged::{sql-specs}/docs.csv-spec[limitationSubSelectRewritten]
  76. --------------------------------------------------
  77. But, if the sub-select would include a `GROUP BY` or `HAVING` or the enclosing `SELECT` would be more complex than `SELECT X
  78. FROM (SELECT ...) WHERE [simple_condition]`, this is currently **un-supported**.
  79. [float]
  80. === Using <<sql-functions-aggs-first, `FIRST`>>/<<sql-functions-aggs-last,`LAST`>> aggregation functions in `HAVING` clause
  81. Using `FIRST` and `LAST` in the `HAVING` clause is not supported. The same applies to
  82. <<sql-functions-aggs-min,`MIN`>> and <<sql-functions-aggs-max,`MAX`>> when their target column
  83. is of type <<keyword, `keyword`>> as they are internally translated to `FIRST` and `LAST`.