duckdb 0.8.2-dev87.0 → 0.9.1-dev0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -0
- package/binding.gyp +30 -15
- package/binding.gyp.in +1 -2
- package/configure.py +11 -3
- package/duckdb_extension_config.cmake +10 -0
- package/lib/duckdb.js +14 -4
- package/package.json +3 -1
- package/src/connection.cpp +67 -38
- package/src/data_chunk.cpp +1 -3
- package/src/database.cpp +9 -17
- package/src/duckdb/extension/icu/icu-dateadd.cpp +13 -21
- package/src/duckdb/extension/icu/icu-datefunc.cpp +10 -1
- package/src/duckdb/extension/icu/icu-datepart.cpp +216 -100
- package/src/duckdb/extension/icu/icu-datesub.cpp +13 -17
- package/src/duckdb/extension/icu/icu-datetrunc.cpp +8 -9
- package/src/duckdb/extension/icu/icu-list-range.cpp +7 -9
- package/src/duckdb/extension/icu/icu-makedate.cpp +27 -16
- package/src/duckdb/extension/icu/icu-strptime.cpp +36 -65
- package/src/duckdb/extension/icu/icu-table-range.cpp +11 -14
- package/src/duckdb/extension/icu/icu-timebucket.cpp +21 -23
- package/src/duckdb/extension/icu/icu-timezone.cpp +26 -37
- package/src/duckdb/extension/icu/icu_extension.cpp +29 -36
- package/src/duckdb/extension/icu/include/icu-dateadd.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-datepart.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-datesub.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-datetrunc.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-list-range.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-makedate.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-strptime.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-table-range.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-timebucket.hpp +1 -1
- package/src/duckdb/extension/icu/include/icu-timezone.hpp +1 -1
- package/src/duckdb/extension/icu/third_party/icu/i18n/unicode/gregocal.h +1 -1
- package/src/duckdb/extension/json/buffered_json_reader.cpp +82 -92
- package/src/duckdb/extension/json/include/buffered_json_reader.hpp +38 -52
- package/src/duckdb/extension/json/include/json_common.hpp +47 -231
- package/src/duckdb/extension/json/include/json_deserializer.hpp +9 -18
- package/src/duckdb/extension/json/include/json_enums.hpp +60 -0
- package/src/duckdb/extension/json/include/json_executors.hpp +49 -13
- package/src/duckdb/extension/json/include/json_functions.hpp +2 -1
- package/src/duckdb/extension/json/include/json_scan.hpp +21 -21
- package/src/duckdb/extension/json/include/json_serializer.hpp +12 -18
- package/src/duckdb/extension/json/include/json_transform.hpp +2 -2
- package/src/duckdb/extension/json/json_common.cpp +272 -40
- package/src/duckdb/extension/json/json_deserializer.cpp +37 -73
- package/src/duckdb/extension/json/json_enums.cpp +105 -0
- package/src/duckdb/extension/json/json_functions/copy_json.cpp +1 -1
- package/src/duckdb/extension/json/json_functions/json_create.cpp +21 -2
- package/src/duckdb/extension/json/json_functions/json_serialize_sql.cpp +4 -1
- package/src/duckdb/extension/json/json_functions/json_structure.cpp +1 -1
- package/src/duckdb/extension/json/json_functions/json_transform.cpp +98 -57
- package/src/duckdb/extension/json/json_functions/json_type.cpp +1 -1
- package/src/duckdb/extension/json/json_functions/read_json.cpp +21 -2
- package/src/duckdb/extension/json/json_functions.cpp +30 -31
- package/src/duckdb/extension/json/json_scan.cpp +148 -175
- package/src/duckdb/extension/json/json_serializer.cpp +29 -72
- package/src/duckdb/extension/json/serialize_json.cpp +92 -0
- package/src/duckdb/extension/parquet/column_reader.cpp +37 -25
- package/src/duckdb/extension/parquet/column_writer.cpp +121 -104
- package/src/duckdb/extension/parquet/include/cast_column_reader.hpp +2 -2
- package/src/duckdb/extension/parquet/include/column_reader.hpp +14 -16
- package/src/duckdb/extension/parquet/include/column_writer.hpp +11 -9
- package/src/duckdb/extension/parquet/include/list_column_reader.hpp +2 -2
- package/src/duckdb/extension/parquet/include/parquet_dbp_decoder.hpp +3 -3
- package/src/duckdb/extension/parquet/include/parquet_decimal_utils.hpp +3 -3
- package/src/duckdb/extension/parquet/include/parquet_file_metadata_cache.hpp +2 -2
- package/src/duckdb/extension/parquet/include/parquet_reader.hpp +3 -2
- package/src/duckdb/extension/parquet/include/parquet_rle_bp_encoder.hpp +4 -4
- package/src/duckdb/extension/parquet/include/parquet_statistics.hpp +2 -2
- package/src/duckdb/extension/parquet/include/parquet_support.hpp +9 -11
- package/src/duckdb/extension/parquet/include/parquet_timestamp.hpp +1 -0
- package/src/duckdb/extension/parquet/include/parquet_writer.hpp +29 -5
- package/src/duckdb/extension/parquet/include/string_column_reader.hpp +1 -1
- package/src/duckdb/extension/parquet/include/struct_column_reader.hpp +2 -3
- package/src/duckdb/extension/parquet/include/zstd_file_system.hpp +2 -2
- package/src/duckdb/extension/parquet/parquet_extension.cpp +340 -93
- package/src/duckdb/extension/parquet/parquet_reader.cpp +10 -10
- package/src/duckdb/extension/parquet/parquet_statistics.cpp +25 -8
- package/src/duckdb/extension/parquet/parquet_timestamp.cpp +6 -0
- package/src/duckdb/extension/parquet/parquet_writer.cpp +170 -33
- package/src/duckdb/extension/parquet/serialize_parquet.cpp +26 -0
- package/src/duckdb/extension/parquet/zstd_file_system.cpp +2 -2
- package/src/duckdb/src/catalog/catalog.cpp +177 -70
- package/src/duckdb/src/catalog/catalog_entry/duck_index_entry.cpp +5 -0
- package/src/duckdb/src/catalog/catalog_entry/duck_table_entry.cpp +8 -11
- package/src/duckdb/src/catalog/catalog_entry/index_catalog_entry.cpp +17 -42
- package/src/duckdb/src/catalog/catalog_entry/macro_catalog_entry.cpp +2 -11
- package/src/duckdb/src/catalog/catalog_entry/schema_catalog_entry.cpp +4 -15
- package/src/duckdb/src/catalog/catalog_entry/sequence_catalog_entry.cpp +11 -29
- package/src/duckdb/src/catalog/catalog_entry/table_catalog_entry.cpp +11 -44
- package/src/duckdb/src/catalog/catalog_entry/type_catalog_entry.cpp +8 -29
- package/src/duckdb/src/catalog/catalog_entry/view_catalog_entry.cpp +11 -28
- package/src/duckdb/src/catalog/catalog_entry.cpp +16 -1
- package/src/duckdb/src/catalog/catalog_search_path.cpp +5 -4
- package/src/duckdb/src/catalog/catalog_set.cpp +16 -77
- package/src/duckdb/src/catalog/default/default_functions.cpp +23 -2
- package/src/duckdb/src/catalog/dependency_manager.cpp +0 -36
- package/src/duckdb/src/catalog/duck_catalog.cpp +4 -0
- package/src/duckdb/src/common/adbc/adbc.cpp +541 -171
- package/src/duckdb/src/common/adbc/driver_manager.cpp +92 -39
- package/src/duckdb/src/common/adbc/nanoarrow/allocator.cpp +57 -0
- package/src/duckdb/src/common/adbc/nanoarrow/metadata.cpp +121 -0
- package/src/duckdb/src/common/adbc/nanoarrow/schema.cpp +474 -0
- package/src/duckdb/src/common/adbc/nanoarrow/single_batch_array_stream.cpp +84 -0
- package/src/duckdb/src/common/allocator.cpp +14 -2
- package/src/duckdb/src/common/arrow/appender/bool_data.cpp +44 -0
- package/src/duckdb/src/common/arrow/appender/list_data.cpp +78 -0
- package/src/duckdb/src/common/arrow/appender/map_data.cpp +86 -0
- package/src/duckdb/src/common/arrow/appender/struct_data.cpp +45 -0
- package/src/duckdb/src/common/arrow/appender/union_data.cpp +70 -0
- package/src/duckdb/src/common/arrow/arrow_appender.cpp +95 -666
- package/src/duckdb/src/common/arrow/arrow_converter.cpp +68 -38
- package/src/duckdb/src/common/arrow/arrow_wrapper.cpp +37 -42
- package/src/duckdb/src/common/assert.cpp +3 -0
- package/src/duckdb/src/common/constants.cpp +2 -2
- package/src/duckdb/src/common/crypto/md5.cpp +2 -12
- package/src/duckdb/src/common/enum_util.cpp +4967 -4412
- package/src/duckdb/src/common/enums/date_part_specifier.cpp +2 -0
- package/src/duckdb/src/common/enums/logical_operator_type.cpp +4 -0
- package/src/duckdb/src/common/enums/optimizer_type.cpp +2 -0
- package/src/duckdb/src/common/enums/physical_operator_type.cpp +4 -0
- package/src/duckdb/src/common/exception.cpp +15 -2
- package/src/duckdb/src/common/extra_type_info.cpp +315 -0
- package/src/duckdb/src/common/file_buffer.cpp +2 -2
- package/src/duckdb/src/common/file_system.cpp +46 -12
- package/src/duckdb/src/common/filename_pattern.cpp +1 -1
- package/src/duckdb/src/common/gzip_file_system.cpp +7 -12
- package/src/duckdb/src/common/hive_partitioning.cpp +10 -6
- package/src/duckdb/src/common/http_state.cpp +78 -0
- package/src/duckdb/src/common/local_file_system.cpp +36 -28
- package/src/duckdb/src/common/multi_file_reader.cpp +175 -70
- package/src/duckdb/src/common/operator/cast_operators.cpp +110 -1
- package/src/duckdb/src/common/operator/string_cast.cpp +45 -8
- package/src/duckdb/src/common/radix_partitioning.cpp +34 -39
- package/src/duckdb/src/common/re2_regex.cpp +1 -1
- package/src/duckdb/src/common/row_operations/row_aggregate.cpp +18 -3
- package/src/duckdb/src/common/row_operations/row_external.cpp +1 -1
- package/src/duckdb/src/common/row_operations/row_matcher.cpp +375 -0
- package/src/duckdb/src/common/serializer/binary_deserializer.cpp +63 -73
- package/src/duckdb/src/common/serializer/binary_serializer.cpp +88 -78
- package/src/duckdb/src/common/serializer/buffered_file_reader.cpp +3 -20
- package/src/duckdb/src/common/serializer/buffered_file_writer.cpp +1 -1
- package/src/duckdb/src/common/serializer/memory_stream.cpp +61 -0
- package/src/duckdb/src/common/serializer/serializer.cpp +15 -0
- package/src/duckdb/src/common/sort/merge_sorter.cpp +9 -16
- package/src/duckdb/src/common/sort/partition_state.cpp +210 -100
- package/src/duckdb/src/common/sort/sort_state.cpp +1 -1
- package/src/duckdb/src/common/sort/sorted_block.cpp +1 -1
- package/src/duckdb/src/common/types/batched_data_collection.cpp +7 -2
- package/src/duckdb/src/common/types/bit.cpp +51 -0
- package/src/duckdb/src/common/types/column/column_data_allocator.cpp +9 -6
- package/src/duckdb/src/common/types/column/column_data_collection.cpp +68 -2
- package/src/duckdb/src/common/types/column/column_data_collection_segment.cpp +20 -6
- package/src/duckdb/src/common/types/column/partitioned_column_data.cpp +2 -2
- package/src/duckdb/src/common/types/data_chunk.cpp +77 -36
- package/src/duckdb/src/common/types/date.cpp +15 -0
- package/src/duckdb/src/common/types/hugeint.cpp +40 -0
- package/src/duckdb/src/common/types/hyperloglog.cpp +9 -7
- package/src/duckdb/src/common/types/interval.cpp +6 -0
- package/src/duckdb/src/common/types/list_segment.cpp +56 -198
- package/src/duckdb/src/common/types/row/partitioned_tuple_data.cpp +251 -131
- package/src/duckdb/src/common/types/row/row_data_collection_scanner.cpp +35 -5
- package/src/duckdb/src/common/types/row/row_layout.cpp +3 -31
- package/src/duckdb/src/common/types/row/tuple_data_allocator.cpp +43 -35
- package/src/duckdb/src/common/types/row/tuple_data_collection.cpp +74 -41
- package/src/duckdb/src/common/types/row/tuple_data_layout.cpp +11 -1
- package/src/duckdb/src/common/types/row/tuple_data_scatter_gather.cpp +46 -45
- package/src/duckdb/src/common/types/row/tuple_data_segment.cpp +21 -16
- package/src/duckdb/src/common/types/string_heap.cpp +4 -0
- package/src/duckdb/src/common/types/time.cpp +105 -0
- package/src/duckdb/src/common/types/timestamp.cpp +7 -0
- package/src/duckdb/src/common/types/uuid.cpp +2 -2
- package/src/duckdb/src/common/types/validity_mask.cpp +89 -0
- package/src/duckdb/src/common/types/value.cpp +103 -189
- package/src/duckdb/src/common/types/vector.cpp +79 -216
- package/src/duckdb/src/common/types.cpp +50 -745
- package/src/duckdb/src/common/vector_operations/vector_hash.cpp +1 -0
- package/src/duckdb/src/common/virtual_file_system.cpp +142 -1
- package/src/duckdb/src/core_functions/aggregate/algebraic/avg.cpp +0 -1
- package/src/duckdb/src/core_functions/aggregate/distributive/string_agg.cpp +6 -7
- package/src/duckdb/src/core_functions/aggregate/holistic/approximate_quantile.cpp +11 -8
- package/src/duckdb/src/core_functions/aggregate/holistic/mode.cpp +6 -8
- package/src/duckdb/src/core_functions/aggregate/holistic/quantile.cpp +137 -92
- package/src/duckdb/src/core_functions/aggregate/holistic/reservoir_quantile.cpp +15 -10
- package/src/duckdb/src/core_functions/aggregate/nested/histogram.cpp +1 -0
- package/src/duckdb/src/core_functions/aggregate/nested/list.cpp +83 -59
- package/src/duckdb/src/core_functions/aggregate/regression/regr_avg.cpp +4 -4
- package/src/duckdb/src/core_functions/aggregate/regression/regr_intercept.cpp +4 -4
- package/src/duckdb/src/core_functions/aggregate/regression/regr_r2.cpp +5 -4
- package/src/duckdb/src/core_functions/aggregate/regression/regr_sxx_syy.cpp +8 -8
- package/src/duckdb/src/core_functions/aggregate/regression/regr_sxy.cpp +4 -3
- package/src/duckdb/src/core_functions/function_list.cpp +20 -6
- package/src/duckdb/src/core_functions/scalar/date/date_diff.cpp +2 -0
- package/src/duckdb/src/core_functions/scalar/date/date_part.cpp +450 -126
- package/src/duckdb/src/core_functions/scalar/date/date_sub.cpp +2 -0
- package/src/duckdb/src/core_functions/scalar/date/date_trunc.cpp +4 -0
- package/src/duckdb/src/core_functions/scalar/date/epoch.cpp +10 -24
- package/src/duckdb/src/core_functions/scalar/date/make_date.cpp +19 -4
- package/src/duckdb/src/core_functions/scalar/date/strftime.cpp +12 -2
- package/src/duckdb/src/core_functions/scalar/debug/vector_type.cpp +23 -0
- package/src/duckdb/src/core_functions/scalar/enum/enum_functions.cpp +16 -12
- package/src/duckdb/src/core_functions/scalar/generic/current_setting.cpp +3 -1
- package/src/duckdb/src/core_functions/scalar/generic/hash.cpp +3 -0
- package/src/duckdb/src/core_functions/scalar/list/array_slice.cpp +324 -82
- package/src/duckdb/src/core_functions/scalar/list/list_aggregates.cpp +25 -18
- package/src/duckdb/src/core_functions/scalar/list/list_cosine_similarity.cpp +78 -0
- package/src/duckdb/src/core_functions/scalar/list/list_distance.cpp +72 -0
- package/src/duckdb/src/core_functions/scalar/list/list_inner_product.cpp +70 -0
- package/src/duckdb/src/core_functions/scalar/list/list_lambdas.cpp +18 -6
- package/src/duckdb/src/core_functions/scalar/list/list_sort.cpp +10 -1
- package/src/duckdb/src/core_functions/scalar/map/map_concat.cpp +0 -2
- package/src/duckdb/src/core_functions/scalar/map/map_entries.cpp +2 -2
- package/src/duckdb/src/core_functions/scalar/string/repeat.cpp +8 -5
- package/src/duckdb/src/core_functions/scalar/string/sha256.cpp +32 -0
- package/src/duckdb/src/core_functions/scalar/string/to_base.cpp +66 -0
- package/src/duckdb/src/core_functions/scalar/struct/struct_pack.cpp +24 -14
- package/src/duckdb/src/core_functions/scalar/union/union_tag.cpp +1 -1
- package/src/duckdb/src/execution/aggregate_hashtable.cpp +229 -348
- package/src/duckdb/src/execution/column_binding_resolver.cpp +11 -7
- package/src/duckdb/src/execution/expression_executor/execute_parameter.cpp +2 -2
- package/src/duckdb/src/execution/expression_executor.cpp +1 -1
- package/src/duckdb/src/execution/index/art/art.cpp +279 -296
- package/src/duckdb/src/execution/index/art/art_key.cpp +0 -11
- package/src/duckdb/src/execution/index/art/iterator.cpp +127 -217
- package/src/duckdb/src/execution/index/art/leaf.cpp +228 -272
- package/src/duckdb/src/execution/index/art/node.cpp +225 -313
- package/src/duckdb/src/execution/index/art/node16.cpp +34 -75
- package/src/duckdb/src/execution/index/art/node256.cpp +40 -63
- package/src/duckdb/src/execution/index/art/node4.cpp +44 -77
- package/src/duckdb/src/execution/index/art/node48.cpp +45 -79
- package/src/duckdb/src/execution/index/art/prefix.cpp +246 -347
- package/src/duckdb/src/execution/index/fixed_size_allocator.cpp +323 -0
- package/src/duckdb/src/execution/index/fixed_size_buffer.cpp +285 -0
- package/src/duckdb/src/execution/join_hashtable.cpp +80 -69
- package/src/duckdb/src/execution/nested_loop_join/nested_loop_join_inner.cpp +20 -27
- package/src/duckdb/src/execution/nested_loop_join/nested_loop_join_mark.cpp +21 -9
- package/src/duckdb/src/execution/operator/aggregate/aggregate_object.cpp +1 -0
- package/src/duckdb/src/execution/operator/aggregate/physical_hash_aggregate.cpp +257 -324
- package/src/duckdb/src/execution/operator/aggregate/physical_perfecthash_aggregate.cpp +6 -4
- package/src/duckdb/src/execution/operator/aggregate/physical_streaming_window.cpp +8 -3
- package/src/duckdb/src/execution/operator/aggregate/physical_ungrouped_aggregate.cpp +231 -190
- package/src/duckdb/src/execution/operator/aggregate/physical_window.cpp +368 -1070
- package/src/duckdb/src/execution/operator/{persistent → csv_scanner}/base_csv_reader.cpp +162 -175
- package/src/duckdb/src/execution/operator/csv_scanner/buffered_csv_reader.cpp +434 -0
- package/src/duckdb/src/execution/operator/csv_scanner/csv_buffer.cpp +89 -0
- package/src/duckdb/src/execution/operator/csv_scanner/csv_buffer_manager.cpp +90 -0
- package/src/duckdb/src/execution/operator/csv_scanner/csv_file_handle.cpp +95 -0
- package/src/duckdb/src/execution/operator/csv_scanner/csv_reader_options.cpp +494 -0
- package/src/duckdb/src/execution/operator/csv_scanner/csv_state_machine.cpp +35 -0
- package/src/duckdb/src/execution/operator/csv_scanner/csv_state_machine_cache.cpp +106 -0
- package/src/duckdb/src/execution/operator/{persistent → csv_scanner}/parallel_csv_reader.cpp +69 -51
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/csv_sniffer.cpp +61 -0
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/dialect_detection.cpp +339 -0
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/header_detection.cpp +171 -0
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/type_detection.cpp +415 -0
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/type_refinement.cpp +196 -0
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/type_replacement.cpp +39 -0
- package/src/duckdb/src/execution/operator/filter/physical_filter.cpp +1 -1
- package/src/duckdb/src/execution/operator/helper/physical_batch_collector.cpp +12 -9
- package/src/duckdb/src/execution/operator/helper/physical_explain_analyze.cpp +2 -2
- package/src/duckdb/src/execution/operator/helper/physical_limit.cpp +10 -8
- package/src/duckdb/src/execution/operator/helper/physical_load.cpp +2 -1
- package/src/duckdb/src/execution/operator/helper/physical_materialized_collector.cpp +7 -5
- package/src/duckdb/src/execution/operator/helper/physical_reset.cpp +3 -1
- package/src/duckdb/src/execution/operator/helper/physical_set.cpp +3 -1
- package/src/duckdb/src/execution/operator/helper/physical_vacuum.cpp +7 -5
- package/src/duckdb/src/execution/operator/join/physical_asof_join.cpp +465 -289
- package/src/duckdb/src/execution/operator/join/physical_blockwise_nl_join.cpp +2 -2
- package/src/duckdb/src/execution/operator/join/physical_comparison_join.cpp +1 -2
- package/src/duckdb/src/execution/operator/join/physical_delim_join.cpp +13 -6
- package/src/duckdb/src/execution/operator/join/physical_hash_join.cpp +37 -19
- package/src/duckdb/src/execution/operator/join/physical_iejoin.cpp +35 -17
- package/src/duckdb/src/execution/operator/join/physical_join.cpp +1 -1
- package/src/duckdb/src/execution/operator/join/physical_nested_loop_join.cpp +7 -4
- package/src/duckdb/src/execution/operator/join/physical_piecewise_merge_join.cpp +31 -10
- package/src/duckdb/src/execution/operator/join/physical_range_join.cpp +41 -5
- package/src/duckdb/src/execution/operator/order/physical_order.cpp +7 -5
- package/src/duckdb/src/execution/operator/order/physical_top_n.cpp +7 -5
- package/src/duckdb/src/execution/operator/persistent/csv_rejects_table.cpp +48 -0
- package/src/duckdb/src/execution/operator/persistent/physical_batch_copy_to_file.cpp +14 -10
- package/src/duckdb/src/execution/operator/persistent/physical_batch_insert.cpp +69 -47
- package/src/duckdb/src/execution/operator/persistent/physical_copy_to_file.cpp +9 -7
- package/src/duckdb/src/execution/operator/persistent/physical_export.cpp +1 -1
- package/src/duckdb/src/execution/operator/persistent/physical_fixed_batch_copy.cpp +14 -12
- package/src/duckdb/src/execution/operator/persistent/physical_insert.cpp +12 -12
- package/src/duckdb/src/execution/operator/persistent/physical_update.cpp +4 -2
- package/src/duckdb/src/execution/operator/projection/physical_pivot.cpp +2 -1
- package/src/duckdb/src/execution/operator/projection/physical_unnest.cpp +24 -27
- package/src/duckdb/src/execution/operator/scan/physical_column_data_scan.cpp +19 -0
- package/src/duckdb/src/execution/operator/scan/physical_table_scan.cpp +7 -12
- package/src/duckdb/src/execution/operator/schema/physical_attach.cpp +6 -2
- package/src/duckdb/src/execution/operator/schema/physical_create_art_index.cpp +198 -0
- package/src/duckdb/src/execution/operator/schema/physical_create_type.cpp +2 -6
- package/src/duckdb/src/execution/operator/set/physical_cte.cpp +160 -0
- package/src/duckdb/src/execution/operator/set/physical_recursive_cte.cpp +16 -7
- package/src/duckdb/src/execution/perfect_aggregate_hashtable.cpp +37 -6
- package/src/duckdb/src/execution/physical_operator.cpp +3 -2
- package/src/duckdb/src/execution/physical_plan/plan_aggregate.cpp +43 -10
- package/src/duckdb/src/execution/physical_plan/plan_asof_join.cpp +57 -35
- package/src/duckdb/src/execution/physical_plan/plan_comparison_join.cpp +45 -25
- package/src/duckdb/src/execution/physical_plan/plan_create_index.cpp +45 -34
- package/src/duckdb/src/execution/physical_plan/plan_cte.cpp +33 -0
- package/src/duckdb/src/execution/physical_plan/plan_delim_join.cpp +2 -5
- package/src/duckdb/src/execution/physical_plan/plan_get.cpp +2 -2
- package/src/duckdb/src/execution/physical_plan/plan_recursive_cte.cpp +25 -4
- package/src/duckdb/src/execution/physical_plan_generator.cpp +6 -11
- package/src/duckdb/src/execution/radix_partitioned_hashtable.cpp +658 -363
- package/src/duckdb/src/execution/reservoir_sample.cpp +3 -9
- package/src/duckdb/src/execution/window_executor.cpp +1285 -0
- package/src/duckdb/src/execution/window_segment_tree.cpp +408 -144
- package/src/duckdb/src/function/aggregate/distributive/count.cpp +2 -13
- package/src/duckdb/src/function/aggregate/sorted_aggregate_function.cpp +6 -12
- package/src/duckdb/src/function/cast/bit_cast.cpp +34 -2
- package/src/duckdb/src/function/cast/blob_cast.cpp +3 -0
- package/src/duckdb/src/function/cast/cast_function_set.cpp +1 -0
- package/src/duckdb/src/function/cast/numeric_casts.cpp +2 -0
- package/src/duckdb/src/function/cast/string_cast.cpp +2 -2
- package/src/duckdb/src/function/cast/struct_cast.cpp +8 -0
- package/src/duckdb/src/function/cast/time_casts.cpp +19 -6
- package/src/duckdb/src/function/cast/union/from_struct.cpp +114 -0
- package/src/duckdb/src/function/cast/union_casts.cpp +25 -36
- package/src/duckdb/src/function/cast/vector_cast_helpers.cpp +15 -4
- package/src/duckdb/src/function/function.cpp +3 -1
- package/src/duckdb/src/function/function_binder.cpp +18 -8
- package/src/duckdb/src/function/macro_function.cpp +0 -42
- package/src/duckdb/src/function/pragma/pragma_functions.cpp +5 -0
- package/src/duckdb/src/function/pragma/pragma_queries.cpp +15 -1
- package/src/duckdb/src/function/scalar/compressed_materialization/compress_integral.cpp +214 -0
- package/src/duckdb/src/function/scalar/compressed_materialization/compress_string.cpp +250 -0
- package/src/duckdb/src/function/scalar/compressed_materialization_functions.cpp +29 -0
- package/src/duckdb/src/function/scalar/list/list_resize.cpp +162 -0
- package/src/duckdb/src/function/scalar/nested_functions.cpp +1 -0
- package/src/duckdb/src/function/scalar/operators/add.cpp +9 -0
- package/src/duckdb/src/function/scalar/operators/arithmetic.cpp +15 -14
- package/src/duckdb/src/function/scalar/strftime_format.cpp +33 -12
- package/src/duckdb/src/function/scalar/string/like.cpp +12 -7
- package/src/duckdb/src/function/scalar/string/suffix.cpp +1 -1
- package/src/duckdb/src/function/scalar/system/aggregate_export.cpp +19 -11
- package/src/duckdb/src/function/scalar_function.cpp +3 -19
- package/src/duckdb/src/function/scalar_macro_function.cpp +0 -10
- package/src/duckdb/src/function/table/arrow/arrow_duck_schema.cpp +57 -0
- package/src/duckdb/src/function/table/arrow.cpp +131 -100
- package/src/duckdb/src/function/table/arrow_conversion.cpp +95 -74
- package/src/duckdb/src/function/table/copy_csv.cpp +133 -127
- package/src/duckdb/src/function/table/read_csv.cpp +198 -381
- package/src/duckdb/src/function/table/system/duckdb_columns.cpp +3 -1
- package/src/duckdb/src/function/table/system/pragma_metadata_info.cpp +83 -0
- package/src/duckdb/src/function/table/system/pragma_storage_info.cpp +5 -0
- package/src/duckdb/src/function/table/system/test_all_types.cpp +48 -21
- package/src/duckdb/src/function/table/system_functions.cpp +2 -0
- package/src/duckdb/src/function/table/table_scan.cpp +29 -24
- package/src/duckdb/src/function/table/version/pragma_version.cpp +49 -2
- package/src/duckdb/src/function/table_macro_function.cpp +0 -10
- package/src/duckdb/src/include/duckdb/catalog/catalog.hpp +23 -5
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/duck_index_entry.hpp +2 -0
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/index_catalog_entry.hpp +3 -3
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/macro_catalog_entry.hpp +1 -4
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/schema_catalog_entry.hpp +2 -7
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/sequence_catalog_entry.hpp +1 -8
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/table_catalog_entry.hpp +2 -13
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/type_catalog_entry.hpp +1 -6
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/view_catalog_entry.hpp +2 -5
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry.hpp +9 -0
- package/src/duckdb/src/include/duckdb/catalog/catalog_set.hpp +0 -6
- package/src/duckdb/src/include/duckdb/catalog/duck_catalog.hpp +1 -0
- package/src/duckdb/src/include/duckdb/common/adbc/adbc.h +1 -0
- package/src/duckdb/src/include/duckdb/common/adbc/adbc.hpp +4 -1
- package/src/duckdb/src/include/duckdb/common/adbc/single_batch_array_stream.hpp +16 -0
- package/src/duckdb/src/include/duckdb/common/allocator.hpp +2 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/append_data.hpp +109 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/bool_data.hpp +15 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/enum_data.hpp +69 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/list.hpp +8 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/list_data.hpp +18 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/map_data.hpp +18 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/scalar_data.hpp +88 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/struct_data.hpp +18 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/union_data.hpp +21 -0
- package/src/duckdb/src/include/duckdb/common/arrow/appender/varchar_data.hpp +105 -0
- package/src/duckdb/src/include/duckdb/common/arrow/arrow_appender.hpp +9 -4
- package/src/duckdb/src/include/duckdb/common/arrow/arrow_converter.hpp +3 -5
- package/src/duckdb/src/include/duckdb/common/arrow/arrow_wrapper.hpp +5 -3
- package/src/duckdb/src/include/duckdb/common/arrow/nanoarrow/nanoarrow.h +462 -0
- package/src/duckdb/src/include/duckdb/common/arrow/nanoarrow/nanoarrow.hpp +14 -0
- package/src/duckdb/src/include/duckdb/common/arrow/result_arrow_wrapper.hpp +4 -0
- package/src/duckdb/src/include/duckdb/common/assert.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/bitpacking.hpp +70 -55
- package/src/duckdb/src/include/duckdb/common/box_renderer.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/bswap.hpp +42 -0
- package/src/duckdb/src/include/duckdb/common/case_insensitive_map.hpp +1 -0
- package/src/duckdb/src/include/duckdb/common/constants.hpp +6 -15
- package/src/duckdb/src/include/duckdb/common/dl.hpp +3 -1
- package/src/duckdb/src/include/duckdb/common/enum_util.hpp +689 -577
- package/src/duckdb/src/include/duckdb/common/enums/cte_materialize.hpp +21 -0
- package/src/duckdb/src/include/duckdb/common/enums/date_part_specifier.hpp +18 -2
- package/src/duckdb/src/include/duckdb/common/enums/index_type.hpp +4 -3
- package/src/duckdb/src/include/duckdb/common/enums/joinref_type.hpp +2 -1
- package/src/duckdb/src/include/duckdb/common/enums/logical_operator_type.hpp +2 -0
- package/src/duckdb/src/include/duckdb/common/enums/operator_result_type.hpp +5 -1
- package/src/duckdb/src/include/duckdb/common/enums/optimizer_type.hpp +2 -0
- package/src/duckdb/src/include/duckdb/common/enums/pending_execution_result.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/enums/physical_operator_type.hpp +2 -0
- package/src/duckdb/src/include/duckdb/common/exception.hpp +15 -1
- package/src/duckdb/src/include/duckdb/common/extra_operator_info.hpp +27 -0
- package/src/duckdb/src/include/duckdb/common/extra_type_info.hpp +185 -0
- package/src/duckdb/src/include/duckdb/common/file_opener.hpp +9 -0
- package/src/duckdb/src/include/duckdb/common/file_system.hpp +10 -8
- package/src/duckdb/src/include/duckdb/common/filename_pattern.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/fixed_size_map.hpp +208 -0
- package/src/duckdb/src/include/duckdb/common/helper.hpp +8 -3
- package/src/duckdb/src/include/duckdb/common/hive_partitioning.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/http_state.hpp +61 -28
- package/src/duckdb/src/include/duckdb/common/hugeint.hpp +15 -0
- package/src/duckdb/src/include/duckdb/common/index_vector.hpp +12 -0
- package/src/duckdb/src/include/duckdb/common/limits.hpp +52 -149
- package/src/duckdb/src/include/duckdb/common/multi_file_reader.hpp +14 -7
- package/src/duckdb/src/include/duckdb/common/multi_file_reader_options.hpp +10 -44
- package/src/duckdb/src/include/duckdb/common/mutex.hpp +3 -0
- package/src/duckdb/src/include/duckdb/common/numeric_utils.hpp +48 -0
- package/src/duckdb/src/include/duckdb/common/opener_file_system.hpp +6 -2
- package/src/duckdb/src/include/duckdb/common/operator/add.hpp +5 -2
- package/src/duckdb/src/include/duckdb/common/operator/cast_operators.hpp +92 -4
- package/src/duckdb/src/include/duckdb/common/operator/comparison_operators.hpp +38 -2
- package/src/duckdb/src/include/duckdb/common/operator/multiply.hpp +3 -2
- package/src/duckdb/src/include/duckdb/common/operator/numeric_cast.hpp +10 -0
- package/src/duckdb/src/include/duckdb/common/operator/string_cast.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/operator/subtract.hpp +3 -2
- package/src/duckdb/src/include/duckdb/common/optional_idx.hpp +4 -1
- package/src/duckdb/src/include/duckdb/common/perfect_map_set.hpp +2 -1
- package/src/duckdb/src/include/duckdb/common/printer.hpp +11 -0
- package/src/duckdb/src/include/duckdb/common/radix.hpp +9 -20
- package/src/duckdb/src/include/duckdb/common/radix_partitioning.hpp +6 -21
- package/src/duckdb/src/include/duckdb/common/row_operations/row_matcher.hpp +63 -0
- package/src/duckdb/src/include/duckdb/common/row_operations/row_operations.hpp +3 -3
- package/src/duckdb/src/include/duckdb/common/serializer/binary_deserializer.hpp +103 -41
- package/src/duckdb/src/include/duckdb/common/serializer/binary_serializer.hpp +59 -42
- package/src/duckdb/src/include/duckdb/common/serializer/buffered_file_reader.hpp +4 -10
- package/src/duckdb/src/include/duckdb/common/serializer/buffered_file_writer.hpp +3 -3
- package/src/duckdb/src/include/duckdb/common/serializer/deserialization_data.hpp +181 -0
- package/src/duckdb/src/include/duckdb/common/serializer/{format_deserializer.hpp → deserializer.hpp} +222 -134
- package/src/duckdb/src/include/duckdb/common/serializer/encoding_util.hpp +132 -0
- package/src/duckdb/src/include/duckdb/common/serializer/memory_stream.hpp +62 -0
- package/src/duckdb/src/include/duckdb/common/serializer/read_stream.hpp +38 -0
- package/src/duckdb/src/include/duckdb/common/serializer/serialization_traits.hpp +172 -19
- package/src/duckdb/src/include/duckdb/common/serializer/serializer.hpp +307 -0
- package/src/duckdb/src/include/duckdb/common/serializer/write_stream.hpp +36 -0
- package/src/duckdb/src/include/duckdb/common/shared_ptr.hpp +8 -0
- package/src/duckdb/src/include/duckdb/common/sort/partition_state.hpp +48 -17
- package/src/duckdb/src/include/duckdb/common/stack_checker.hpp +34 -0
- package/src/duckdb/src/include/duckdb/common/string_util.hpp +11 -0
- package/src/duckdb/src/include/duckdb/common/type_util.hpp +8 -0
- package/src/duckdb/src/include/duckdb/common/typedefs.hpp +8 -0
- package/src/duckdb/src/include/duckdb/common/types/batched_data_collection.hpp +3 -1
- package/src/duckdb/src/include/duckdb/common/types/bit.hpp +81 -0
- package/src/duckdb/src/include/duckdb/common/types/column/column_data_allocator.hpp +11 -1
- package/src/duckdb/src/include/duckdb/common/types/column/column_data_collection.hpp +12 -1
- package/src/duckdb/src/include/duckdb/common/types/column/column_data_collection_segment.hpp +3 -1
- package/src/duckdb/src/include/duckdb/common/types/column/column_data_scan_states.hpp +3 -1
- package/src/duckdb/src/include/duckdb/common/types/data_chunk.hpp +4 -6
- package/src/duckdb/src/include/duckdb/common/types/date.hpp +9 -5
- package/src/duckdb/src/include/duckdb/common/types/datetime.hpp +46 -3
- package/src/duckdb/src/include/duckdb/common/types/hyperloglog.hpp +6 -6
- package/src/duckdb/src/include/duckdb/common/types/interval.hpp +7 -0
- package/src/duckdb/src/include/duckdb/common/types/list_segment.hpp +11 -15
- package/src/duckdb/src/include/duckdb/common/types/row/partitioned_tuple_data.hpp +46 -11
- package/src/duckdb/src/include/duckdb/common/types/row/row_data_collection_scanner.hpp +10 -1
- package/src/duckdb/src/include/duckdb/common/types/row/row_layout.hpp +1 -23
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_allocator.hpp +14 -8
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_collection.hpp +15 -5
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_layout.hpp +7 -0
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_segment.hpp +13 -8
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_states.hpp +8 -4
- package/src/duckdb/src/include/duckdb/common/types/string_heap.hpp +3 -0
- package/src/duckdb/src/include/duckdb/common/types/string_type.hpp +9 -0
- package/src/duckdb/src/include/duckdb/common/types/time.hpp +5 -0
- package/src/duckdb/src/include/duckdb/common/types/timestamp.hpp +16 -10
- package/src/duckdb/src/include/duckdb/common/types/validity_mask.hpp +7 -1
- package/src/duckdb/src/include/duckdb/common/types/value.hpp +8 -7
- package/src/duckdb/src/include/duckdb/common/types/vector.hpp +13 -11
- package/src/duckdb/src/include/duckdb/common/types.hpp +8 -35
- package/src/duckdb/src/include/duckdb/common/vector.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/vector_operations/aggregate_executor.hpp +7 -2
- package/src/duckdb/src/include/duckdb/common/virtual_file_system.hpp +40 -97
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/algebraic/corr.hpp +4 -4
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/algebraic/covar.hpp +3 -1
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/algebraic_functions.hpp +3 -1
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/distributive_functions.hpp +4 -2
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/holistic_functions.hpp +3 -1
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/nested_functions.hpp +3 -1
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/regression/regr_count.hpp +1 -0
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/regression/regr_slope.hpp +3 -3
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/regression_functions.hpp +3 -1
- package/src/duckdb/src/include/duckdb/core_functions/scalar/bit_functions.hpp +7 -5
- package/src/duckdb/src/include/duckdb/core_functions/scalar/blob_functions.hpp +7 -5
- package/src/duckdb/src/include/duckdb/core_functions/scalar/date_functions.hpp +44 -15
- package/src/duckdb/src/include/duckdb/core_functions/scalar/debug_functions.hpp +27 -0
- package/src/duckdb/src/include/duckdb/core_functions/scalar/enum_functions.hpp +10 -8
- package/src/duckdb/src/include/duckdb/core_functions/scalar/generic_functions.hpp +15 -13
- package/src/duckdb/src/include/duckdb/core_functions/scalar/list_functions.hpp +66 -13
- package/src/duckdb/src/include/duckdb/core_functions/scalar/map_functions.hpp +6 -4
- package/src/duckdb/src/include/duckdb/core_functions/scalar/math_functions.hpp +38 -36
- package/src/duckdb/src/include/duckdb/core_functions/scalar/operators_functions.hpp +6 -4
- package/src/duckdb/src/include/duckdb/core_functions/scalar/random_functions.hpp +6 -4
- package/src/duckdb/src/include/duckdb/core_functions/scalar/string_functions.hpp +34 -14
- package/src/duckdb/src/include/duckdb/core_functions/scalar/struct_functions.hpp +10 -5
- package/src/duckdb/src/include/duckdb/core_functions/scalar/union_functions.hpp +5 -3
- package/src/duckdb/src/include/duckdb/execution/aggregate_hashtable.hpp +132 -131
- package/src/duckdb/src/include/duckdb/execution/executor.hpp +3 -0
- package/src/duckdb/src/include/duckdb/execution/index/art/art.hpp +27 -16
- package/src/duckdb/src/include/duckdb/execution/index/art/art_key.hpp +0 -1
- package/src/duckdb/src/include/duckdb/execution/index/art/iterator.hpp +36 -32
- package/src/duckdb/src/include/duckdb/execution/index/art/leaf.hpp +47 -56
- package/src/duckdb/src/include/duckdb/execution/index/art/node.hpp +67 -64
- package/src/duckdb/src/include/duckdb/execution/index/art/node16.hpp +17 -20
- package/src/duckdb/src/include/duckdb/execution/index/art/node256.hpp +17 -25
- package/src/duckdb/src/include/duckdb/execution/index/art/node4.hpp +19 -22
- package/src/duckdb/src/include/duckdb/execution/index/art/node48.hpp +17 -26
- package/src/duckdb/src/include/duckdb/execution/index/art/prefix.hpp +60 -55
- package/src/duckdb/src/include/duckdb/execution/index/fixed_size_allocator.hpp +120 -0
- package/src/duckdb/src/include/duckdb/execution/index/fixed_size_buffer.hpp +109 -0
- package/src/duckdb/src/include/duckdb/execution/index/index_pointer.hpp +96 -0
- package/src/duckdb/src/include/duckdb/execution/join_hashtable.hpp +14 -8
- package/src/duckdb/src/include/duckdb/execution/operator/aggregate/physical_hash_aggregate.hpp +8 -7
- package/src/duckdb/src/include/duckdb/execution/operator/aggregate/physical_perfecthash_aggregate.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/aggregate/physical_ungrouped_aggregate.hpp +3 -3
- package/src/duckdb/src/include/duckdb/execution/operator/aggregate/physical_window.hpp +6 -5
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_batch_collector.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_explain_analyze.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_limit.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_materialized_collector.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_vacuum.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_asof_join.hpp +5 -12
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_blockwise_nl_join.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_delim_join.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_hash_join.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_iejoin.hpp +3 -3
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_nested_loop_join.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_piecewise_merge_join.hpp +3 -3
- package/src/duckdb/src/include/duckdb/execution/operator/join/physical_range_join.hpp +12 -1
- package/src/duckdb/src/include/duckdb/execution/operator/order/physical_order.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/order/physical_top_n.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/csv_rejects_table.hpp +36 -0
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/physical_batch_copy_to_file.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/physical_batch_insert.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/physical_copy_to_file.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/physical_fixed_batch_copy.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/physical_insert.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/physical_update.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/{persistent → scan/csv}/base_csv_reader.hpp +23 -19
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/buffered_csv_reader.hpp +72 -0
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/csv_buffer.hpp +110 -0
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/csv_buffer_manager.hpp +103 -0
- package/src/duckdb/src/include/duckdb/execution/operator/{persistent → scan/csv}/csv_file_handle.hpp +8 -15
- package/src/duckdb/src/include/duckdb/execution/operator/{persistent → scan/csv}/csv_line_info.hpp +9 -4
- package/src/duckdb/src/include/duckdb/execution/operator/{persistent → scan/csv}/csv_reader_options.hpp +79 -33
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/csv_sniffer.hpp +129 -0
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/csv_state_machine.hpp +75 -0
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/csv_state_machine_cache.hpp +51 -0
- package/src/duckdb/src/include/duckdb/execution/operator/{persistent → scan/csv}/parallel_csv_reader.hpp +23 -28
- package/src/duckdb/src/include/duckdb/execution/operator/scan/csv/quote_rules.hpp +21 -0
- package/src/duckdb/src/include/duckdb/execution/operator/scan/physical_column_data_scan.hpp +10 -0
- package/src/duckdb/src/include/duckdb/execution/operator/scan/physical_table_scan.hpp +5 -5
- package/src/duckdb/src/include/duckdb/execution/operator/schema/{physical_create_index.hpp → physical_create_art_index.hpp} +14 -7
- package/src/duckdb/src/include/duckdb/execution/operator/set/physical_cte.hpp +62 -0
- package/src/duckdb/src/include/duckdb/execution/operator/set/physical_recursive_cte.hpp +8 -2
- package/src/duckdb/src/include/duckdb/execution/perfect_aggregate_hashtable.hpp +4 -2
- package/src/duckdb/src/include/duckdb/execution/physical_operator.hpp +3 -5
- package/src/duckdb/src/include/duckdb/execution/physical_operator_states.hpp +11 -0
- package/src/duckdb/src/include/duckdb/execution/physical_plan_generator.hpp +6 -2
- package/src/duckdb/src/include/duckdb/execution/radix_partitioned_hashtable.hpp +18 -21
- package/src/duckdb/src/include/duckdb/execution/window_executor.hpp +313 -0
- package/src/duckdb/src/include/duckdb/execution/window_segment_tree.hpp +79 -63
- package/src/duckdb/src/include/duckdb/function/aggregate_function.hpp +3 -5
- package/src/duckdb/src/include/duckdb/function/aggregate_state.hpp +2 -2
- package/src/duckdb/src/include/duckdb/function/built_in_functions.hpp +1 -0
- package/src/duckdb/src/include/duckdb/function/cast/bound_cast_data.hpp +32 -0
- package/src/duckdb/src/include/duckdb/function/compression_function.hpp +36 -4
- package/src/duckdb/src/include/duckdb/function/copy_function.hpp +11 -4
- package/src/duckdb/src/include/duckdb/function/function_serialization.hpp +58 -61
- package/src/duckdb/src/include/duckdb/function/macro_function.hpp +1 -4
- package/src/duckdb/src/include/duckdb/function/scalar/compressed_materialization_functions.hpp +49 -0
- package/src/duckdb/src/include/duckdb/function/scalar/list/contains_or_position.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/scalar/nested_functions.hpp +14 -10
- package/src/duckdb/src/include/duckdb/function/scalar/strftime_format.hpp +14 -5
- package/src/duckdb/src/include/duckdb/function/scalar/string_functions.hpp +2 -0
- package/src/duckdb/src/include/duckdb/function/scalar_function.hpp +2 -7
- package/src/duckdb/src/include/duckdb/function/scalar_macro_function.hpp +2 -4
- package/src/duckdb/src/include/duckdb/function/table/arrow/arrow_duck_schema.hpp +99 -0
- package/src/duckdb/src/include/duckdb/function/table/arrow.hpp +11 -36
- package/src/duckdb/src/include/duckdb/function/table/read_csv.hpp +22 -22
- package/src/duckdb/src/include/duckdb/function/table/system_functions.hpp +9 -1
- package/src/duckdb/src/include/duckdb/function/table_function.hpp +2 -3
- package/src/duckdb/src/include/duckdb/function/table_macro_function.hpp +2 -4
- package/src/duckdb/src/include/duckdb/function/udf_function.hpp +2 -1
- package/src/duckdb/src/include/duckdb/main/attached_database.hpp +1 -1
- package/src/duckdb/src/include/duckdb/main/capi/capi_internal.hpp +4 -3
- package/src/duckdb/src/include/duckdb/main/chunk_scan_state/query_result.hpp +29 -0
- package/src/duckdb/src/include/duckdb/main/chunk_scan_state.hpp +43 -0
- package/src/duckdb/src/include/duckdb/main/client_config.hpp +9 -2
- package/src/duckdb/src/include/duckdb/main/client_context.hpp +16 -14
- package/src/duckdb/src/include/duckdb/main/client_context_file_opener.hpp +1 -0
- package/src/duckdb/src/include/duckdb/main/client_data.hpp +2 -1
- package/src/duckdb/src/include/duckdb/main/client_properties.hpp +25 -0
- package/src/duckdb/src/include/duckdb/main/config.hpp +19 -1
- package/src/duckdb/src/include/duckdb/main/connection.hpp +3 -4
- package/src/duckdb/src/include/duckdb/main/extension/generated_extension_loader.hpp +27 -0
- package/src/duckdb/src/include/duckdb/main/extension_entries.hpp +258 -144
- package/src/duckdb/src/include/duckdb/main/extension_helper.hpp +42 -6
- package/src/duckdb/src/include/duckdb/main/extension_util.hpp +18 -0
- package/src/duckdb/src/include/duckdb/main/pending_query_result.hpp +5 -0
- package/src/duckdb/src/include/duckdb/main/prepared_statement.hpp +73 -5
- package/src/duckdb/src/include/duckdb/main/prepared_statement_data.hpp +7 -6
- package/src/duckdb/src/include/duckdb/main/query_result.hpp +3 -28
- package/src/duckdb/src/include/duckdb/main/relation/aggregate_relation.hpp +4 -1
- package/src/duckdb/src/include/duckdb/main/relation/cross_product_relation.hpp +4 -1
- package/src/duckdb/src/include/duckdb/main/relation/join_relation.hpp +5 -2
- package/src/duckdb/src/include/duckdb/main/relation/read_csv_relation.hpp +7 -7
- package/src/duckdb/src/include/duckdb/main/relation/table_function_relation.hpp +1 -0
- package/src/duckdb/src/include/duckdb/main/relation.hpp +17 -4
- package/src/duckdb/src/include/duckdb/main/settings.hpp +72 -12
- package/src/duckdb/src/include/duckdb/optimizer/column_binding_replacer.hpp +47 -0
- package/src/duckdb/src/include/duckdb/optimizer/compressed_materialization.hpp +132 -0
- package/src/duckdb/src/include/duckdb/optimizer/deliminator.hpp +13 -16
- package/src/duckdb/src/include/duckdb/optimizer/filter_pushdown.hpp +7 -0
- package/src/duckdb/src/include/duckdb/optimizer/join_order/cardinality_estimator.hpp +38 -64
- package/src/duckdb/src/include/duckdb/optimizer/join_order/cost_model.hpp +37 -0
- package/src/duckdb/src/include/duckdb/optimizer/join_order/estimated_properties.hpp +10 -1
- package/src/duckdb/src/include/duckdb/optimizer/join_order/join_node.hpp +14 -29
- package/src/duckdb/src/include/duckdb/optimizer/join_order/join_order_optimizer.hpp +8 -22
- package/src/duckdb/src/include/duckdb/optimizer/join_order/join_relation.hpp +1 -12
- package/src/duckdb/src/include/duckdb/optimizer/join_order/plan_enumerator.hpp +89 -0
- package/src/duckdb/src/include/duckdb/optimizer/join_order/query_graph.hpp +19 -30
- package/src/duckdb/src/include/duckdb/optimizer/join_order/query_graph_manager.hpp +113 -0
- package/src/duckdb/src/include/duckdb/optimizer/join_order/relation_manager.hpp +73 -0
- package/src/duckdb/src/include/duckdb/optimizer/join_order/relation_statistics_helper.hpp +73 -0
- package/src/duckdb/src/include/duckdb/optimizer/matcher/set_matcher.hpp +13 -0
- package/src/duckdb/src/include/duckdb/optimizer/optimizer.hpp +3 -0
- package/src/duckdb/src/include/duckdb/optimizer/remove_duplicate_groups.hpp +40 -0
- package/src/duckdb/src/include/duckdb/optimizer/rule/empty_needle_removal.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/statistics_propagator.hpp +11 -3
- package/src/duckdb/src/include/duckdb/optimizer/topn_optimizer.hpp +2 -0
- package/src/duckdb/src/include/duckdb/parallel/event.hpp +12 -1
- package/src/duckdb/src/include/duckdb/parallel/pipeline.hpp +2 -3
- package/src/duckdb/src/include/duckdb/parallel/pipeline_executor.hpp +3 -2
- package/src/duckdb/src/include/duckdb/parallel/task_scheduler.hpp +9 -1
- package/src/duckdb/src/include/duckdb/parser/column_definition.hpp +4 -6
- package/src/duckdb/src/include/duckdb/parser/column_list.hpp +3 -3
- package/src/duckdb/src/include/duckdb/parser/common_table_expression_info.hpp +4 -2
- package/src/duckdb/src/include/duckdb/parser/constraint.hpp +3 -8
- package/src/duckdb/src/include/duckdb/parser/constraints/check_constraint.hpp +2 -2
- package/src/duckdb/src/include/duckdb/parser/constraints/foreign_key_constraint.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/constraints/not_null_constraint.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/constraints/unique_constraint.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/between_expression.hpp +5 -5
- package/src/duckdb/src/include/duckdb/parser/expression/bound_expression.hpp +1 -4
- package/src/duckdb/src/include/duckdb/parser/expression/case_expression.hpp +4 -6
- package/src/duckdb/src/include/duckdb/parser/expression/cast_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/collate_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/columnref_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/comparison_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/conjunction_expression.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/expression/constant_expression.hpp +4 -4
- package/src/duckdb/src/include/duckdb/parser/expression/default_expression.hpp +2 -3
- package/src/duckdb/src/include/duckdb/parser/expression/function_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/lambda_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/operator_expression.hpp +22 -7
- package/src/duckdb/src/include/duckdb/parser/expression/parameter_expression.hpp +19 -5
- package/src/duckdb/src/include/duckdb/parser/expression/positional_reference_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/expression/star_expression.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/expression/subquery_expression.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/expression/window_expression.hpp +5 -4
- package/src/duckdb/src/include/duckdb/parser/group_by_node.hpp +11 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_info.hpp +12 -4
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_scalar_function_info.hpp +0 -2
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_table_function_info.hpp +0 -2
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_table_info.hpp +66 -29
- package/src/duckdb/src/include/duckdb/parser/parsed_data/attach_info.hpp +6 -2
- package/src/duckdb/src/include/duckdb/parser/parsed_data/copy_info.hpp +8 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_collation_info.hpp +0 -3
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_copy_function_info.hpp +0 -3
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_function_info.hpp +0 -5
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_index_info.hpp +7 -4
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_info.hpp +7 -12
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_macro_info.hpp +2 -5
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_schema_info.hpp +2 -9
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_sequence_info.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_table_info.hpp +3 -5
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_type_info.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_view_info.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/parsed_data/detach_info.hpp +6 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/drop_info.hpp +6 -2
- package/src/duckdb/src/include/duckdb/parser/parsed_data/exported_table_data.hpp +7 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/load_info.hpp +14 -19
- package/src/duckdb/src/include/duckdb/parser/parsed_data/parse_info.hpp +22 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/pragma_info.hpp +10 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/sample_options.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/parsed_data/show_select_info.hpp +7 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/transaction_info.hpp +8 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/vacuum_info.hpp +9 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_expression.hpp +3 -16
- package/src/duckdb/src/include/duckdb/parser/parser.hpp +4 -0
- package/src/duckdb/src/include/duckdb/parser/query_node/cte_node.hpp +52 -0
- package/src/duckdb/src/include/duckdb/parser/query_node/list.hpp +1 -0
- package/src/duckdb/src/include/duckdb/parser/query_node/recursive_cte_node.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/query_node/select_node.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/query_node/set_operation_node.hpp +2 -4
- package/src/duckdb/src/include/duckdb/parser/query_node.hpp +9 -15
- package/src/duckdb/src/include/duckdb/parser/result_modifier.hpp +14 -32
- package/src/duckdb/src/include/duckdb/parser/statement/execute_statement.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/statement/select_statement.hpp +4 -9
- package/src/duckdb/src/include/duckdb/parser/tableref/basetableref.hpp +2 -6
- package/src/duckdb/src/include/duckdb/parser/tableref/emptytableref.hpp +2 -5
- package/src/duckdb/src/include/duckdb/parser/tableref/expressionlistref.hpp +2 -6
- package/src/duckdb/src/include/duckdb/parser/tableref/joinref.hpp +3 -7
- package/src/duckdb/src/include/duckdb/parser/tableref/pivotref.hpp +6 -14
- package/src/duckdb/src/include/duckdb/parser/tableref/subqueryref.hpp +5 -6
- package/src/duckdb/src/include/duckdb/parser/tableref/table_function_ref.hpp +2 -6
- package/src/duckdb/src/include/duckdb/parser/tableref.hpp +2 -10
- package/src/duckdb/src/include/duckdb/parser/tokens.hpp +1 -0
- package/src/duckdb/src/include/duckdb/parser/transformer.hpp +24 -26
- package/src/duckdb/src/include/duckdb/planner/binder.hpp +16 -5
- package/src/duckdb/src/include/duckdb/planner/bound_constraint.hpp +0 -9
- package/src/duckdb/src/include/duckdb/planner/bound_parameter_map.hpp +30 -2
- package/src/duckdb/src/include/duckdb/planner/bound_result_modifier.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/bound_tokens.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/column_binding.hpp +9 -0
- package/src/duckdb/src/include/duckdb/planner/constraints/bound_unique_constraint.hpp +3 -3
- package/src/duckdb/src/include/duckdb/planner/expression/bound_aggregate_expression.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_between_expression.hpp +6 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_case_expression.hpp +3 -3
- package/src/duckdb/src/include/duckdb/planner/expression/bound_cast_expression.hpp +5 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_columnref_expression.hpp +2 -5
- package/src/duckdb/src/include/duckdb/planner/expression/bound_comparison_expression.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_conjunction_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_constant_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_default_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_function_expression.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_lambda_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_lambdaref_expression.hpp +2 -5
- package/src/duckdb/src/include/duckdb/planner/expression/bound_operator_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_parameter_data.hpp +12 -29
- package/src/duckdb/src/include/duckdb/planner/expression/bound_parameter_expression.hpp +9 -5
- package/src/duckdb/src/include/duckdb/planner/expression/bound_reference_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_subquery_expression.hpp +0 -3
- package/src/duckdb/src/include/duckdb/planner/expression/bound_unnest_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/bound_window_expression.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/expression/list.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/expression.hpp +2 -11
- package/src/duckdb/src/include/duckdb/planner/expression_binder/base_select_binder.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/expression_binder/lateral_binder.hpp +0 -2
- package/src/duckdb/src/include/duckdb/planner/expression_binder.hpp +13 -1
- package/src/duckdb/src/include/duckdb/planner/extension_callback.hpp +26 -0
- package/src/duckdb/src/include/duckdb/planner/filter/conjunction_filter.hpp +4 -4
- package/src/duckdb/src/include/duckdb/planner/filter/constant_filter.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/filter/null_filter.hpp +4 -4
- package/src/duckdb/src/include/duckdb/planner/joinside.hpp +1 -3
- package/src/duckdb/src/include/duckdb/planner/logical_operator.hpp +2 -16
- package/src/duckdb/src/include/duckdb/planner/logical_tokens.hpp +1 -2
- package/src/duckdb/src/include/duckdb/planner/operator/list.hpp +3 -3
- package/src/duckdb/src/include/duckdb/planner/operator/logical_aggregate.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_any_join.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_column_data_get.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_comparison_join.hpp +12 -11
- package/src/duckdb/src/include/duckdb/planner/operator/logical_copy_to_file.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_create.hpp +8 -8
- package/src/duckdb/src/include/duckdb/planner/operator/logical_create_index.hpp +11 -25
- package/src/duckdb/src/include/duckdb/planner/operator/logical_create_table.hpp +8 -8
- package/src/duckdb/src/include/duckdb/planner/operator/logical_cross_product.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_cteref.hpp +9 -4
- package/src/duckdb/src/include/duckdb/planner/operator/logical_delete.hpp +6 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_delim_get.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_dependent_join.hpp +42 -0
- package/src/duckdb/src/include/duckdb/planner/operator/logical_distinct.hpp +6 -12
- package/src/duckdb/src/include/duckdb/planner/operator/logical_dummy_scan.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_empty_result.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_execute.hpp +0 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_explain.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_export.hpp +0 -3
- package/src/duckdb/src/include/duckdb/planner/operator/logical_expression_get.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_extension_operator.hpp +7 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_filter.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_get.hpp +11 -3
- package/src/duckdb/src/include/duckdb/planner/operator/logical_insert.hpp +5 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_join.hpp +1 -3
- package/src/duckdb/src/include/duckdb/planner/operator/logical_limit.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_limit_percent.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_materialized_cte.hpp +50 -0
- package/src/duckdb/src/include/duckdb/planner/operator/logical_order.hpp +6 -37
- package/src/duckdb/src/include/duckdb/planner/operator/logical_pivot.hpp +6 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_positional_join.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_pragma.hpp +0 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_prepare.hpp +0 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_projection.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_recursive_cte.hpp +10 -9
- package/src/duckdb/src/include/duckdb/planner/operator/logical_reset.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_sample.hpp +5 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_set.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_set_operation.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_show.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_simple.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_top_n.hpp +4 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_unnest.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_update.hpp +6 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_window.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator_extension.hpp +1 -2
- package/src/duckdb/src/include/duckdb/planner/parsed_data/bound_create_table_info.hpp +0 -5
- package/src/duckdb/src/include/duckdb/planner/planner.hpp +5 -4
- package/src/duckdb/src/include/duckdb/planner/query_node/bound_cte_node.hpp +44 -0
- package/src/duckdb/src/include/duckdb/planner/query_node/list.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/subquery/flatten_dependent_join.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/subquery/has_correlated_expressions.hpp +4 -1
- package/src/duckdb/src/include/duckdb/planner/subquery/recursive_dependent_join_planner.hpp +31 -0
- package/src/duckdb/src/include/duckdb/planner/subquery/rewrite_correlated_expressions.hpp +8 -2
- package/src/duckdb/src/include/duckdb/planner/table_filter.hpp +4 -7
- package/src/duckdb/src/include/duckdb/planner/tableref/bound_cteref.hpp +5 -2
- package/src/duckdb/src/include/duckdb/planner/tableref/bound_pivotref.hpp +3 -0
- package/src/duckdb/src/include/duckdb/storage/arena_allocator.hpp +2 -1
- package/src/duckdb/src/include/duckdb/storage/block.hpp +36 -4
- package/src/duckdb/src/include/duckdb/storage/block_manager.hpp +11 -11
- package/src/duckdb/src/include/duckdb/storage/buffer/block_handle.hpp +3 -0
- package/src/duckdb/src/include/duckdb/storage/checkpoint/row_group_writer.hpp +8 -7
- package/src/duckdb/src/include/duckdb/storage/checkpoint/string_checkpoint_state.hpp +27 -4
- package/src/duckdb/src/include/duckdb/storage/checkpoint/table_data_reader.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/checkpoint/table_data_writer.hpp +7 -7
- package/src/duckdb/src/include/duckdb/storage/checkpoint/write_overflow_strings_to_disk.hpp +4 -2
- package/src/duckdb/src/include/duckdb/storage/checkpoint_manager.hpp +29 -24
- package/src/duckdb/src/include/duckdb/storage/compression/bitpacking.hpp +1 -8
- package/src/duckdb/src/include/duckdb/storage/data_pointer.hpp +31 -4
- package/src/duckdb/src/include/duckdb/storage/data_table.hpp +4 -4
- package/src/duckdb/src/include/duckdb/storage/database_size.hpp +6 -0
- package/src/duckdb/src/include/duckdb/storage/in_memory_block_manager.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/index.hpp +12 -10
- package/src/duckdb/src/include/duckdb/storage/metadata/metadata_manager.hpp +91 -0
- package/src/duckdb/src/include/duckdb/storage/metadata/metadata_reader.hpp +57 -0
- package/src/duckdb/src/include/duckdb/storage/metadata/metadata_writer.hpp +52 -0
- package/src/duckdb/src/include/duckdb/storage/object_cache.hpp +22 -0
- package/src/duckdb/src/include/duckdb/storage/partial_block_manager.hpp +37 -21
- package/src/duckdb/src/include/duckdb/storage/single_file_block_manager.hpp +8 -5
- package/src/duckdb/src/include/duckdb/storage/statistics/base_statistics.hpp +3 -8
- package/src/duckdb/src/include/duckdb/storage/statistics/column_statistics.hpp +3 -1
- package/src/duckdb/src/include/duckdb/storage/statistics/distinct_statistics.hpp +4 -7
- package/src/duckdb/src/include/duckdb/storage/statistics/list_stats.hpp +2 -4
- package/src/duckdb/src/include/duckdb/storage/statistics/node_statistics.hpp +0 -26
- package/src/duckdb/src/include/duckdb/storage/statistics/numeric_stats.hpp +2 -4
- package/src/duckdb/src/include/duckdb/storage/statistics/string_stats.hpp +6 -4
- package/src/duckdb/src/include/duckdb/storage/statistics/struct_stats.hpp +2 -4
- package/src/duckdb/src/include/duckdb/storage/storage_info.hpp +25 -8
- package/src/duckdb/src/include/duckdb/storage/storage_manager.hpp +4 -2
- package/src/duckdb/src/include/duckdb/storage/string_uncompressed.hpp +6 -1
- package/src/duckdb/src/include/duckdb/storage/table/chunk_info.hpp +28 -16
- package/src/duckdb/src/include/duckdb/storage/table/column_checkpoint_state.hpp +5 -20
- package/src/duckdb/src/include/duckdb/storage/table/column_data.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/table/column_segment.hpp +7 -3
- package/src/duckdb/src/include/duckdb/storage/table/list_column_data.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/persistent_table_data.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/table/row_group.hpp +21 -21
- package/src/duckdb/src/include/duckdb/storage/table/row_group_collection.hpp +4 -4
- package/src/duckdb/src/include/duckdb/storage/table/row_group_segment_tree.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/table/row_version_manager.hpp +59 -0
- package/src/duckdb/src/include/duckdb/storage/table/standard_column_data.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/table/table_index_list.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/table_statistics.hpp +4 -2
- package/src/duckdb/src/include/duckdb/storage/table/update_segment.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table_io_manager.hpp +3 -0
- package/src/duckdb/src/include/duckdb/storage/table_storage_info.hpp +1 -0
- package/src/duckdb/src/include/duckdb/storage/write_ahead_log.hpp +29 -32
- package/src/duckdb/src/include/duckdb/transaction/commit_state.hpp +1 -6
- package/src/duckdb/src/include/duckdb/transaction/delete_info.hpp +3 -2
- package/src/duckdb/src/include/duckdb/transaction/duck_transaction.hpp +4 -2
- package/src/duckdb/src/include/duckdb/transaction/local_storage.hpp +3 -4
- package/src/duckdb/src/include/duckdb/transaction/undo_buffer.hpp +0 -1
- package/src/duckdb/src/include/duckdb/verification/prepared_statement_verifier.hpp +1 -1
- package/src/duckdb/src/include/duckdb/verification/statement_verifier.hpp +0 -1
- package/src/duckdb/src/include/duckdb.h +101 -4
- package/src/duckdb/src/main/appender.cpp +3 -1
- package/src/duckdb/src/main/attached_database.cpp +2 -2
- package/src/duckdb/src/main/capi/arrow-c.cpp +196 -8
- package/src/duckdb/src/main/capi/duckdb-c.cpp +16 -0
- package/src/duckdb/src/main/capi/duckdb_value-c.cpp +1 -1
- package/src/duckdb/src/main/capi/logical_types-c.cpp +22 -0
- package/src/duckdb/src/main/capi/pending-c.cpp +23 -0
- package/src/duckdb/src/main/capi/prepared-c.cpp +114 -30
- package/src/duckdb/src/main/capi/result-c.cpp +3 -1
- package/src/duckdb/src/main/chunk_scan_state/query_result.cpp +53 -0
- package/src/duckdb/src/main/chunk_scan_state.cpp +48 -0
- package/src/duckdb/src/main/client_context.cpp +42 -25
- package/src/duckdb/src/main/client_context_file_opener.cpp +17 -0
- package/src/duckdb/src/main/client_verify.cpp +17 -1
- package/src/duckdb/src/main/config.cpp +10 -4
- package/src/duckdb/src/main/connection.cpp +5 -7
- package/src/duckdb/src/main/database.cpp +9 -12
- package/src/duckdb/src/main/db_instance_cache.cpp +14 -6
- package/src/duckdb/src/main/extension/extension_helper.cpp +195 -87
- package/src/duckdb/src/main/extension/extension_install.cpp +79 -15
- package/src/duckdb/src/main/extension/extension_load.cpp +63 -14
- package/src/duckdb/src/main/extension/extension_util.cpp +72 -0
- package/src/duckdb/src/main/pending_query_result.cpp +9 -1
- package/src/duckdb/src/main/prepared_statement.cpp +38 -11
- package/src/duckdb/src/main/prepared_statement_data.cpp +23 -18
- package/src/duckdb/src/main/query_result.cpp +16 -31
- package/src/duckdb/src/main/relation/aggregate_relation.cpp +20 -10
- package/src/duckdb/src/main/relation/cross_product_relation.cpp +4 -3
- package/src/duckdb/src/main/relation/join_relation.cpp +6 -6
- package/src/duckdb/src/main/relation/read_csv_relation.cpp +38 -13
- package/src/duckdb/src/main/relation/table_function_relation.cpp +8 -2
- package/src/duckdb/src/main/relation.cpp +35 -11
- package/src/duckdb/src/main/settings/settings.cpp +134 -43
- package/src/duckdb/src/optimizer/column_binding_replacer.cpp +43 -0
- package/src/duckdb/src/optimizer/column_lifetime_analyzer.cpp +11 -7
- package/src/duckdb/src/optimizer/compressed_materialization/compress_aggregate.cpp +140 -0
- package/src/duckdb/src/optimizer/compressed_materialization/compress_distinct.cpp +42 -0
- package/src/duckdb/src/optimizer/compressed_materialization/compress_order.cpp +65 -0
- package/src/duckdb/src/optimizer/compressed_materialization.cpp +477 -0
- package/src/duckdb/src/optimizer/deliminator.cpp +180 -323
- package/src/duckdb/src/optimizer/filter_pushdown.cpp +23 -6
- package/src/duckdb/src/optimizer/join_order/cardinality_estimator.cpp +79 -325
- package/src/duckdb/src/optimizer/join_order/cost_model.cpp +19 -0
- package/src/duckdb/src/optimizer/join_order/estimated_properties.cpp +7 -0
- package/src/duckdb/src/optimizer/join_order/join_node.cpp +5 -37
- package/src/duckdb/src/optimizer/join_order/join_order_optimizer.cpp +48 -1047
- package/src/duckdb/src/optimizer/join_order/join_relation_set.cpp +2 -6
- package/src/duckdb/src/optimizer/join_order/plan_enumerator.cpp +552 -0
- package/src/duckdb/src/optimizer/join_order/query_graph.cpp +52 -41
- package/src/duckdb/src/optimizer/join_order/query_graph_manager.cpp +409 -0
- package/src/duckdb/src/optimizer/join_order/relation_manager.cpp +356 -0
- package/src/duckdb/src/optimizer/join_order/relation_statistics_helper.cpp +351 -0
- package/src/duckdb/src/optimizer/optimizer.cpp +49 -14
- package/src/duckdb/src/optimizer/pushdown/pushdown_cross_product.cpp +5 -5
- package/src/duckdb/src/optimizer/pushdown/pushdown_get.cpp +0 -1
- package/src/duckdb/src/optimizer/pushdown/pushdown_projection.cpp +34 -7
- package/src/duckdb/src/optimizer/remove_duplicate_groups.cpp +127 -0
- package/src/duckdb/src/optimizer/remove_unused_columns.cpp +4 -0
- package/src/duckdb/src/optimizer/rule/date_part_simplification.cpp +0 -3
- package/src/duckdb/src/optimizer/rule/regex_optimizations.cpp +154 -15
- package/src/duckdb/src/optimizer/statistics/expression/propagate_cast.cpp +14 -0
- package/src/duckdb/src/optimizer/statistics/operator/propagate_join.cpp +65 -8
- package/src/duckdb/src/optimizer/statistics/operator/propagate_order.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/operator/propagate_projection.cpp +0 -1
- package/src/duckdb/src/optimizer/statistics_propagator.cpp +7 -5
- package/src/duckdb/src/optimizer/topn_optimizer.cpp +27 -10
- package/src/duckdb/src/optimizer/unnest_rewriter.cpp +3 -5
- package/src/duckdb/src/parallel/executor.cpp +25 -1
- package/src/duckdb/src/parallel/pipeline.cpp +0 -17
- package/src/duckdb/src/parallel/pipeline_executor.cpp +26 -7
- package/src/duckdb/src/parallel/pipeline_finish_event.cpp +55 -1
- package/src/duckdb/src/parallel/task_scheduler.cpp +18 -2
- package/src/duckdb/src/parser/column_definition.cpp +18 -55
- package/src/duckdb/src/parser/column_list.cpp +8 -13
- package/src/duckdb/src/parser/constraint.cpp +0 -33
- package/src/duckdb/src/parser/constraints/check_constraint.cpp +0 -11
- package/src/duckdb/src/parser/constraints/foreign_key_constraint.cpp +3 -27
- package/src/duckdb/src/parser/constraints/not_null_constraint.cpp +0 -11
- package/src/duckdb/src/parser/constraints/unique_constraint.cpp +3 -24
- package/src/duckdb/src/parser/expression/between_expression.cpp +5 -31
- package/src/duckdb/src/parser/expression/case_expression.cpp +2 -54
- package/src/duckdb/src/parser/expression/cast_expression.cpp +5 -30
- package/src/duckdb/src/parser/expression/collate_expression.cpp +5 -27
- package/src/duckdb/src/parser/expression/columnref_expression.cpp +5 -25
- package/src/duckdb/src/parser/expression/comparison_expression.cpp +5 -27
- package/src/duckdb/src/parser/expression/conjunction_expression.cpp +2 -25
- package/src/duckdb/src/parser/expression/constant_expression.cpp +5 -23
- package/src/duckdb/src/parser/expression/default_expression.cpp +2 -13
- package/src/duckdb/src/parser/expression/function_expression.cpp +5 -64
- package/src/duckdb/src/parser/expression/lambda_expression.cpp +6 -28
- package/src/duckdb/src/parser/expression/operator_expression.cpp +2 -25
- package/src/duckdb/src/parser/expression/parameter_expression.cpp +7 -30
- package/src/duckdb/src/parser/expression/positional_reference_expression.cpp +6 -23
- package/src/duckdb/src/parser/expression/star_expression.cpp +2 -62
- package/src/duckdb/src/parser/expression/subquery_expression.cpp +2 -46
- package/src/duckdb/src/parser/expression/window_expression.cpp +5 -92
- package/src/duckdb/src/parser/keyword_helper.cpp +1 -1
- package/src/duckdb/src/parser/parsed_data/alter_info.cpp +4 -36
- package/src/duckdb/src/parser/parsed_data/alter_scalar_function_info.cpp +0 -18
- package/src/duckdb/src/parser/parsed_data/alter_table_function_info.cpp +0 -13
- package/src/duckdb/src/parser/parsed_data/alter_table_info.cpp +38 -188
- package/src/duckdb/src/parser/parsed_data/attach_info.cpp +0 -29
- package/src/duckdb/src/parser/parsed_data/create_collation_info.cpp +0 -4
- package/src/duckdb/src/parser/parsed_data/create_copy_function_info.cpp +0 -4
- package/src/duckdb/src/parser/parsed_data/create_index_info.cpp +2 -34
- package/src/duckdb/src/parser/parsed_data/create_info.cpp +0 -47
- package/src/duckdb/src/parser/parsed_data/create_macro_info.cpp +1 -28
- package/src/duckdb/src/parser/parsed_data/create_sequence_info.cpp +0 -29
- package/src/duckdb/src/parser/parsed_data/create_table_info.cpp +0 -23
- package/src/duckdb/src/parser/parsed_data/create_type_info.cpp +0 -22
- package/src/duckdb/src/parser/parsed_data/create_view_info.cpp +0 -23
- package/src/duckdb/src/parser/parsed_data/detach_info.cpp +1 -20
- package/src/duckdb/src/parser/parsed_data/drop_info.cpp +1 -27
- package/src/duckdb/src/parser/parsed_data/sample_options.cpp +2 -43
- package/src/duckdb/src/parser/parsed_data/transaction_info.cpp +2 -15
- package/src/duckdb/src/parser/parsed_data/vacuum_info.cpp +1 -21
- package/src/duckdb/src/parser/parsed_expression.cpp +2 -149
- package/src/duckdb/src/parser/parsed_expression_iterator.cpp +7 -0
- package/src/duckdb/src/parser/parser.cpp +62 -36
- package/src/duckdb/src/parser/query_node/cte_node.cpp +41 -0
- package/src/duckdb/src/parser/query_node/recursive_cte_node.cpp +2 -40
- package/src/duckdb/src/parser/query_node/select_node.cpp +2 -76
- package/src/duckdb/src/parser/query_node/set_operation_node.cpp +2 -32
- package/src/duckdb/src/parser/query_node.cpp +12 -104
- package/src/duckdb/src/parser/result_modifier.cpp +2 -183
- package/src/duckdb/src/parser/statement/execute_statement.cpp +2 -2
- package/src/duckdb/src/parser/statement/select_statement.cpp +2 -23
- package/src/duckdb/src/parser/tableref/basetableref.cpp +2 -40
- package/src/duckdb/src/parser/tableref/emptytableref.cpp +0 -13
- package/src/duckdb/src/parser/tableref/expressionlistref.cpp +2 -43
- package/src/duckdb/src/parser/tableref/joinref.cpp +5 -46
- package/src/duckdb/src/parser/tableref/pivotref.cpp +0 -116
- package/src/duckdb/src/parser/tableref/subqueryref.cpp +5 -28
- package/src/duckdb/src/parser/tableref/table_function.cpp +2 -32
- package/src/duckdb/src/parser/tableref.cpp +2 -96
- package/src/duckdb/src/parser/transform/constraint/transform_constraint.cpp +55 -38
- package/src/duckdb/src/parser/transform/expression/transform_array_access.cpp +13 -4
- package/src/duckdb/src/parser/transform/expression/transform_constant.cpp +55 -3
- package/src/duckdb/src/parser/transform/expression/transform_expression.cpp +2 -0
- package/src/duckdb/src/parser/transform/expression/transform_function.cpp +3 -0
- package/src/duckdb/src/parser/transform/expression/transform_multi_assign_reference.cpp +44 -0
- package/src/duckdb/src/parser/transform/expression/transform_param_ref.cpp +45 -26
- package/src/duckdb/src/parser/transform/helpers/transform_cte.cpp +19 -1
- package/src/duckdb/src/parser/transform/helpers/transform_typename.cpp +16 -1
- package/src/duckdb/src/parser/transform/statement/transform_copy.cpp +13 -0
- package/src/duckdb/src/parser/transform/statement/transform_create_index.cpp +32 -17
- package/src/duckdb/src/parser/transform/statement/transform_create_type.cpp +1 -1
- package/src/duckdb/src/parser/transform/statement/transform_delete.cpp +6 -1
- package/src/duckdb/src/parser/transform/statement/transform_insert.cpp +6 -1
- package/src/duckdb/src/parser/transform/statement/transform_load.cpp +1 -0
- package/src/duckdb/src/parser/transform/statement/transform_pivot_stmt.cpp +7 -2
- package/src/duckdb/src/parser/transform/statement/transform_pragma.cpp +14 -11
- package/src/duckdb/src/parser/transform/statement/transform_prepare.cpp +28 -6
- package/src/duckdb/src/parser/transform/statement/transform_select_node.cpp +11 -2
- package/src/duckdb/src/parser/transform/statement/transform_update.cpp +6 -1
- package/src/duckdb/src/parser/transformer.cpp +44 -25
- package/src/duckdb/src/planner/binder/expression/bind_aggregate_expression.cpp +1 -4
- package/src/duckdb/src/planner/binder/expression/bind_comparison_expression.cpp +1 -0
- package/src/duckdb/src/planner/binder/expression/bind_function_expression.cpp +14 -5
- package/src/duckdb/src/planner/binder/expression/bind_macro_expression.cpp +5 -3
- package/src/duckdb/src/planner/binder/expression/bind_parameter_expression.cpp +12 -22
- package/src/duckdb/src/planner/binder/expression/bind_subquery_expression.cpp +1 -4
- package/src/duckdb/src/planner/binder/query_node/bind_cte_node.cpp +64 -0
- package/src/duckdb/src/planner/binder/query_node/bind_select_node.cpp +28 -6
- package/src/duckdb/src/planner/binder/query_node/plan_cte_node.cpp +26 -0
- package/src/duckdb/src/planner/binder/query_node/plan_recursive_cte_node.cpp +5 -5
- package/src/duckdb/src/planner/binder/query_node/plan_setop.cpp +4 -4
- package/src/duckdb/src/planner/binder/query_node/plan_subquery.cpp +36 -33
- package/src/duckdb/src/planner/binder/statement/bind_copy.cpp +1 -1
- package/src/duckdb/src/planner/binder/statement/bind_create.cpp +14 -52
- package/src/duckdb/src/planner/binder/statement/bind_create_table.cpp +0 -23
- package/src/duckdb/src/planner/binder/statement/bind_drop.cpp +3 -0
- package/src/duckdb/src/planner/binder/statement/bind_execute.cpp +13 -7
- package/src/duckdb/src/planner/binder/statement/bind_export.cpp +168 -30
- package/src/duckdb/src/planner/binder/tableref/bind_basetableref.cpp +93 -28
- package/src/duckdb/src/planner/binder/tableref/bind_joinref.cpp +32 -5
- package/src/duckdb/src/planner/binder/tableref/bind_pivot.cpp +116 -49
- package/src/duckdb/src/planner/binder/tableref/plan_cteref.cpp +1 -1
- package/src/duckdb/src/planner/binder/tableref/plan_joinref.cpp +79 -35
- package/src/duckdb/src/planner/binder/tableref/plan_subqueryref.cpp +3 -3
- package/src/duckdb/src/planner/binder.cpp +49 -32
- package/src/duckdb/src/planner/bound_parameter_map.cpp +67 -0
- package/src/duckdb/src/planner/bound_result_modifier.cpp +0 -33
- package/src/duckdb/src/planner/expression/bound_aggregate_expression.cpp +20 -21
- package/src/duckdb/src/planner/expression/bound_between_expression.cpp +4 -19
- package/src/duckdb/src/planner/expression/bound_case_expression.cpp +0 -36
- package/src/duckdb/src/planner/expression/bound_cast_expression.cpp +13 -23
- package/src/duckdb/src/planner/expression/bound_columnref_expression.cpp +0 -20
- package/src/duckdb/src/planner/expression/bound_comparison_expression.cpp +0 -13
- package/src/duckdb/src/planner/expression/bound_conjunction_expression.cpp +0 -13
- package/src/duckdb/src/planner/expression/bound_constant_expression.cpp +0 -11
- package/src/duckdb/src/planner/expression/bound_expression.cpp +1 -5
- package/src/duckdb/src/planner/expression/bound_function_expression.cpp +18 -16
- package/src/duckdb/src/planner/expression/bound_lambda_expression.cpp +0 -4
- package/src/duckdb/src/planner/expression/bound_lambdaref_expression.cpp +0 -23
- package/src/duckdb/src/planner/expression/bound_operator_expression.cpp +0 -16
- package/src/duckdb/src/planner/expression/bound_parameter_expression.cpp +23 -33
- package/src/duckdb/src/planner/expression/bound_reference_expression.cpp +0 -16
- package/src/duckdb/src/planner/expression/bound_subquery_expression.cpp +0 -4
- package/src/duckdb/src/planner/expression/bound_unnest_expression.cpp +0 -15
- package/src/duckdb/src/planner/expression/bound_window_expression.cpp +41 -50
- package/src/duckdb/src/planner/expression.cpp +0 -74
- package/src/duckdb/src/planner/expression_binder/base_select_binder.cpp +14 -6
- package/src/duckdb/src/planner/expression_binder/lateral_binder.cpp +4 -31
- package/src/duckdb/src/planner/expression_binder/order_binder.cpp +5 -4
- package/src/duckdb/src/planner/expression_binder.cpp +23 -0
- package/src/duckdb/src/planner/expression_iterator.cpp +6 -0
- package/src/duckdb/src/planner/filter/conjunction_filter.cpp +0 -21
- package/src/duckdb/src/planner/filter/constant_filter.cpp +0 -12
- package/src/duckdb/src/planner/filter/null_filter.cpp +0 -14
- package/src/duckdb/src/planner/joinside.cpp +0 -24
- package/src/duckdb/src/planner/logical_operator.cpp +18 -206
- package/src/duckdb/src/planner/logical_operator_visitor.cpp +5 -6
- package/src/duckdb/src/planner/operator/logical_aggregate.cpp +0 -46
- package/src/duckdb/src/planner/operator/logical_any_join.cpp +0 -14
- package/src/duckdb/src/planner/operator/logical_column_data_get.cpp +0 -23
- package/src/duckdb/src/planner/operator/logical_comparison_join.cpp +0 -21
- package/src/duckdb/src/planner/operator/logical_copy_to_file.cpp +4 -50
- package/src/duckdb/src/planner/operator/logical_create.cpp +10 -8
- package/src/duckdb/src/planner/operator/logical_create_index.cpp +30 -26
- package/src/duckdb/src/planner/operator/logical_create_table.cpp +12 -6
- package/src/duckdb/src/planner/operator/logical_cross_product.cpp +0 -9
- package/src/duckdb/src/planner/operator/logical_cteref.cpp +0 -16
- package/src/duckdb/src/planner/operator/logical_delete.cpp +4 -18
- package/src/duckdb/src/planner/operator/logical_delim_get.cpp +0 -12
- package/src/duckdb/src/planner/operator/logical_dependent_join.cpp +22 -0
- package/src/duckdb/src/planner/operator/logical_distinct.cpp +10 -13
- package/src/duckdb/src/planner/operator/logical_dummy_scan.cpp +0 -10
- package/src/duckdb/src/planner/operator/logical_empty_result.cpp +0 -15
- package/src/duckdb/src/planner/operator/logical_expression_get.cpp +0 -24
- package/src/duckdb/src/planner/operator/logical_extension_operator.cpp +32 -6
- package/src/duckdb/src/planner/operator/logical_filter.cpp +0 -15
- package/src/duckdb/src/planner/operator/logical_get.cpp +63 -70
- package/src/duckdb/src/planner/operator/logical_insert.cpp +4 -74
- package/src/duckdb/src/planner/operator/logical_join.cpp +0 -17
- package/src/duckdb/src/planner/operator/logical_limit.cpp +0 -16
- package/src/duckdb/src/planner/operator/logical_limit_percent.cpp +0 -16
- package/src/duckdb/src/planner/operator/logical_materialized_cte.cpp +9 -0
- package/src/duckdb/src/planner/operator/logical_order.cpp +35 -11
- package/src/duckdb/src/planner/operator/logical_pivot.cpp +3 -20
- package/src/duckdb/src/planner/operator/logical_positional_join.cpp +0 -10
- package/src/duckdb/src/planner/operator/logical_pragma.cpp +0 -8
- package/src/duckdb/src/planner/operator/logical_prepare.cpp +0 -8
- package/src/duckdb/src/planner/operator/logical_projection.cpp +0 -12
- package/src/duckdb/src/planner/operator/logical_recursive_cte.cpp +0 -15
- package/src/duckdb/src/planner/operator/logical_reset.cpp +0 -12
- package/src/duckdb/src/planner/operator/logical_sample.cpp +3 -11
- package/src/duckdb/src/planner/operator/logical_set.cpp +0 -14
- package/src/duckdb/src/planner/operator/logical_set_operation.cpp +0 -13
- package/src/duckdb/src/planner/operator/logical_simple.cpp +0 -60
- package/src/duckdb/src/planner/operator/logical_top_n.cpp +0 -14
- package/src/duckdb/src/planner/operator/logical_unnest.cpp +0 -14
- package/src/duckdb/src/planner/operator/logical_update.cpp +4 -25
- package/src/duckdb/src/planner/operator/logical_window.cpp +0 -13
- package/src/duckdb/src/planner/planner.cpp +26 -24
- package/src/duckdb/src/planner/subquery/flatten_dependent_join.cpp +90 -38
- package/src/duckdb/src/planner/subquery/has_correlated_expressions.cpp +22 -7
- package/src/duckdb/src/planner/subquery/rewrite_correlated_expressions.cpp +65 -7
- package/src/duckdb/src/planner/table_filter.cpp +0 -59
- package/src/duckdb/src/storage/arena_allocator.cpp +13 -2
- package/src/duckdb/src/storage/buffer/block_manager.cpp +13 -9
- package/src/duckdb/src/storage/checkpoint/row_group_writer.cpp +5 -18
- package/src/duckdb/src/storage/checkpoint/table_data_reader.cpp +10 -8
- package/src/duckdb/src/storage/checkpoint/table_data_writer.cpp +25 -25
- package/src/duckdb/src/storage/checkpoint/write_overflow_strings_to_disk.cpp +53 -26
- package/src/duckdb/src/storage/checkpoint_manager.cpp +314 -267
- package/src/duckdb/src/storage/compression/bitpacking.cpp +138 -107
- package/src/duckdb/src/storage/compression/bitpacking_hugeint.cpp +295 -0
- package/src/duckdb/src/storage/compression/fixed_size_uncompressed.cpp +6 -1
- package/src/duckdb/src/storage/compression/fsst.cpp +1 -1
- package/src/duckdb/src/storage/compression/rle.cpp +66 -16
- package/src/duckdb/src/storage/compression/string_uncompressed.cpp +84 -51
- package/src/duckdb/src/storage/compression/validity_uncompressed.cpp +4 -4
- package/src/duckdb/src/storage/data_pointer.cpp +20 -0
- package/src/duckdb/src/storage/data_table.cpp +60 -39
- package/src/duckdb/src/storage/index.cpp +11 -27
- package/src/duckdb/src/storage/local_storage.cpp +17 -16
- package/src/duckdb/src/storage/metadata/metadata_manager.cpp +322 -0
- package/src/duckdb/src/storage/metadata/metadata_reader.cpp +89 -0
- package/src/duckdb/src/storage/metadata/metadata_writer.cpp +92 -0
- package/src/duckdb/src/storage/partial_block_manager.cpp +42 -15
- package/src/duckdb/src/storage/serialization/serialize_constraint.cpp +98 -0
- package/src/duckdb/src/storage/serialization/serialize_create_info.cpp +198 -0
- package/src/duckdb/src/storage/serialization/serialize_expression.cpp +283 -0
- package/src/duckdb/src/storage/serialization/serialize_logical_operator.cpp +748 -0
- package/src/duckdb/src/storage/serialization/serialize_macro_function.cpp +62 -0
- package/src/duckdb/src/storage/serialization/serialize_nodes.cpp +459 -0
- package/src/duckdb/src/storage/serialization/serialize_parse_info.cpp +421 -0
- package/src/duckdb/src/storage/serialization/serialize_parsed_expression.cpp +342 -0
- package/src/duckdb/src/storage/serialization/serialize_query_node.cpp +122 -0
- package/src/duckdb/src/storage/serialization/serialize_result_modifier.cpp +97 -0
- package/src/duckdb/src/storage/serialization/serialize_statement.cpp +22 -0
- package/src/duckdb/src/storage/serialization/serialize_storage.cpp +78 -0
- package/src/duckdb/src/storage/serialization/serialize_table_filter.cpp +97 -0
- package/src/duckdb/src/storage/serialization/serialize_tableref.cpp +164 -0
- package/src/duckdb/src/storage/serialization/serialize_types.cpp +127 -0
- package/src/duckdb/src/storage/single_file_block_manager.cpp +93 -64
- package/src/duckdb/src/storage/standard_buffer_manager.cpp +10 -16
- package/src/duckdb/src/storage/statistics/base_statistics.cpp +62 -53
- package/src/duckdb/src/storage/statistics/column_statistics.cpp +10 -7
- package/src/duckdb/src/storage/statistics/distinct_statistics.cpp +0 -26
- package/src/duckdb/src/storage/statistics/list_stats.cpp +12 -7
- package/src/duckdb/src/storage/statistics/numeric_stats.cpp +53 -43
- package/src/duckdb/src/storage/statistics/string_stats.cpp +37 -18
- package/src/duckdb/src/storage/statistics/struct_stats.cpp +17 -12
- package/src/duckdb/src/storage/storage_info.cpp +3 -2
- package/src/duckdb/src/storage/storage_manager.cpp +22 -7
- package/src/duckdb/src/storage/table/chunk_info.cpp +59 -36
- package/src/duckdb/src/storage/table/column_checkpoint_state.cpp +31 -34
- package/src/duckdb/src/storage/table/column_data.cpp +44 -41
- package/src/duckdb/src/storage/table/column_data_checkpointer.cpp +7 -11
- package/src/duckdb/src/storage/table/column_segment.cpp +21 -12
- package/src/duckdb/src/storage/table/list_column_data.cpp +24 -14
- package/src/duckdb/src/storage/table/persistent_table_data.cpp +1 -2
- package/src/duckdb/src/storage/table/row_group.cpp +131 -209
- package/src/duckdb/src/storage/table/row_group_collection.cpp +34 -25
- package/src/duckdb/src/storage/table/row_version_manager.cpp +228 -0
- package/src/duckdb/src/storage/table/standard_column_data.cpp +10 -7
- package/src/duckdb/src/storage/table/struct_column_data.cpp +22 -11
- package/src/duckdb/src/storage/table/table_statistics.cpp +19 -9
- package/src/duckdb/src/storage/table/update_segment.cpp +3 -3
- package/src/duckdb/src/storage/table_index_list.cpp +2 -2
- package/src/duckdb/src/storage/wal_replay.cpp +135 -127
- package/src/duckdb/src/storage/write_ahead_log.cpp +136 -64
- package/src/duckdb/src/transaction/cleanup_state.cpp +2 -1
- package/src/duckdb/src/transaction/commit_state.cpp +32 -13
- package/src/duckdb/src/transaction/duck_transaction.cpp +5 -2
- package/src/duckdb/src/transaction/rollback_state.cpp +2 -1
- package/src/duckdb/src/transaction/undo_buffer.cpp +3 -5
- package/src/duckdb/src/verification/deserialized_statement_verifier.cpp +11 -6
- package/src/duckdb/src/verification/prepared_statement_verifier.cpp +16 -11
- package/src/duckdb/src/verification/statement_verifier.cpp +0 -3
- package/src/duckdb/third_party/concurrentqueue/concurrentqueue.h +2 -2
- package/src/duckdb/third_party/concurrentqueue/lightweightsemaphore.h +5 -2
- package/src/duckdb/third_party/fast_float/fast_float/fast_float.h +2 -0
- package/src/duckdb/third_party/httplib/httplib.hpp +10 -1
- package/src/duckdb/third_party/libpg_query/include/nodes/parsenodes.hpp +11 -0
- package/src/duckdb/third_party/libpg_query/include/parser/gram.hpp +2 -1
- package/src/duckdb/third_party/libpg_query/pg_functions.cpp +13 -0
- package/src/duckdb/third_party/libpg_query/src_backend_parser_gram.cpp +11019 -10364
- package/src/duckdb/third_party/libpg_query/src_backend_parser_scansup.cpp +9 -0
- package/src/duckdb/third_party/mbedtls/include/mbedtls_wrapper.hpp +14 -1
- package/src/duckdb/third_party/mbedtls/mbedtls_wrapper.cpp +54 -2
- package/src/duckdb/third_party/parquet/parquet_types.h +1 -1
- package/src/duckdb/third_party/utf8proc/include/utf8proc_wrapper.hpp +8 -0
- package/src/duckdb/ub_extension_icu_third_party_icu_i18n.cpp +6 -6
- package/src/duckdb/ub_src_common.cpp +3 -3
- package/src/duckdb/ub_src_common_adbc_nanoarrow.cpp +8 -0
- package/src/duckdb/ub_src_common_arrow_appender.cpp +10 -0
- package/src/duckdb/ub_src_common_row_operations.cpp +1 -1
- package/src/duckdb/ub_src_common_serializer.cpp +3 -3
- package/src/duckdb/ub_src_core_functions_scalar_debug.cpp +2 -0
- package/src/duckdb/ub_src_core_functions_scalar_list.cpp +6 -0
- package/src/duckdb/ub_src_core_functions_scalar_string.cpp +4 -0
- package/src/duckdb/ub_src_execution.cpp +2 -2
- package/src/duckdb/ub_src_execution_index.cpp +4 -0
- package/src/duckdb/ub_src_execution_index_art.cpp +0 -8
- package/src/duckdb/ub_src_execution_operator_csv_scanner.cpp +18 -0
- package/src/duckdb/ub_src_execution_operator_csv_scanner_sniffer.cpp +12 -0
- package/src/duckdb/ub_src_execution_operator_persistent.cpp +1 -11
- package/src/duckdb/ub_src_execution_operator_schema.cpp +1 -1
- package/src/duckdb/ub_src_execution_operator_set.cpp +2 -0
- package/src/duckdb/ub_src_execution_physical_plan.cpp +2 -0
- package/src/duckdb/ub_src_function_cast_union.cpp +2 -0
- package/src/duckdb/ub_src_function_scalar.cpp +2 -0
- package/src/duckdb/ub_src_function_scalar_compressed_materialization.cpp +4 -0
- package/src/duckdb/ub_src_function_scalar_list.cpp +2 -0
- package/src/duckdb/ub_src_function_table_arrow.cpp +2 -0
- package/src/duckdb/ub_src_function_table_system.cpp +2 -0
- package/src/duckdb/ub_src_main.cpp +2 -0
- package/src/duckdb/ub_src_main_chunk_scan_state.cpp +2 -0
- package/src/duckdb/ub_src_optimizer.cpp +6 -0
- package/src/duckdb/ub_src_optimizer_compressed_materialization.cpp +6 -0
- package/src/duckdb/ub_src_optimizer_join_order.cpp +10 -0
- package/src/duckdb/ub_src_optimizer_statistics_expression.cpp +0 -2
- package/src/duckdb/ub_src_parser.cpp +0 -2
- package/src/duckdb/ub_src_parser_query_node.cpp +2 -0
- package/src/duckdb/ub_src_parser_transform_expression.cpp +2 -0
- package/src/duckdb/ub_src_planner.cpp +2 -2
- package/src/duckdb/ub_src_planner_binder_query_node.cpp +4 -0
- package/src/duckdb/ub_src_planner_expression.cpp +0 -2
- package/src/duckdb/ub_src_planner_operator.cpp +3 -11
- package/src/duckdb/ub_src_storage.cpp +2 -4
- package/src/duckdb/ub_src_storage_compression.cpp +2 -0
- package/src/duckdb/ub_src_storage_metadata.cpp +6 -0
- package/src/duckdb/ub_src_storage_serialization.cpp +30 -0
- package/src/duckdb/ub_src_storage_table.cpp +2 -0
- package/src/duckdb_node.cpp +6 -12
- package/src/duckdb_node.hpp +25 -13
- package/src/statement.cpp +27 -25
- package/test/close_hang.test.ts +39 -0
- package/test/columns.test.ts +25 -3
- package/test/database_fail.test.ts +26 -0
- package/test/extension.test.ts +1 -1
- package/test/prepare.test.ts +10 -1
- package/test/test_all_types.test.ts +234 -0
- package/test/worker.js +7 -0
- package/tsconfig.json +1 -0
- package/src/duckdb/src/common/field_writer.cpp +0 -97
- package/src/duckdb/src/common/row_operations/row_match.cpp +0 -359
- package/src/duckdb/src/common/serializer/buffered_deserializer.cpp +0 -27
- package/src/duckdb/src/common/serializer/buffered_serializer.cpp +0 -36
- package/src/duckdb/src/common/serializer.cpp +0 -24
- package/src/duckdb/src/execution/index/art/fixed_size_allocator.cpp +0 -242
- package/src/duckdb/src/execution/index/art/leaf_segment.cpp +0 -52
- package/src/duckdb/src/execution/index/art/prefix_segment.cpp +0 -42
- package/src/duckdb/src/execution/index/art/swizzleable_pointer.cpp +0 -22
- package/src/duckdb/src/execution/operator/persistent/buffered_csv_reader.cpp +0 -1487
- package/src/duckdb/src/execution/operator/persistent/csv_buffer.cpp +0 -72
- package/src/duckdb/src/execution/operator/persistent/csv_file_handle.cpp +0 -158
- package/src/duckdb/src/execution/operator/persistent/csv_reader_options.cpp +0 -260
- package/src/duckdb/src/execution/operator/schema/physical_create_index.cpp +0 -193
- package/src/duckdb/src/execution/partitionable_hashtable.cpp +0 -172
- package/src/duckdb/src/include/duckdb/common/arrow/arrow_options.hpp +0 -25
- package/src/duckdb/src/include/duckdb/common/field_writer.hpp +0 -383
- package/src/duckdb/src/include/duckdb/common/serializer/buffered_deserializer.hpp +0 -41
- package/src/duckdb/src/include/duckdb/common/serializer/buffered_serializer.hpp +0 -50
- package/src/duckdb/src/include/duckdb/common/serializer/format_serializer.hpp +0 -248
- package/src/duckdb/src/include/duckdb/common/serializer.hpp +0 -158
- package/src/duckdb/src/include/duckdb/execution/index/art/fixed_size_allocator.hpp +0 -117
- package/src/duckdb/src/include/duckdb/execution/index/art/leaf_segment.hpp +0 -38
- package/src/duckdb/src/include/duckdb/execution/index/art/prefix_segment.hpp +0 -40
- package/src/duckdb/src/include/duckdb/execution/index/art/swizzleable_pointer.hpp +0 -58
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/buffered_csv_reader.hpp +0 -133
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/csv_buffer.hpp +0 -74
- package/src/duckdb/src/include/duckdb/execution/partitionable_hashtable.hpp +0 -69
- package/src/duckdb/src/include/duckdb/planner/operator/logical_asof_join.hpp +0 -27
- package/src/duckdb/src/include/duckdb/planner/operator/logical_delim_join.hpp +0 -32
- package/src/duckdb/src/include/duckdb/planner/plan_serialization.hpp +0 -44
- package/src/duckdb/src/include/duckdb/storage/meta_block_reader.hpp +0 -49
- package/src/duckdb/src/include/duckdb/storage/meta_block_writer.hpp +0 -50
- package/src/duckdb/src/include/duckdb/verification/deserialized_statement_verifier_v2.hpp +0 -26
- package/src/duckdb/src/optimizer/statistics/expression/propagate_and_compress.cpp +0 -118
- package/src/duckdb/src/parser/common_table_expression_info.cpp +0 -19
- package/src/duckdb/src/planner/expression/bound_default_expression.cpp +0 -16
- package/src/duckdb/src/planner/operator/logical_asof_join.cpp +0 -14
- package/src/duckdb/src/planner/operator/logical_delim_join.cpp +0 -27
- package/src/duckdb/src/planner/operator/logical_execute.cpp +0 -12
- package/src/duckdb/src/planner/operator/logical_explain.cpp +0 -22
- package/src/duckdb/src/planner/operator/logical_export.cpp +0 -13
- package/src/duckdb/src/planner/operator/logical_show.cpp +0 -21
- package/src/duckdb/src/planner/parsed_data/bound_create_table_info.cpp +0 -20
- package/src/duckdb/src/planner/plan_serialization.cpp +0 -20
- package/src/duckdb/src/storage/meta_block_reader.cpp +0 -78
- package/src/duckdb/src/storage/meta_block_writer.cpp +0 -80
- package/src/duckdb/src/verification/deserialized_statement_verifier_v2.cpp +0 -20
- package/src/duckdb/ub_src_planner_parsed_data.cpp +0 -2
@@ -20,8 +20,6 @@
|
|
20
20
|
namespace duckdb {
|
21
21
|
|
22
22
|
class CastFunctionSet;
|
23
|
-
class Deserializer;
|
24
|
-
class Serializer;
|
25
23
|
struct GetCastFunctionInput;
|
26
24
|
struct ExtraValueInfo;
|
27
25
|
|
@@ -120,7 +118,7 @@ public:
|
|
120
118
|
DUCKDB_API static Value DATE(int32_t year, int32_t month, int32_t day);
|
121
119
|
//! Create a time Value from a specified time
|
122
120
|
DUCKDB_API static Value TIME(dtime_t time);
|
123
|
-
DUCKDB_API static Value TIMETZ(
|
121
|
+
DUCKDB_API static Value TIMETZ(dtime_tz_t time);
|
124
122
|
//! Create a time Value from a specified time
|
125
123
|
DUCKDB_API static Value TIME(int32_t hour, int32_t min, int32_t sec, int32_t micros);
|
126
124
|
//! Create a timestamp Value from a specified date/time combination
|
@@ -177,7 +175,10 @@ public:
|
|
177
175
|
template <class T>
|
178
176
|
T GetValue() const;
|
179
177
|
template <class T>
|
180
|
-
static Value CreateValue(T value)
|
178
|
+
static Value CreateValue(T value) {
|
179
|
+
static_assert(AlwaysFalse<T>::value, "No specialization exists for this type");
|
180
|
+
return Value(nullptr);
|
181
|
+
}
|
181
182
|
// Returns the internal value. Unlike GetValue(), this method does not perform casting, and assumes T matches the
|
182
183
|
// type of the value. Only use this if you know what you are doing.
|
183
184
|
template <class T>
|
@@ -222,10 +223,8 @@ public:
|
|
222
223
|
|
223
224
|
//! Serializes a Value to a stand-alone binary blob
|
224
225
|
DUCKDB_API void Serialize(Serializer &serializer) const;
|
225
|
-
DUCKDB_API void FormatSerialize(FormatSerializer &serializer) const;
|
226
|
-
DUCKDB_API static Value FormatDeserialize(FormatDeserializer &deserializer);
|
227
226
|
//! Deserializes a Value from a blob
|
228
|
-
DUCKDB_API static Value Deserialize(Deserializer &
|
227
|
+
DUCKDB_API static Value Deserialize(Deserializer &deserializer);
|
229
228
|
|
230
229
|
//===--------------------------------------------------------------------===//
|
231
230
|
// Comparison Operators
|
@@ -299,6 +298,7 @@ private:
|
|
299
298
|
uint64_t hash;
|
300
299
|
date_t date;
|
301
300
|
dtime_t time;
|
301
|
+
dtime_tz_t timetz;
|
302
302
|
timestamp_t timestamp;
|
303
303
|
interval_t interval;
|
304
304
|
} value_; // NOLINT
|
@@ -394,6 +394,7 @@ struct ListValue {
|
|
394
394
|
struct UnionValue {
|
395
395
|
DUCKDB_API static const Value &GetValue(const Value &value);
|
396
396
|
DUCKDB_API static uint8_t GetTag(const Value &value);
|
397
|
+
DUCKDB_API static const LogicalType &GetType(const Value &value);
|
397
398
|
};
|
398
399
|
|
399
400
|
//! Return the internal integral value for any type that is stored as an integral value internally
|
@@ -35,6 +35,11 @@ struct UnifiedVectorFormat {
|
|
35
35
|
}
|
36
36
|
};
|
37
37
|
|
38
|
+
struct RecursiveUnifiedVectorFormat {
|
39
|
+
UnifiedVectorFormat unified;
|
40
|
+
vector<RecursiveUnifiedVectorFormat> children;
|
41
|
+
};
|
42
|
+
|
38
43
|
class VectorCache;
|
39
44
|
class VectorStructBuffer;
|
40
45
|
class VectorListBuffer;
|
@@ -96,14 +101,14 @@ public:
|
|
96
101
|
DUCKDB_API void Reference(const Value &value);
|
97
102
|
//! Causes this vector to reference the data held by the other vector.
|
98
103
|
//! The type of the "other" vector should match the type of this vector
|
99
|
-
DUCKDB_API void Reference(Vector &other);
|
104
|
+
DUCKDB_API void Reference(const Vector &other);
|
100
105
|
//! Reinterpret the data of the other vector as the type of this vector
|
101
106
|
//! Note that this takes the data of the other vector as-is and places it in this vector
|
102
107
|
//! Without changing the type of this vector
|
103
|
-
DUCKDB_API void Reinterpret(Vector &other);
|
108
|
+
DUCKDB_API void Reinterpret(const Vector &other);
|
104
109
|
|
105
110
|
//! Causes this vector to reference the data held by the other vector, changes the type if required.
|
106
|
-
DUCKDB_API void ReferenceAndSetType(Vector &other);
|
111
|
+
DUCKDB_API void ReferenceAndSetType(const Vector &other);
|
107
112
|
|
108
113
|
//! Resets a vector from a vector cache.
|
109
114
|
//! This turns the vector back into an empty FlatVector with STANDARD_VECTOR_SIZE entries.
|
@@ -140,6 +145,8 @@ public:
|
|
140
145
|
//! The most common vector types (flat, constant & dictionary) can be converted to the canonical format "for free"
|
141
146
|
//! ToUnifiedFormat was originally called Orrify, as a tribute to Orri Erling who came up with it
|
142
147
|
DUCKDB_API void ToUnifiedFormat(idx_t count, UnifiedVectorFormat &data);
|
148
|
+
//! Recursively calls UnifiedVectorFormat on a vector and its child vectors (for nested types)
|
149
|
+
static void RecursiveToUnifiedFormat(Vector &input, idx_t count, RecursiveUnifiedVectorFormat &data);
|
143
150
|
|
144
151
|
//! Turn the vector into a sequence vector
|
145
152
|
DUCKDB_API void Sequence(int64_t start, int64_t increment, idx_t count);
|
@@ -166,13 +173,8 @@ public:
|
|
166
173
|
//! This functions resizes the vector
|
167
174
|
DUCKDB_API void Resize(idx_t cur_size, idx_t new_size);
|
168
175
|
|
169
|
-
|
170
|
-
DUCKDB_API void
|
171
|
-
//! Deserializes a blob back into a Vector
|
172
|
-
DUCKDB_API void Deserialize(idx_t count, Deserializer &source);
|
173
|
-
|
174
|
-
DUCKDB_API void FormatSerialize(FormatSerializer &serializer, idx_t count);
|
175
|
-
DUCKDB_API void FormatDeserialize(FormatDeserializer &deserializer, idx_t count);
|
176
|
+
DUCKDB_API void Serialize(Serializer &serializer, idx_t count);
|
177
|
+
DUCKDB_API void Deserialize(Deserializer &deserializer, idx_t count);
|
176
178
|
|
177
179
|
// Getters
|
178
180
|
inline VectorType GetVectorType() const {
|
@@ -445,7 +447,7 @@ struct StructVector {
|
|
445
447
|
DUCKDB_API static vector<unique_ptr<Vector>> &GetEntries(Vector &vector);
|
446
448
|
};
|
447
449
|
|
448
|
-
enum class UnionInvalidReason : uint8_t { VALID, TAG_OUT_OF_RANGE, NO_MEMBERS, VALIDITY_OVERLAP };
|
450
|
+
enum class UnionInvalidReason : uint8_t { VALID, TAG_OUT_OF_RANGE, NO_MEMBERS, VALIDITY_OVERLAP, TAG_MISMATCH };
|
449
451
|
|
450
452
|
struct UnionVector {
|
451
453
|
// Unions are stored as structs, but the first child is always the "tag"
|
@@ -17,28 +17,12 @@
|
|
17
17
|
|
18
18
|
namespace duckdb {
|
19
19
|
|
20
|
-
class FormatSerializer;
|
21
|
-
class FormatDeserializer;
|
22
20
|
class Serializer;
|
23
21
|
class Deserializer;
|
24
22
|
class Value;
|
25
23
|
class TypeCatalogEntry;
|
26
24
|
class Vector;
|
27
25
|
class ClientContext;
|
28
|
-
class FieldWriter;
|
29
|
-
|
30
|
-
//! Extra Type Info Type
|
31
|
-
enum class ExtraTypeInfoType : uint8_t {
|
32
|
-
INVALID_TYPE_INFO = 0,
|
33
|
-
GENERIC_TYPE_INFO = 1,
|
34
|
-
DECIMAL_TYPE_INFO = 2,
|
35
|
-
STRING_TYPE_INFO = 3,
|
36
|
-
LIST_TYPE_INFO = 4,
|
37
|
-
STRUCT_TYPE_INFO = 5,
|
38
|
-
ENUM_TYPE_INFO = 6,
|
39
|
-
USER_TYPE_INFO = 7,
|
40
|
-
AGGREGATE_STATE_TYPE_INFO = 8
|
41
|
-
};
|
42
26
|
|
43
27
|
struct string_t;
|
44
28
|
|
@@ -296,16 +280,8 @@ struct LogicalType {
|
|
296
280
|
return !(*this == rhs);
|
297
281
|
}
|
298
282
|
|
299
|
-
//! Serializes a LogicalType to a stand-alone binary blob
|
300
283
|
DUCKDB_API void Serialize(Serializer &serializer) const;
|
301
|
-
|
302
|
-
DUCKDB_API void SerializeEnumType(Serializer &serializer) const;
|
303
|
-
|
304
|
-
//! Deserializes a blob back into an LogicalType
|
305
|
-
DUCKDB_API static LogicalType Deserialize(Deserializer &source);
|
306
|
-
|
307
|
-
DUCKDB_API void FormatSerialize(FormatSerializer &serializer) const;
|
308
|
-
DUCKDB_API static LogicalType FormatDeserialize(FormatDeserializer &deserializer);
|
284
|
+
DUCKDB_API static LogicalType Deserialize(Deserializer &deserializer);
|
309
285
|
|
310
286
|
|
311
287
|
static bool TypeIsTimestamp(LogicalTypeId id) {
|
@@ -328,8 +304,6 @@ struct LogicalType {
|
|
328
304
|
|
329
305
|
DUCKDB_API static LogicalType MaxLogicalType(const LogicalType &left, const LogicalType &right);
|
330
306
|
|
331
|
-
DUCKDB_API static ExtraTypeInfoType GetExtraTypeInfoType(const ExtraTypeInfo &type);
|
332
|
-
|
333
307
|
//! Gets the decimal properties of a numeric type. Fails if the type is not numeric.
|
334
308
|
DUCKDB_API bool GetDecimalProperties(uint8_t &width, uint8_t &scale) const;
|
335
309
|
|
@@ -388,9 +362,10 @@ public:
|
|
388
362
|
DUCKDB_API static LogicalType STRUCT(child_list_t<LogicalType> children); // NOLINT
|
389
363
|
DUCKDB_API static LogicalType AGGREGATE_STATE(aggregate_state_t state_type); // NOLINT
|
390
364
|
DUCKDB_API static LogicalType MAP(const LogicalType &child); // NOLINT
|
391
|
-
DUCKDB_API static LogicalType MAP( child_list_t<LogicalType> children); // NOLINT
|
392
365
|
DUCKDB_API static LogicalType MAP(LogicalType key, LogicalType value); // NOLINT
|
393
366
|
DUCKDB_API static LogicalType UNION( child_list_t<LogicalType> members); // NOLINT
|
367
|
+
DUCKDB_API static LogicalType ENUM(Vector &ordered_data, idx_t size); // NOLINT
|
368
|
+
// DEPRECATED - provided for backwards compatibility
|
394
369
|
DUCKDB_API static LogicalType ENUM(const string &enum_name, Vector &ordered_data, idx_t size); // NOLINT
|
395
370
|
DUCKDB_API static LogicalType USER(const string &user_type_name); // NOLINT
|
396
371
|
//! A list of all NUMERIC types (integral and floating point types)
|
@@ -415,21 +390,17 @@ struct ListType {
|
|
415
390
|
DUCKDB_API static const LogicalType &GetChildType(const LogicalType &type);
|
416
391
|
};
|
417
392
|
|
418
|
-
struct UserType{
|
393
|
+
struct UserType {
|
419
394
|
DUCKDB_API static const string &GetTypeName(const LogicalType &type);
|
420
395
|
};
|
421
396
|
|
422
|
-
struct EnumType{
|
423
|
-
DUCKDB_API static const string &GetTypeName(const LogicalType &type);
|
397
|
+
struct EnumType {
|
424
398
|
DUCKDB_API static int64_t GetPos(const LogicalType &type, const string_t& key);
|
425
399
|
DUCKDB_API static const Vector &GetValuesInsertOrder(const LogicalType &type);
|
426
400
|
DUCKDB_API static idx_t GetSize(const LogicalType &type);
|
427
401
|
DUCKDB_API static const string GetValue(const Value &val);
|
428
|
-
DUCKDB_API static void SetCatalog(LogicalType &type, optional_ptr<TypeCatalogEntry> catalog_entry);
|
429
|
-
DUCKDB_API static optional_ptr<TypeCatalogEntry> GetCatalog(const LogicalType &type);
|
430
|
-
DUCKDB_API static string GetSchemaName(const LogicalType &type);
|
431
402
|
DUCKDB_API static PhysicalType GetPhysicalType(const LogicalType &type);
|
432
|
-
DUCKDB_API static
|
403
|
+
DUCKDB_API static string_t GetString(const LogicalType &type, idx_t pos);
|
433
404
|
};
|
434
405
|
|
435
406
|
struct StructType {
|
@@ -437,6 +408,7 @@ struct StructType {
|
|
437
408
|
DUCKDB_API static const LogicalType &GetChildType(const LogicalType &type, idx_t index);
|
438
409
|
DUCKDB_API static const string &GetChildName(const LogicalType &type, idx_t index);
|
439
410
|
DUCKDB_API static idx_t GetChildCount(const LogicalType &type);
|
411
|
+
DUCKDB_API static bool IsUnnamed(const LogicalType &type);
|
440
412
|
};
|
441
413
|
|
442
414
|
struct MapType {
|
@@ -480,6 +452,7 @@ bool ApproxEqual(float l, float r);
|
|
480
452
|
bool ApproxEqual(double l, double r);
|
481
453
|
|
482
454
|
struct aggregate_state_t {
|
455
|
+
aggregate_state_t() {}
|
483
456
|
aggregate_state_t(string function_name_p, LogicalType return_type_p, vector<LogicalType> bound_argument_types_p) : function_name(std::move(function_name_p)), return_type(std::move(return_type_p)), bound_argument_types(std::move(bound_argument_types_p)) {
|
484
457
|
}
|
485
458
|
|
@@ -88,14 +88,14 @@ public:
|
|
88
88
|
}
|
89
89
|
|
90
90
|
typename original::reference back() {
|
91
|
-
if (original::empty()) {
|
91
|
+
if (MemorySafety<SAFE>::enabled && original::empty()) {
|
92
92
|
throw InternalException("'back' called on an empty vector!");
|
93
93
|
}
|
94
94
|
return get<SAFE>(original::size() - 1);
|
95
95
|
}
|
96
96
|
|
97
97
|
typename original::const_reference back() const {
|
98
|
-
if (original::empty()) {
|
98
|
+
if (MemorySafety<SAFE>::enabled && original::empty()) {
|
99
99
|
throw InternalException("'back' called on an empty vector!");
|
100
100
|
}
|
101
101
|
return get<SAFE>(original::size() - 1);
|
@@ -15,9 +15,14 @@
|
|
15
15
|
|
16
16
|
namespace duckdb {
|
17
17
|
|
18
|
+
// structs
|
18
19
|
struct AggregateInputData;
|
19
|
-
|
20
|
-
|
20
|
+
struct FrameBounds {
|
21
|
+
FrameBounds() : start(0), end(0) {};
|
22
|
+
FrameBounds(idx_t start, idx_t end) : start(start), end(end) {};
|
23
|
+
idx_t start = 0;
|
24
|
+
idx_t end = 0;
|
25
|
+
};
|
21
26
|
|
22
27
|
class AggregateExecutor {
|
23
28
|
private:
|
@@ -10,6 +10,7 @@
|
|
10
10
|
|
11
11
|
#include "duckdb/common/file_system.hpp"
|
12
12
|
#include "duckdb/common/map.hpp"
|
13
|
+
#include "duckdb/common/unordered_set.hpp"
|
13
14
|
|
14
15
|
namespace duckdb {
|
15
16
|
|
@@ -22,120 +23,62 @@ public:
|
|
22
23
|
FileCompressionType compression = FileCompressionType::UNCOMPRESSED,
|
23
24
|
FileOpener *opener = nullptr) override;
|
24
25
|
|
25
|
-
void Read(FileHandle &handle, void *buffer, int64_t nr_bytes, idx_t location) override
|
26
|
-
|
27
|
-
};
|
26
|
+
void Read(FileHandle &handle, void *buffer, int64_t nr_bytes, idx_t location) override;
|
27
|
+
void Write(FileHandle &handle, void *buffer, int64_t nr_bytes, idx_t location) override;
|
28
28
|
|
29
|
-
|
30
|
-
handle.file_system.Write(handle, buffer, nr_bytes, location);
|
31
|
-
}
|
29
|
+
int64_t Read(FileHandle &handle, void *buffer, int64_t nr_bytes) override;
|
32
30
|
|
33
|
-
int64_t
|
34
|
-
return handle.file_system.Read(handle, buffer, nr_bytes);
|
35
|
-
}
|
31
|
+
int64_t Write(FileHandle &handle, void *buffer, int64_t nr_bytes) override;
|
36
32
|
|
37
|
-
int64_t
|
38
|
-
|
39
|
-
|
33
|
+
int64_t GetFileSize(FileHandle &handle) override;
|
34
|
+
time_t GetLastModifiedTime(FileHandle &handle) override;
|
35
|
+
FileType GetFileType(FileHandle &handle) override;
|
40
36
|
|
41
|
-
|
42
|
-
return handle.file_system.GetFileSize(handle);
|
43
|
-
}
|
44
|
-
time_t GetLastModifiedTime(FileHandle &handle) override {
|
45
|
-
return handle.file_system.GetLastModifiedTime(handle);
|
46
|
-
}
|
47
|
-
FileType GetFileType(FileHandle &handle) override {
|
48
|
-
return handle.file_system.GetFileType(handle);
|
49
|
-
}
|
37
|
+
void Truncate(FileHandle &handle, int64_t new_size) override;
|
50
38
|
|
51
|
-
void
|
52
|
-
handle.file_system.Truncate(handle, new_size);
|
53
|
-
}
|
54
|
-
|
55
|
-
void FileSync(FileHandle &handle) override {
|
56
|
-
handle.file_system.FileSync(handle);
|
57
|
-
}
|
39
|
+
void FileSync(FileHandle &handle) override;
|
58
40
|
|
59
41
|
// need to look up correct fs for this
|
60
|
-
bool DirectoryExists(const string &directory) override
|
61
|
-
|
62
|
-
}
|
63
|
-
void CreateDirectory(const string &directory) override {
|
64
|
-
FindFileSystem(directory)->CreateDirectory(directory);
|
65
|
-
}
|
42
|
+
bool DirectoryExists(const string &directory) override;
|
43
|
+
void CreateDirectory(const string &directory) override;
|
66
44
|
|
67
|
-
void RemoveDirectory(const string &directory) override
|
68
|
-
FindFileSystem(directory)->RemoveDirectory(directory);
|
69
|
-
}
|
45
|
+
void RemoveDirectory(const string &directory) override;
|
70
46
|
|
71
47
|
bool ListFiles(const string &directory, const std::function<void(const string &, bool)> &callback,
|
72
|
-
FileOpener *opener = nullptr) override
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
sub_systems.push_back(std::move(fs));
|
97
|
-
}
|
98
|
-
|
99
|
-
void UnregisterSubSystem(const string &name) override {
|
100
|
-
for (auto sub_system = sub_systems.begin(); sub_system != sub_systems.end(); sub_system++) {
|
101
|
-
if (sub_system->get()->GetName() == name) {
|
102
|
-
sub_systems.erase(sub_system);
|
103
|
-
return;
|
104
|
-
}
|
105
|
-
}
|
106
|
-
throw InvalidInputException("Could not find filesystem with name %s", name);
|
107
|
-
}
|
108
|
-
|
109
|
-
void RegisterSubSystem(FileCompressionType compression_type, unique_ptr<FileSystem> fs) override {
|
110
|
-
compressed_fs[compression_type] = std::move(fs);
|
111
|
-
}
|
112
|
-
|
113
|
-
vector<string> ListSubSystems() override {
|
114
|
-
vector<string> names(sub_systems.size());
|
115
|
-
for (idx_t i = 0; i < sub_systems.size(); i++) {
|
116
|
-
names[i] = sub_systems[i]->GetName();
|
117
|
-
}
|
118
|
-
return names;
|
119
|
-
}
|
120
|
-
|
121
|
-
std::string GetName() const override {
|
122
|
-
return "VirtualFileSystem";
|
123
|
-
}
|
48
|
+
FileOpener *opener = nullptr) override;
|
49
|
+
|
50
|
+
void MoveFile(const string &source, const string &target) override;
|
51
|
+
|
52
|
+
bool FileExists(const string &filename) override;
|
53
|
+
|
54
|
+
bool IsPipe(const string &filename) override;
|
55
|
+
virtual void RemoveFile(const string &filename) override;
|
56
|
+
|
57
|
+
virtual vector<string> Glob(const string &path, FileOpener *opener = nullptr) override;
|
58
|
+
|
59
|
+
void RegisterSubSystem(unique_ptr<FileSystem> fs) override;
|
60
|
+
|
61
|
+
void UnregisterSubSystem(const string &name) override;
|
62
|
+
|
63
|
+
void RegisterSubSystem(FileCompressionType compression_type, unique_ptr<FileSystem> fs) override;
|
64
|
+
|
65
|
+
vector<string> ListSubSystems() override;
|
66
|
+
|
67
|
+
std::string GetName() const override;
|
68
|
+
|
69
|
+
void SetDisabledFileSystems(const vector<string> &names) override;
|
70
|
+
|
71
|
+
string PathSeparator(const string &path) override;
|
124
72
|
|
125
73
|
private:
|
126
|
-
FileSystem
|
127
|
-
|
128
|
-
if (sub_system->CanHandleFile(path)) {
|
129
|
-
return sub_system.get();
|
130
|
-
}
|
131
|
-
}
|
132
|
-
return default_fs.get();
|
133
|
-
}
|
74
|
+
FileSystem &FindFileSystem(const string &path);
|
75
|
+
FileSystem &FindFileSystemInternal(const string &path);
|
134
76
|
|
135
77
|
private:
|
136
78
|
vector<unique_ptr<FileSystem>> sub_systems;
|
137
79
|
map<FileCompressionType, unique_ptr<FileSystem>> compressed_fs;
|
138
80
|
const unique_ptr<FileSystem> default_fs;
|
81
|
+
unordered_set<string> disabled_file_systems;
|
139
82
|
};
|
140
83
|
|
141
84
|
} // namespace duckdb
|
@@ -31,10 +31,10 @@ struct CorrOperation {
|
|
31
31
|
}
|
32
32
|
|
33
33
|
template <class A_TYPE, class B_TYPE, class STATE, class OP>
|
34
|
-
static void Operation(STATE &state, const A_TYPE &
|
35
|
-
CovarOperation::Operation<A_TYPE, B_TYPE, CovarState, OP>(state.cov_pop,
|
36
|
-
STDDevBaseOperation::Execute<A_TYPE, StddevState>(state.dev_pop_x,
|
37
|
-
STDDevBaseOperation::Execute<B_TYPE, StddevState>(state.dev_pop_y,
|
34
|
+
static void Operation(STATE &state, const A_TYPE &y, const B_TYPE &x, AggregateBinaryInput &idata) {
|
35
|
+
CovarOperation::Operation<A_TYPE, B_TYPE, CovarState, OP>(state.cov_pop, y, x, idata);
|
36
|
+
STDDevBaseOperation::Execute<A_TYPE, StddevState>(state.dev_pop_x, x);
|
37
|
+
STDDevBaseOperation::Execute<B_TYPE, StddevState>(state.dev_pop_y, y);
|
38
38
|
}
|
39
39
|
|
40
40
|
template <class STATE, class OP>
|
@@ -5,6 +5,7 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
+
// COVAR_POP(y,x)
|
8
9
|
|
9
10
|
#pragma once
|
10
11
|
|
@@ -29,7 +30,7 @@ struct CovarOperation {
|
|
29
30
|
}
|
30
31
|
|
31
32
|
template <class A_TYPE, class B_TYPE, class STATE, class OP>
|
32
|
-
static void Operation(STATE &state, const A_TYPE &
|
33
|
+
static void Operation(STATE &state, const A_TYPE &y, const B_TYPE &x, AggregateBinaryInput &idata) {
|
33
34
|
// update running mean and d^2
|
34
35
|
const uint64_t n = ++(state.count);
|
35
36
|
|
@@ -39,6 +40,7 @@ struct CovarOperation {
|
|
39
40
|
const double dy = (y - state.meany);
|
40
41
|
const double meany = state.meany + dy / n;
|
41
42
|
|
43
|
+
// Schubert and Gertz SSDBM 2018 (4.3)
|
42
44
|
const double C = state.co_moment + dx * (y - meany);
|
43
45
|
|
44
46
|
state.meanx = meanx;
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -197,7 +199,7 @@ struct StringAggFun {
|
|
197
199
|
static constexpr const char *Name = "string_agg";
|
198
200
|
static constexpr const char *Parameters = "str,arg";
|
199
201
|
static constexpr const char *Description = "Concatenates the column string values with an optional separator.";
|
200
|
-
static constexpr const char *Example = "string_agg(A, '-)";
|
202
|
+
static constexpr const char *Example = "string_agg(A, '-')";
|
201
203
|
|
202
204
|
static AggregateFunctionSet GetFunctions();
|
203
205
|
};
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -25,9 +25,9 @@ struct RegrSlopeOperation {
|
|
25
25
|
}
|
26
26
|
|
27
27
|
template <class A_TYPE, class B_TYPE, class STATE, class OP>
|
28
|
-
static void Operation(STATE &state, const A_TYPE &
|
29
|
-
CovarOperation::Operation<A_TYPE, B_TYPE, CovarState, OP>(state.cov_pop,
|
30
|
-
STDDevBaseOperation::Execute<A_TYPE, StddevState>(state.var_pop,
|
28
|
+
static void Operation(STATE &state, const A_TYPE &y, const B_TYPE &x, AggregateBinaryInput &idata) {
|
29
|
+
CovarOperation::Operation<A_TYPE, B_TYPE, CovarState, OP>(state.cov_pop, y, x,idata);
|
30
|
+
STDDevBaseOperation::Execute<A_TYPE, StddevState>(state.var_pop, x);
|
31
31
|
}
|
32
32
|
|
33
33
|
template <class STATE, class OP>
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -16,7 +18,7 @@ namespace duckdb {
|
|
16
18
|
struct GetBitFun {
|
17
19
|
static constexpr const char *Name = "get_bit";
|
18
20
|
static constexpr const char *Parameters = "bitstring,index";
|
19
|
-
static constexpr const char *Description = "Extracts the nth bit from bitstring; the first (leftmost) bit is indexed 0
|
21
|
+
static constexpr const char *Description = "Extracts the nth bit from bitstring; the first (leftmost) bit is indexed 0";
|
20
22
|
static constexpr const char *Example = "get_bit('0110010'::BIT, 2)";
|
21
23
|
|
22
24
|
static ScalarFunction GetFunction();
|
@@ -25,7 +27,7 @@ struct GetBitFun {
|
|
25
27
|
struct SetBitFun {
|
26
28
|
static constexpr const char *Name = "set_bit";
|
27
29
|
static constexpr const char *Parameters = "bitstring,index,new_value";
|
28
|
-
static constexpr const char *Description = "Sets the nth bit in bitstring to newvalue; the first (leftmost) bit is indexed 0. Returns a new bitstring
|
30
|
+
static constexpr const char *Description = "Sets the nth bit in bitstring to newvalue; the first (leftmost) bit is indexed 0. Returns a new bitstring";
|
29
31
|
static constexpr const char *Example = "set_bit('0110010'::BIT, 2, 0)";
|
30
32
|
|
31
33
|
static ScalarFunction GetFunction();
|
@@ -34,7 +36,7 @@ struct SetBitFun {
|
|
34
36
|
struct BitPositionFun {
|
35
37
|
static constexpr const char *Name = "bit_position";
|
36
38
|
static constexpr const char *Parameters = "substring,bitstring";
|
37
|
-
static constexpr const char *Description = "Returns first starting index of the specified substring within bits, or zero if it
|
39
|
+
static constexpr const char *Description = "Returns first starting index of the specified substring within bits, or zero if it is not present. The first (leftmost) bit is indexed 1";
|
38
40
|
static constexpr const char *Example = "bit_position('010'::BIT, '1110101'::BIT)";
|
39
41
|
|
40
42
|
static ScalarFunction GetFunction();
|
@@ -43,7 +45,7 @@ struct BitPositionFun {
|
|
43
45
|
struct BitStringFun {
|
44
46
|
static constexpr const char *Name = "bitstring";
|
45
47
|
static constexpr const char *Parameters = "bitstring,length";
|
46
|
-
static constexpr const char *Description = "Pads the bitstring until the specified length
|
48
|
+
static constexpr const char *Description = "Pads the bitstring until the specified length";
|
47
49
|
static constexpr const char *Example = "bitstring('1010'::BIT, 7)";
|
48
50
|
|
49
51
|
static ScalarFunction GetFunction();
|
@@ -5,7 +5,9 @@
|
|
5
5
|
//
|
6
6
|
//
|
7
7
|
//===----------------------------------------------------------------------===//
|
8
|
-
// This file is generated by scripts/generate_functions.py
|
8
|
+
// This file is automatically generated by scripts/generate_functions.py
|
9
|
+
// Do not edit this file manually, your changes will be overwritten
|
10
|
+
//===----------------------------------------------------------------------===//
|
9
11
|
|
10
12
|
#pragma once
|
11
13
|
|
@@ -16,7 +18,7 @@ namespace duckdb {
|
|
16
18
|
struct DecodeFun {
|
17
19
|
static constexpr const char *Name = "decode";
|
18
20
|
static constexpr const char *Parameters = "blob";
|
19
|
-
static constexpr const char *Description = "Convert blob to varchar. Fails if blob is not valid utf-8
|
21
|
+
static constexpr const char *Description = "Convert blob to varchar. Fails if blob is not valid utf-8";
|
20
22
|
static constexpr const char *Example = "decode('\\xC3\\xBC'::BLOB)";
|
21
23
|
|
22
24
|
static ScalarFunction GetFunction();
|
@@ -25,7 +27,7 @@ struct DecodeFun {
|
|
25
27
|
struct EncodeFun {
|
26
28
|
static constexpr const char *Name = "encode";
|
27
29
|
static constexpr const char *Parameters = "string";
|
28
|
-
static constexpr const char *Description = "Convert varchar to blob. Converts utf-8 characters into literal encoding
|
30
|
+
static constexpr const char *Description = "Convert varchar to blob. Converts utf-8 characters into literal encoding";
|
29
31
|
static constexpr const char *Example = "encode('my_string_with_ü')";
|
30
32
|
|
31
33
|
static ScalarFunction GetFunction();
|
@@ -34,7 +36,7 @@ struct EncodeFun {
|
|
34
36
|
struct FromBase64Fun {
|
35
37
|
static constexpr const char *Name = "from_base64";
|
36
38
|
static constexpr const char *Parameters = "string";
|
37
|
-
static constexpr const char *Description = "Convert a base64 encoded string to a character string
|
39
|
+
static constexpr const char *Description = "Convert a base64 encoded string to a character string";
|
38
40
|
static constexpr const char *Example = "from_base64('QQ==')";
|
39
41
|
|
40
42
|
static ScalarFunction GetFunction();
|
@@ -43,7 +45,7 @@ struct FromBase64Fun {
|
|
43
45
|
struct ToBase64Fun {
|
44
46
|
static constexpr const char *Name = "to_base64";
|
45
47
|
static constexpr const char *Parameters = "blob";
|
46
|
-
static constexpr const char *Description = "Convert a blob to a base64 encoded string
|
48
|
+
static constexpr const char *Description = "Convert a blob to a base64 encoded string";
|
47
49
|
static constexpr const char *Example = "base64('A'::blob)";
|
48
50
|
|
49
51
|
static ScalarFunction GetFunction();
|