sequel 4.26.0 → 5.37.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.
- checksums.yaml +5 -5
- data/CHANGELOG +405 -5656
- data/MIT-LICENSE +1 -1
- data/README.rdoc +232 -157
- data/bin/sequel +32 -9
- data/doc/advanced_associations.rdoc +252 -188
- data/doc/association_basics.rdoc +231 -273
- data/doc/bin_sequel.rdoc +5 -3
- data/doc/cheat_sheet.rdoc +75 -48
- data/doc/code_order.rdoc +28 -10
- data/doc/core_extensions.rdoc +104 -63
- data/doc/dataset_basics.rdoc +12 -21
- data/doc/dataset_filtering.rdoc +99 -86
- data/doc/extensions.rdoc +3 -10
- data/doc/mass_assignment.rdoc +74 -31
- data/doc/migration.rdoc +72 -46
- data/doc/model_dataset_method_design.rdoc +129 -0
- data/doc/model_hooks.rdoc +15 -25
- data/doc/model_plugins.rdoc +12 -12
- data/doc/mssql_stored_procedures.rdoc +3 -3
- data/doc/object_model.rdoc +59 -69
- data/doc/opening_databases.rdoc +84 -94
- data/doc/postgresql.rdoc +268 -38
- data/doc/prepared_statements.rdoc +29 -24
- data/doc/querying.rdoc +184 -164
- data/doc/reflection.rdoc +5 -6
- data/doc/release_notes/5.0.0.txt +159 -0
- data/doc/release_notes/5.1.0.txt +31 -0
- data/doc/release_notes/5.10.0.txt +84 -0
- data/doc/release_notes/5.11.0.txt +83 -0
- data/doc/release_notes/5.12.0.txt +141 -0
- data/doc/release_notes/5.13.0.txt +27 -0
- data/doc/release_notes/5.14.0.txt +63 -0
- data/doc/release_notes/5.15.0.txt +39 -0
- data/doc/release_notes/5.16.0.txt +110 -0
- data/doc/release_notes/5.17.0.txt +31 -0
- data/doc/release_notes/5.18.0.txt +69 -0
- data/doc/release_notes/5.19.0.txt +28 -0
- data/doc/release_notes/5.2.0.txt +33 -0
- data/doc/release_notes/5.20.0.txt +89 -0
- data/doc/release_notes/5.21.0.txt +87 -0
- data/doc/release_notes/5.22.0.txt +48 -0
- data/doc/release_notes/5.23.0.txt +56 -0
- data/doc/release_notes/5.24.0.txt +56 -0
- data/doc/release_notes/5.25.0.txt +32 -0
- data/doc/release_notes/5.26.0.txt +35 -0
- data/doc/release_notes/5.27.0.txt +21 -0
- data/doc/release_notes/5.28.0.txt +16 -0
- data/doc/release_notes/5.29.0.txt +22 -0
- data/doc/release_notes/5.3.0.txt +121 -0
- data/doc/release_notes/5.30.0.txt +20 -0
- data/doc/release_notes/5.31.0.txt +148 -0
- data/doc/release_notes/5.32.0.txt +46 -0
- data/doc/release_notes/5.33.0.txt +24 -0
- data/doc/release_notes/5.34.0.txt +40 -0
- data/doc/release_notes/5.35.0.txt +56 -0
- data/doc/release_notes/5.36.0.txt +60 -0
- data/doc/release_notes/5.37.0.txt +30 -0
- data/doc/release_notes/5.4.0.txt +80 -0
- data/doc/release_notes/5.5.0.txt +61 -0
- data/doc/release_notes/5.6.0.txt +31 -0
- data/doc/release_notes/5.7.0.txt +108 -0
- data/doc/release_notes/5.8.0.txt +170 -0
- data/doc/release_notes/5.9.0.txt +99 -0
- data/doc/schema_modification.rdoc +102 -77
- data/doc/security.rdoc +160 -87
- data/doc/sharding.rdoc +74 -47
- data/doc/sql.rdoc +135 -122
- data/doc/testing.rdoc +34 -18
- data/doc/thread_safety.rdoc +2 -4
- data/doc/transactions.rdoc +101 -19
- data/doc/validations.rdoc +64 -51
- data/doc/virtual_rows.rdoc +90 -109
- data/lib/sequel.rb +3 -1
- data/lib/sequel/adapters/ado.rb +154 -22
- data/lib/sequel/adapters/ado/access.rb +21 -21
- data/lib/sequel/adapters/ado/mssql.rb +8 -15
- data/lib/sequel/adapters/amalgalite.rb +17 -25
- data/lib/sequel/adapters/ibmdb.rb +52 -58
- data/lib/sequel/adapters/jdbc.rb +149 -127
- data/lib/sequel/adapters/jdbc/db2.rb +32 -40
- data/lib/sequel/adapters/jdbc/derby.rb +56 -58
- data/lib/sequel/adapters/jdbc/h2.rb +40 -30
- data/lib/sequel/adapters/jdbc/hsqldb.rb +22 -33
- data/lib/sequel/adapters/jdbc/jtds.rb +4 -10
- data/lib/sequel/adapters/jdbc/mssql.rb +6 -12
- data/lib/sequel/adapters/jdbc/mysql.rb +17 -18
- data/lib/sequel/adapters/jdbc/oracle.rb +25 -19
- data/lib/sequel/adapters/jdbc/postgresql.rb +90 -69
- data/lib/sequel/adapters/jdbc/sqlanywhere.rb +14 -24
- data/lib/sequel/adapters/jdbc/sqlite.rb +50 -12
- data/lib/sequel/adapters/jdbc/sqlserver.rb +36 -9
- data/lib/sequel/adapters/jdbc/transactions.rb +25 -39
- data/lib/sequel/adapters/mock.rb +104 -113
- data/lib/sequel/adapters/mysql.rb +42 -61
- data/lib/sequel/adapters/mysql2.rb +126 -35
- data/lib/sequel/adapters/odbc.rb +21 -28
- data/lib/sequel/adapters/odbc/db2.rb +3 -1
- data/lib/sequel/adapters/odbc/mssql.rb +11 -15
- data/lib/sequel/adapters/odbc/oracle.rb +11 -0
- data/lib/sequel/adapters/oracle.rb +62 -68
- data/lib/sequel/adapters/postgres.rb +257 -311
- data/lib/sequel/adapters/postgresql.rb +3 -1
- data/lib/sequel/adapters/shared/access.rb +75 -79
- data/lib/sequel/adapters/shared/db2.rb +96 -74
- data/lib/sequel/adapters/shared/mssql.rb +258 -213
- data/lib/sequel/adapters/shared/mysql.rb +284 -216
- data/lib/sequel/adapters/shared/oracle.rb +175 -60
- data/lib/sequel/adapters/shared/postgres.rb +829 -383
- data/lib/sequel/adapters/shared/sqlanywhere.rb +105 -127
- data/lib/sequel/adapters/shared/sqlite.rb +382 -159
- data/lib/sequel/adapters/sqlanywhere.rb +53 -38
- data/lib/sequel/adapters/sqlite.rb +111 -105
- data/lib/sequel/adapters/tinytds.rb +38 -46
- data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +8 -9
- data/lib/sequel/adapters/utils/emulate_offset_with_row_number.rb +7 -5
- data/lib/sequel/adapters/utils/mysql_mysql2.rb +87 -0
- data/lib/sequel/adapters/utils/mysql_prepared_statements.rb +56 -0
- data/lib/sequel/adapters/utils/replace.rb +3 -4
- data/lib/sequel/adapters/utils/split_alter_table.rb +2 -0
- data/lib/sequel/adapters/utils/stored_procedures.rb +9 -22
- data/lib/sequel/adapters/utils/unmodified_identifiers.rb +28 -0
- data/lib/sequel/ast_transformer.rb +13 -89
- data/lib/sequel/connection_pool.rb +54 -26
- data/lib/sequel/connection_pool/sharded_single.rb +19 -12
- data/lib/sequel/connection_pool/sharded_threaded.rb +160 -111
- data/lib/sequel/connection_pool/single.rb +21 -12
- data/lib/sequel/connection_pool/threaded.rb +137 -119
- data/lib/sequel/core.rb +352 -320
- data/lib/sequel/database.rb +19 -2
- data/lib/sequel/database/connecting.rb +70 -55
- data/lib/sequel/database/dataset.rb +15 -5
- data/lib/sequel/database/dataset_defaults.rb +20 -102
- data/lib/sequel/database/features.rb +20 -4
- data/lib/sequel/database/logging.rb +25 -7
- data/lib/sequel/database/misc.rb +132 -118
- data/lib/sequel/database/query.rb +51 -28
- data/lib/sequel/database/schema_generator.rb +188 -75
- data/lib/sequel/database/schema_methods.rb +161 -92
- data/lib/sequel/database/transactions.rb +260 -58
- data/lib/sequel/dataset.rb +28 -12
- data/lib/sequel/dataset/actions.rb +354 -170
- data/lib/sequel/dataset/dataset_module.rb +46 -0
- data/lib/sequel/dataset/features.rb +81 -34
- data/lib/sequel/dataset/graph.rb +82 -58
- data/lib/sequel/dataset/misc.rb +139 -47
- data/lib/sequel/dataset/placeholder_literalizer.rb +66 -26
- data/lib/sequel/dataset/prepared_statements.rb +188 -85
- data/lib/sequel/dataset/query.rb +428 -214
- data/lib/sequel/dataset/sql.rb +446 -339
- data/lib/sequel/deprecated.rb +14 -2
- data/lib/sequel/exceptions.rb +48 -16
- data/lib/sequel/extensions/_model_constraint_validations.rb +16 -0
- data/lib/sequel/extensions/_model_pg_row.rb +43 -0
- data/lib/sequel/extensions/_pretty_table.rb +10 -9
- data/lib/sequel/extensions/any_not_empty.rb +45 -0
- data/lib/sequel/extensions/arbitrary_servers.rb +15 -11
- data/lib/sequel/extensions/auto_literal_strings.rb +74 -0
- data/lib/sequel/extensions/blank.rb +2 -0
- data/lib/sequel/extensions/caller_logging.rb +79 -0
- data/lib/sequel/extensions/columns_introspection.rb +9 -4
- data/lib/sequel/extensions/connection_expiration.rb +99 -0
- data/lib/sequel/extensions/connection_validator.rb +26 -13
- data/lib/sequel/extensions/constant_sql_override.rb +65 -0
- data/lib/sequel/extensions/constraint_validations.rb +93 -38
- data/lib/sequel/extensions/core_extensions.rb +45 -53
- data/lib/sequel/extensions/core_refinements.rb +44 -46
- data/lib/sequel/extensions/current_datetime_timestamp.rb +5 -4
- data/lib/sequel/extensions/dataset_source_alias.rb +4 -0
- data/lib/sequel/extensions/date_arithmetic.rb +42 -16
- data/lib/sequel/extensions/datetime_parse_to_time.rb +37 -0
- data/lib/sequel/extensions/duplicate_columns_handler.rb +94 -0
- data/lib/sequel/extensions/empty_array_consider_nulls.rb +7 -3
- data/lib/sequel/extensions/error_sql.rb +7 -3
- data/lib/sequel/extensions/escaped_like.rb +100 -0
- data/lib/sequel/extensions/eval_inspect.rb +14 -15
- data/lib/sequel/extensions/exclude_or_null.rb +68 -0
- data/lib/sequel/extensions/fiber_concurrency.rb +24 -0
- data/lib/sequel/extensions/freeze_datasets.rb +3 -0
- data/lib/sequel/extensions/from_block.rb +2 -31
- data/lib/sequel/extensions/graph_each.rb +19 -6
- data/lib/sequel/extensions/identifier_mangling.rb +180 -0
- data/lib/sequel/extensions/implicit_subquery.rb +48 -0
- data/lib/sequel/extensions/index_caching.rb +109 -0
- data/lib/sequel/extensions/inflector.rb +8 -4
- data/lib/sequel/extensions/integer64.rb +32 -0
- data/lib/sequel/extensions/looser_typecasting.rb +19 -9
- data/lib/sequel/extensions/migration.rb +132 -80
- data/lib/sequel/extensions/mssql_emulate_lateral_with_apply.rb +4 -0
- data/lib/sequel/extensions/named_timezones.rb +88 -23
- data/lib/sequel/extensions/no_auto_literal_strings.rb +4 -0
- data/lib/sequel/extensions/null_dataset.rb +12 -8
- data/lib/sequel/extensions/pagination.rb +35 -28
- data/lib/sequel/extensions/pg_array.rb +227 -316
- data/lib/sequel/extensions/pg_array_ops.rb +19 -7
- data/lib/sequel/extensions/pg_enum.rb +69 -24
- data/lib/sequel/extensions/pg_extended_date_support.rb +250 -0
- data/lib/sequel/extensions/pg_hstore.rb +50 -59
- data/lib/sequel/extensions/pg_hstore_ops.rb +9 -3
- data/lib/sequel/extensions/pg_inet.rb +34 -15
- data/lib/sequel/extensions/pg_inet_ops.rb +5 -1
- data/lib/sequel/extensions/pg_interval.rb +26 -26
- data/lib/sequel/extensions/pg_json.rb +422 -141
- data/lib/sequel/extensions/pg_json_ops.rb +248 -9
- data/lib/sequel/extensions/pg_loose_count.rb +5 -1
- data/lib/sequel/extensions/pg_range.rb +162 -146
- data/lib/sequel/extensions/pg_range_ops.rb +10 -5
- data/lib/sequel/extensions/pg_row.rb +53 -87
- data/lib/sequel/extensions/pg_row_ops.rb +36 -13
- data/lib/sequel/extensions/pg_static_cache_updater.rb +6 -2
- data/lib/sequel/extensions/pg_timestamptz.rb +28 -0
- data/lib/sequel/extensions/pretty_table.rb +4 -0
- data/lib/sequel/extensions/query.rb +12 -7
- data/lib/sequel/extensions/round_timestamps.rb +6 -9
- data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
- data/lib/sequel/extensions/s.rb +59 -0
- data/lib/sequel/extensions/schema_caching.rb +14 -1
- data/lib/sequel/extensions/schema_dumper.rb +83 -55
- data/lib/sequel/extensions/select_remove.rb +8 -4
- data/lib/sequel/extensions/sequel_4_dataset_methods.rb +85 -0
- data/lib/sequel/extensions/server_block.rb +50 -17
- data/lib/sequel/extensions/server_logging.rb +61 -0
- data/lib/sequel/extensions/split_array_nil.rb +8 -4
- data/lib/sequel/extensions/sql_comments.rb +96 -0
- data/lib/sequel/extensions/sql_expr.rb +4 -1
- data/lib/sequel/extensions/string_agg.rb +181 -0
- data/lib/sequel/extensions/string_date_time.rb +2 -0
- data/lib/sequel/extensions/symbol_aref.rb +53 -0
- data/lib/sequel/extensions/symbol_aref_refinement.rb +43 -0
- data/lib/sequel/extensions/symbol_as.rb +23 -0
- data/lib/sequel/extensions/symbol_as_refinement.rb +37 -0
- data/lib/sequel/extensions/synchronize_sql.rb +45 -0
- data/lib/sequel/extensions/thread_local_timezones.rb +4 -0
- data/lib/sequel/extensions/to_dot.rb +15 -5
- data/lib/sequel/extensions/virtual_row_method_block.rb +44 -0
- data/lib/sequel/model.rb +36 -126
- data/lib/sequel/model/associations.rb +850 -257
- data/lib/sequel/model/base.rb +652 -764
- data/lib/sequel/model/dataset_module.rb +13 -10
- data/lib/sequel/model/default_inflections.rb +3 -1
- data/lib/sequel/model/errors.rb +3 -3
- data/lib/sequel/model/exceptions.rb +12 -12
- data/lib/sequel/model/inflections.rb +8 -19
- data/lib/sequel/model/plugins.rb +111 -0
- data/lib/sequel/plugins/accessed_columns.rb +2 -0
- data/lib/sequel/plugins/active_model.rb +32 -7
- data/lib/sequel/plugins/after_initialize.rb +3 -1
- data/lib/sequel/plugins/association_dependencies.rb +27 -18
- data/lib/sequel/plugins/association_lazy_eager_option.rb +66 -0
- data/lib/sequel/plugins/association_multi_add_remove.rb +85 -0
- data/lib/sequel/plugins/association_pks.rb +181 -83
- data/lib/sequel/plugins/association_proxies.rb +33 -9
- data/lib/sequel/plugins/auto_validations.rb +58 -23
- data/lib/sequel/plugins/before_after_save.rb +8 -0
- data/lib/sequel/plugins/blacklist_security.rb +23 -12
- data/lib/sequel/plugins/boolean_readers.rb +9 -6
- data/lib/sequel/plugins/boolean_subsets.rb +64 -0
- data/lib/sequel/plugins/caching.rb +27 -16
- data/lib/sequel/plugins/class_table_inheritance.rb +192 -94
- data/lib/sequel/plugins/column_conflicts.rb +18 -3
- data/lib/sequel/plugins/column_select.rb +9 -5
- data/lib/sequel/plugins/columns_updated.rb +42 -0
- data/lib/sequel/plugins/composition.rb +36 -24
- data/lib/sequel/plugins/constraint_validations.rb +37 -16
- data/lib/sequel/plugins/csv_serializer.rb +58 -35
- data/lib/sequel/plugins/dataset_associations.rb +60 -18
- data/lib/sequel/plugins/def_dataset_method.rb +90 -0
- data/lib/sequel/plugins/defaults_setter.rb +74 -13
- data/lib/sequel/plugins/delay_add_association.rb +4 -1
- data/lib/sequel/plugins/dirty.rb +65 -24
- data/lib/sequel/plugins/eager_each.rb +27 -3
- data/lib/sequel/plugins/eager_graph_eager.rb +139 -0
- data/lib/sequel/plugins/empty_failure_backtraces.rb +38 -0
- data/lib/sequel/plugins/error_splitter.rb +19 -12
- data/lib/sequel/plugins/finder.rb +246 -0
- data/lib/sequel/plugins/forbid_lazy_load.rb +216 -0
- data/lib/sequel/plugins/force_encoding.rb +9 -12
- data/lib/sequel/plugins/hook_class_methods.rb +39 -54
- data/lib/sequel/plugins/input_transformer.rb +20 -10
- data/lib/sequel/plugins/insert_conflict.rb +72 -0
- data/lib/sequel/plugins/insert_returning_select.rb +4 -2
- data/lib/sequel/plugins/instance_filters.rb +12 -8
- data/lib/sequel/plugins/instance_hooks.rb +36 -17
- data/lib/sequel/plugins/instance_specific_default.rb +113 -0
- data/lib/sequel/plugins/inverted_subsets.rb +24 -13
- data/lib/sequel/plugins/json_serializer.rb +123 -47
- data/lib/sequel/plugins/lazy_attributes.rb +20 -14
- data/lib/sequel/plugins/list.rb +40 -26
- data/lib/sequel/plugins/many_through_many.rb +28 -12
- data/lib/sequel/plugins/modification_detection.rb +17 -5
- data/lib/sequel/plugins/mssql_optimistic_locking.rb +8 -5
- data/lib/sequel/plugins/nested_attributes.rb +55 -28
- data/lib/sequel/plugins/optimistic_locking.rb +5 -3
- data/lib/sequel/plugins/pg_array_associations.rb +52 -18
- data/lib/sequel/plugins/pg_auto_constraint_validations.rb +348 -0
- data/lib/sequel/plugins/pg_row.rb +7 -51
- data/lib/sequel/plugins/prepared_statements.rb +53 -72
- data/lib/sequel/plugins/prepared_statements_safe.rb +13 -5
- data/lib/sequel/plugins/rcte_tree.rb +43 -63
- data/lib/sequel/plugins/serialization.rb +37 -44
- data/lib/sequel/plugins/serialization_modification_detection.rb +3 -1
- data/lib/sequel/plugins/sharding.rb +17 -10
- data/lib/sequel/plugins/single_table_inheritance.rb +62 -28
- data/lib/sequel/plugins/singular_table_names.rb +2 -0
- data/lib/sequel/plugins/skip_create_refresh.rb +5 -3
- data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
- data/lib/sequel/plugins/split_values.rb +13 -6
- data/lib/sequel/plugins/static_cache.rb +79 -53
- data/lib/sequel/plugins/static_cache_cache.rb +53 -0
- data/lib/sequel/plugins/string_stripper.rb +5 -3
- data/lib/sequel/plugins/subclasses.rb +20 -2
- data/lib/sequel/plugins/subset_conditions.rb +48 -0
- data/lib/sequel/plugins/table_select.rb +4 -2
- data/lib/sequel/plugins/tactical_eager_loading.rb +120 -6
- data/lib/sequel/plugins/throw_failures.rb +110 -0
- data/lib/sequel/plugins/timestamps.rb +22 -8
- data/lib/sequel/plugins/touch.rb +21 -8
- data/lib/sequel/plugins/tree.rb +57 -30
- data/lib/sequel/plugins/typecast_on_load.rb +14 -4
- data/lib/sequel/plugins/unlimited_update.rb +3 -7
- data/lib/sequel/plugins/update_or_create.rb +6 -4
- data/lib/sequel/plugins/update_primary_key.rb +3 -1
- data/lib/sequel/plugins/update_refresh.rb +28 -15
- data/lib/sequel/plugins/uuid.rb +70 -0
- data/lib/sequel/plugins/validate_associated.rb +20 -0
- data/lib/sequel/plugins/validation_class_methods.rb +40 -19
- data/lib/sequel/plugins/validation_contexts.rb +49 -0
- data/lib/sequel/plugins/validation_helpers.rb +49 -31
- data/lib/sequel/plugins/whitelist_security.rb +122 -0
- data/lib/sequel/plugins/xml_serializer.rb +31 -30
- data/lib/sequel/sql.rb +479 -329
- data/lib/sequel/timezones.rb +62 -32
- data/lib/sequel/version.rb +10 -3
- metadata +177 -477
- data/Rakefile +0 -165
- data/doc/active_record.rdoc +0 -912
- data/doc/release_notes/1.0.txt +0 -38
- data/doc/release_notes/1.1.txt +0 -143
- data/doc/release_notes/1.3.txt +0 -101
- data/doc/release_notes/1.4.0.txt +0 -53
- data/doc/release_notes/1.5.0.txt +0 -155
- data/doc/release_notes/2.0.0.txt +0 -298
- data/doc/release_notes/2.1.0.txt +0 -271
- data/doc/release_notes/2.10.0.txt +0 -328
- data/doc/release_notes/2.11.0.txt +0 -215
- data/doc/release_notes/2.12.0.txt +0 -534
- data/doc/release_notes/2.2.0.txt +0 -253
- data/doc/release_notes/2.3.0.txt +0 -88
- data/doc/release_notes/2.4.0.txt +0 -106
- data/doc/release_notes/2.5.0.txt +0 -137
- data/doc/release_notes/2.6.0.txt +0 -157
- data/doc/release_notes/2.7.0.txt +0 -166
- data/doc/release_notes/2.8.0.txt +0 -171
- data/doc/release_notes/2.9.0.txt +0 -97
- data/doc/release_notes/3.0.0.txt +0 -221
- data/doc/release_notes/3.1.0.txt +0 -406
- data/doc/release_notes/3.10.0.txt +0 -286
- data/doc/release_notes/3.11.0.txt +0 -254
- data/doc/release_notes/3.12.0.txt +0 -304
- data/doc/release_notes/3.13.0.txt +0 -210
- data/doc/release_notes/3.14.0.txt +0 -118
- data/doc/release_notes/3.15.0.txt +0 -78
- data/doc/release_notes/3.16.0.txt +0 -45
- data/doc/release_notes/3.17.0.txt +0 -58
- data/doc/release_notes/3.18.0.txt +0 -120
- data/doc/release_notes/3.19.0.txt +0 -67
- data/doc/release_notes/3.2.0.txt +0 -268
- data/doc/release_notes/3.20.0.txt +0 -41
- data/doc/release_notes/3.21.0.txt +0 -87
- data/doc/release_notes/3.22.0.txt +0 -39
- data/doc/release_notes/3.23.0.txt +0 -172
- data/doc/release_notes/3.24.0.txt +0 -420
- data/doc/release_notes/3.25.0.txt +0 -88
- data/doc/release_notes/3.26.0.txt +0 -88
- data/doc/release_notes/3.27.0.txt +0 -82
- data/doc/release_notes/3.28.0.txt +0 -304
- data/doc/release_notes/3.29.0.txt +0 -459
- data/doc/release_notes/3.3.0.txt +0 -192
- data/doc/release_notes/3.30.0.txt +0 -135
- data/doc/release_notes/3.31.0.txt +0 -146
- data/doc/release_notes/3.32.0.txt +0 -202
- data/doc/release_notes/3.33.0.txt +0 -157
- data/doc/release_notes/3.34.0.txt +0 -671
- data/doc/release_notes/3.35.0.txt +0 -144
- data/doc/release_notes/3.36.0.txt +0 -245
- data/doc/release_notes/3.37.0.txt +0 -338
- data/doc/release_notes/3.38.0.txt +0 -234
- data/doc/release_notes/3.39.0.txt +0 -237
- data/doc/release_notes/3.4.0.txt +0 -325
- data/doc/release_notes/3.40.0.txt +0 -73
- data/doc/release_notes/3.41.0.txt +0 -155
- data/doc/release_notes/3.42.0.txt +0 -74
- data/doc/release_notes/3.43.0.txt +0 -105
- data/doc/release_notes/3.44.0.txt +0 -152
- data/doc/release_notes/3.45.0.txt +0 -179
- data/doc/release_notes/3.46.0.txt +0 -122
- data/doc/release_notes/3.47.0.txt +0 -270
- data/doc/release_notes/3.48.0.txt +0 -477
- data/doc/release_notes/3.5.0.txt +0 -510
- data/doc/release_notes/3.6.0.txt +0 -366
- data/doc/release_notes/3.7.0.txt +0 -179
- data/doc/release_notes/3.8.0.txt +0 -151
- data/doc/release_notes/3.9.0.txt +0 -233
- data/doc/release_notes/4.0.0.txt +0 -262
- data/doc/release_notes/4.1.0.txt +0 -85
- data/doc/release_notes/4.10.0.txt +0 -226
- data/doc/release_notes/4.11.0.txt +0 -147
- data/doc/release_notes/4.12.0.txt +0 -105
- data/doc/release_notes/4.13.0.txt +0 -169
- data/doc/release_notes/4.14.0.txt +0 -68
- data/doc/release_notes/4.15.0.txt +0 -56
- data/doc/release_notes/4.16.0.txt +0 -36
- data/doc/release_notes/4.17.0.txt +0 -38
- data/doc/release_notes/4.18.0.txt +0 -36
- data/doc/release_notes/4.19.0.txt +0 -45
- data/doc/release_notes/4.2.0.txt +0 -129
- data/doc/release_notes/4.20.0.txt +0 -79
- data/doc/release_notes/4.21.0.txt +0 -94
- data/doc/release_notes/4.22.0.txt +0 -72
- data/doc/release_notes/4.23.0.txt +0 -65
- data/doc/release_notes/4.24.0.txt +0 -99
- data/doc/release_notes/4.25.0.txt +0 -181
- data/doc/release_notes/4.26.0.txt +0 -44
- data/doc/release_notes/4.3.0.txt +0 -40
- data/doc/release_notes/4.4.0.txt +0 -92
- data/doc/release_notes/4.5.0.txt +0 -34
- data/doc/release_notes/4.6.0.txt +0 -30
- data/doc/release_notes/4.7.0.txt +0 -103
- data/doc/release_notes/4.8.0.txt +0 -175
- data/doc/release_notes/4.9.0.txt +0 -190
- data/lib/sequel/adapters/cubrid.rb +0 -142
- data/lib/sequel/adapters/do.rb +0 -156
- data/lib/sequel/adapters/do/mysql.rb +0 -64
- data/lib/sequel/adapters/do/postgres.rb +0 -42
- data/lib/sequel/adapters/do/sqlite3.rb +0 -40
- data/lib/sequel/adapters/jdbc/as400.rb +0 -82
- data/lib/sequel/adapters/jdbc/cubrid.rb +0 -62
- data/lib/sequel/adapters/jdbc/firebirdsql.rb +0 -34
- data/lib/sequel/adapters/jdbc/informix-sqli.rb +0 -31
- data/lib/sequel/adapters/jdbc/jdbcprogress.rb +0 -31
- data/lib/sequel/adapters/odbc/progress.rb +0 -8
- data/lib/sequel/adapters/shared/cubrid.rb +0 -243
- data/lib/sequel/adapters/shared/firebird.rb +0 -245
- data/lib/sequel/adapters/shared/informix.rb +0 -52
- data/lib/sequel/adapters/shared/mysql_prepared_statements.rb +0 -150
- data/lib/sequel/adapters/shared/progress.rb +0 -38
- data/lib/sequel/adapters/swift.rb +0 -158
- data/lib/sequel/adapters/swift/mysql.rb +0 -47
- data/lib/sequel/adapters/swift/postgres.rb +0 -45
- data/lib/sequel/adapters/swift/sqlite.rb +0 -47
- data/lib/sequel/adapters/utils/pg_types.rb +0 -68
- data/lib/sequel/dataset/mutation.rb +0 -109
- data/lib/sequel/extensions/empty_array_ignore_nulls.rb +0 -3
- data/lib/sequel/extensions/filter_having.rb +0 -59
- data/lib/sequel/extensions/hash_aliases.rb +0 -45
- data/lib/sequel/extensions/meta_def.rb +0 -31
- data/lib/sequel/extensions/query_literals.rb +0 -80
- data/lib/sequel/extensions/ruby18_symbol_extensions.rb +0 -22
- data/lib/sequel/extensions/sequel_3_dataset_methods.rb +0 -118
- data/lib/sequel/extensions/set_overrides.rb +0 -72
- data/lib/sequel/no_core_ext.rb +0 -1
- data/lib/sequel/plugins/association_autoreloading.rb +0 -7
- data/lib/sequel/plugins/many_to_one_pk_lookup.rb +0 -7
- data/lib/sequel/plugins/pg_typecast_on_load.rb +0 -78
- data/lib/sequel/plugins/prepared_statements_associations.rb +0 -117
- data/lib/sequel/plugins/prepared_statements_with_pk.rb +0 -59
- data/lib/sequel/plugins/schema.rb +0 -80
- data/lib/sequel/plugins/scissors.rb +0 -33
- data/spec/adapters/db2_spec.rb +0 -160
- data/spec/adapters/firebird_spec.rb +0 -411
- data/spec/adapters/informix_spec.rb +0 -100
- data/spec/adapters/mssql_spec.rb +0 -706
- data/spec/adapters/mysql_spec.rb +0 -1287
- data/spec/adapters/oracle_spec.rb +0 -313
- data/spec/adapters/postgres_spec.rb +0 -3725
- data/spec/adapters/spec_helper.rb +0 -43
- data/spec/adapters/sqlanywhere_spec.rb +0 -170
- data/spec/adapters/sqlite_spec.rb +0 -653
- data/spec/bin_spec.rb +0 -254
- data/spec/core/connection_pool_spec.rb +0 -1016
- data/spec/core/database_spec.rb +0 -2531
- data/spec/core/dataset_spec.rb +0 -5098
- data/spec/core/deprecated_spec.rb +0 -70
- data/spec/core/expression_filters_spec.rb +0 -1243
- data/spec/core/mock_adapter_spec.rb +0 -462
- data/spec/core/object_graph_spec.rb +0 -303
- data/spec/core/placeholder_literalizer_spec.rb +0 -163
- data/spec/core/schema_generator_spec.rb +0 -179
- data/spec/core/schema_spec.rb +0 -1659
- data/spec/core/spec_helper.rb +0 -34
- data/spec/core/version_spec.rb +0 -7
- data/spec/core_extensions_spec.rb +0 -699
- data/spec/extensions/accessed_columns_spec.rb +0 -51
- data/spec/extensions/active_model_spec.rb +0 -123
- data/spec/extensions/after_initialize_spec.rb +0 -24
- data/spec/extensions/arbitrary_servers_spec.rb +0 -109
- data/spec/extensions/association_dependencies_spec.rb +0 -117
- data/spec/extensions/association_pks_spec.rb +0 -365
- data/spec/extensions/association_proxies_spec.rb +0 -86
- data/spec/extensions/auto_validations_spec.rb +0 -192
- data/spec/extensions/blacklist_security_spec.rb +0 -88
- data/spec/extensions/blank_spec.rb +0 -69
- data/spec/extensions/boolean_readers_spec.rb +0 -93
- data/spec/extensions/caching_spec.rb +0 -270
- data/spec/extensions/class_table_inheritance_spec.rb +0 -420
- data/spec/extensions/column_conflicts_spec.rb +0 -60
- data/spec/extensions/column_select_spec.rb +0 -108
- data/spec/extensions/columns_introspection_spec.rb +0 -91
- data/spec/extensions/composition_spec.rb +0 -242
- data/spec/extensions/connection_validator_spec.rb +0 -120
- data/spec/extensions/constraint_validations_plugin_spec.rb +0 -274
- data/spec/extensions/constraint_validations_spec.rb +0 -325
- data/spec/extensions/core_refinements_spec.rb +0 -519
- data/spec/extensions/csv_serializer_spec.rb +0 -173
- data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
- data/spec/extensions/dataset_associations_spec.rb +0 -311
- data/spec/extensions/dataset_source_alias_spec.rb +0 -51
- data/spec/extensions/date_arithmetic_spec.rb +0 -150
- data/spec/extensions/defaults_setter_spec.rb +0 -101
- data/spec/extensions/delay_add_association_spec.rb +0 -52
- data/spec/extensions/dirty_spec.rb +0 -180
- data/spec/extensions/eager_each_spec.rb +0 -42
- data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
- data/spec/extensions/error_splitter_spec.rb +0 -18
- data/spec/extensions/error_sql_spec.rb +0 -20
- data/spec/extensions/eval_inspect_spec.rb +0 -73
- data/spec/extensions/filter_having_spec.rb +0 -40
- data/spec/extensions/force_encoding_spec.rb +0 -114
- data/spec/extensions/from_block_spec.rb +0 -21
- data/spec/extensions/graph_each_spec.rb +0 -109
- data/spec/extensions/hash_aliases_spec.rb +0 -24
- data/spec/extensions/hook_class_methods_spec.rb +0 -429
- data/spec/extensions/inflector_spec.rb +0 -183
- data/spec/extensions/input_transformer_spec.rb +0 -54
- data/spec/extensions/insert_returning_select_spec.rb +0 -46
- data/spec/extensions/instance_filters_spec.rb +0 -79
- data/spec/extensions/instance_hooks_spec.rb +0 -276
- data/spec/extensions/inverted_subsets_spec.rb +0 -33
- data/spec/extensions/json_serializer_spec.rb +0 -291
- data/spec/extensions/lazy_attributes_spec.rb +0 -170
- data/spec/extensions/list_spec.rb +0 -267
- data/spec/extensions/looser_typecasting_spec.rb +0 -43
- data/spec/extensions/many_through_many_spec.rb +0 -2172
- data/spec/extensions/meta_def_spec.rb +0 -21
- data/spec/extensions/migration_spec.rb +0 -712
- data/spec/extensions/modification_detection_spec.rb +0 -80
- data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -91
- data/spec/extensions/named_timezones_spec.rb +0 -108
- data/spec/extensions/nested_attributes_spec.rb +0 -697
- data/spec/extensions/null_dataset_spec.rb +0 -85
- data/spec/extensions/optimistic_locking_spec.rb +0 -128
- data/spec/extensions/pagination_spec.rb +0 -118
- data/spec/extensions/pg_array_associations_spec.rb +0 -736
- data/spec/extensions/pg_array_ops_spec.rb +0 -143
- data/spec/extensions/pg_array_spec.rb +0 -395
- data/spec/extensions/pg_enum_spec.rb +0 -92
- data/spec/extensions/pg_hstore_ops_spec.rb +0 -236
- data/spec/extensions/pg_hstore_spec.rb +0 -206
- data/spec/extensions/pg_inet_ops_spec.rb +0 -101
- data/spec/extensions/pg_inet_spec.rb +0 -52
- data/spec/extensions/pg_interval_spec.rb +0 -76
- data/spec/extensions/pg_json_ops_spec.rb +0 -229
- data/spec/extensions/pg_json_spec.rb +0 -218
- data/spec/extensions/pg_loose_count_spec.rb +0 -17
- data/spec/extensions/pg_range_ops_spec.rb +0 -58
- data/spec/extensions/pg_range_spec.rb +0 -404
- data/spec/extensions/pg_row_ops_spec.rb +0 -60
- data/spec/extensions/pg_row_plugin_spec.rb +0 -62
- data/spec/extensions/pg_row_spec.rb +0 -360
- data/spec/extensions/pg_static_cache_updater_spec.rb +0 -92
- data/spec/extensions/pg_typecast_on_load_spec.rb +0 -63
- data/spec/extensions/prepared_statements_associations_spec.rb +0 -159
- data/spec/extensions/prepared_statements_safe_spec.rb +0 -61
- data/spec/extensions/prepared_statements_spec.rb +0 -103
- data/spec/extensions/prepared_statements_with_pk_spec.rb +0 -31
- data/spec/extensions/pretty_table_spec.rb +0 -92
- data/spec/extensions/query_literals_spec.rb +0 -183
- data/spec/extensions/query_spec.rb +0 -102
- data/spec/extensions/rcte_tree_spec.rb +0 -392
- data/spec/extensions/round_timestamps_spec.rb +0 -43
- data/spec/extensions/schema_caching_spec.rb +0 -41
- data/spec/extensions/schema_dumper_spec.rb +0 -789
- data/spec/extensions/schema_spec.rb +0 -117
- data/spec/extensions/scissors_spec.rb +0 -26
- data/spec/extensions/select_remove_spec.rb +0 -38
- data/spec/extensions/sequel_3_dataset_methods_spec.rb +0 -101
- data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
- data/spec/extensions/serialization_spec.rb +0 -362
- data/spec/extensions/server_block_spec.rb +0 -90
- data/spec/extensions/set_overrides_spec.rb +0 -61
- data/spec/extensions/sharding_spec.rb +0 -198
- data/spec/extensions/shared_caching_spec.rb +0 -175
- data/spec/extensions/single_table_inheritance_spec.rb +0 -297
- data/spec/extensions/singular_table_names_spec.rb +0 -22
- data/spec/extensions/skip_create_refresh_spec.rb +0 -17
- data/spec/extensions/spec_helper.rb +0 -71
- data/spec/extensions/split_array_nil_spec.rb +0 -24
- data/spec/extensions/split_values_spec.rb +0 -22
- data/spec/extensions/sql_expr_spec.rb +0 -60
- data/spec/extensions/static_cache_spec.rb +0 -361
- data/spec/extensions/string_date_time_spec.rb +0 -95
- data/spec/extensions/string_stripper_spec.rb +0 -68
- data/spec/extensions/subclasses_spec.rb +0 -66
- data/spec/extensions/table_select_spec.rb +0 -71
- data/spec/extensions/tactical_eager_loading_spec.rb +0 -82
- data/spec/extensions/thread_local_timezones_spec.rb +0 -67
- data/spec/extensions/timestamps_spec.rb +0 -175
- data/spec/extensions/to_dot_spec.rb +0 -154
- data/spec/extensions/touch_spec.rb +0 -203
- data/spec/extensions/tree_spec.rb +0 -274
- data/spec/extensions/typecast_on_load_spec.rb +0 -80
- data/spec/extensions/unlimited_update_spec.rb +0 -20
- data/spec/extensions/update_or_create_spec.rb +0 -87
- data/spec/extensions/update_primary_key_spec.rb +0 -100
- data/spec/extensions/update_refresh_spec.rb +0 -53
- data/spec/extensions/validate_associated_spec.rb +0 -52
- data/spec/extensions/validation_class_methods_spec.rb +0 -1027
- data/spec/extensions/validation_helpers_spec.rb +0 -541
- data/spec/extensions/xml_serializer_spec.rb +0 -207
- data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
- data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
- data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
- data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
- data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
- data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
- data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
- data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
- data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
- data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
- data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
- data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
- data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
- data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
- data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
- data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
- data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
- data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
- data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
- data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
- data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
- data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
- data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
- data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
- data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
- data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
- data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
- data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
- data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
- data/spec/files/reversible_migrations/001_reversible.rb +0 -5
- data/spec/files/reversible_migrations/002_reversible.rb +0 -5
- data/spec/files/reversible_migrations/003_reversible.rb +0 -5
- data/spec/files/reversible_migrations/004_reversible.rb +0 -5
- data/spec/files/reversible_migrations/005_reversible.rb +0 -10
- data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
- data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
- data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
- data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
- data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
- data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
- data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
- data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
- data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
- data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
- data/spec/guards_helper.rb +0 -55
- data/spec/integration/associations_test.rb +0 -2454
- data/spec/integration/database_test.rb +0 -113
- data/spec/integration/dataset_test.rb +0 -1808
- data/spec/integration/eager_loader_test.rb +0 -687
- data/spec/integration/migrator_test.rb +0 -240
- data/spec/integration/model_test.rb +0 -226
- data/spec/integration/plugin_test.rb +0 -2240
- data/spec/integration/prepared_statement_test.rb +0 -467
- data/spec/integration/schema_test.rb +0 -817
- data/spec/integration/spec_helper.rb +0 -48
- data/spec/integration/timezone_test.rb +0 -86
- data/spec/integration/transaction_test.rb +0 -374
- data/spec/integration/type_test.rb +0 -133
- data/spec/model/association_reflection_spec.rb +0 -525
- data/spec/model/associations_spec.rb +0 -4426
- data/spec/model/base_spec.rb +0 -759
- data/spec/model/class_dataset_methods_spec.rb +0 -146
- data/spec/model/dataset_methods_spec.rb +0 -149
- data/spec/model/eager_loading_spec.rb +0 -2137
- data/spec/model/hooks_spec.rb +0 -604
- data/spec/model/inflector_spec.rb +0 -26
- data/spec/model/model_spec.rb +0 -982
- data/spec/model/plugins_spec.rb +0 -299
- data/spec/model/record_spec.rb +0 -2147
- data/spec/model/spec_helper.rb +0 -46
- data/spec/model/validations_spec.rb +0 -193
- data/spec/sequel_coverage.rb +0 -15
- data/spec/spec_config.rb +0 -10
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* The pg_json extension now adds a Database#wrap_json_primitives
|
|
4
|
+
accessor. When set to true, JSON primitive values (string, number,
|
|
5
|
+
true, false, and null) will be wrapped by delegate Ruby objects
|
|
6
|
+
instead of using Ruby primitives. This allows the values to round
|
|
7
|
+
trip, so the following code will work even for primitive values in
|
|
8
|
+
json_column:
|
|
9
|
+
|
|
10
|
+
DB.extension :pg_json
|
|
11
|
+
DB.wrap_json_primitives = true
|
|
12
|
+
value = DB[:table].get(:json_column)
|
|
13
|
+
DB[:other_table].insert(json_column: value)
|
|
14
|
+
|
|
15
|
+
This should be enabled with care, especially in cases where false
|
|
16
|
+
and null JSON values are used, as the behavior will change if
|
|
17
|
+
the objects are used in a boolean context in Ruby, as only false
|
|
18
|
+
and nil in Ruby are treated as false:
|
|
19
|
+
|
|
20
|
+
# assume JSON false or null value
|
|
21
|
+
value = DB[:table].get(:json_column)
|
|
22
|
+
|
|
23
|
+
if value
|
|
24
|
+
# executed if wrap_json_primitives is true
|
|
25
|
+
else
|
|
26
|
+
# executed by default
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
When typecasting input in model objects to a JSON type, string
|
|
30
|
+
input will still be parsed as JSON. However, you can set the
|
|
31
|
+
Database#typecast_json_strings accessor to true, and then string
|
|
32
|
+
input will be considered as a JSON string instead of parsing the
|
|
33
|
+
string as JSON.
|
|
34
|
+
|
|
35
|
+
To prevent backwards compatibility issues, Sequel.pg_json/pg_jsonb
|
|
36
|
+
behavior has not changed. To support wrapping Ruby primitives in
|
|
37
|
+
the delegate objects, new Sequel.pg_json_wrap/pg_jsonb_wrap methods
|
|
38
|
+
have been added. These methods only handle the Ruby primitives,
|
|
39
|
+
they cannot be used if the existing object is already a delegate
|
|
40
|
+
object.
|
|
41
|
+
|
|
42
|
+
As model objects always consider a nil value as SQL NULL and do
|
|
43
|
+
not typecast it, if you want to explicitly set a JSON null value,
|
|
44
|
+
you need to wrap it explicitly:
|
|
45
|
+
|
|
46
|
+
model_object.json_column = Sequel.pg_json_wrap(nil)
|
|
47
|
+
|
|
48
|
+
= Other Improvements
|
|
49
|
+
|
|
50
|
+
* Sequel now supports window function options :window, :exclude, and
|
|
51
|
+
:frame :type=>:groups, :start, and :end on SQLite 3.28.0+.
|
|
52
|
+
|
|
53
|
+
* The server_block extension now respects the :servers_hash Database
|
|
54
|
+
option. This makes it more similar to Sequel's default behavior.
|
|
55
|
+
However, that means by default, the server_block extension will
|
|
56
|
+
default to handling unknown shards as the default shard, instead
|
|
57
|
+
of raising an error for them.
|
|
58
|
+
|
|
59
|
+
* The rcte_tree plugin now disallows eager graphing of the ancestors
|
|
60
|
+
and descendants associations. Previously, eager graphing of these
|
|
61
|
+
associations generated incorrect results. It is not possible to
|
|
62
|
+
eager graph these extensions, but normal eager loading does work.
|
|
63
|
+
|
|
64
|
+
* The ado adapter's performance has been improved by using faster
|
|
65
|
+
callables for type conversion and a more efficient inner loop.
|
|
66
|
+
|
|
67
|
+
* The sqlite adapter now converts a :timeout option given as a string
|
|
68
|
+
to an integer. This allows you to use the option inside of a
|
|
69
|
+
connection string.
|
|
70
|
+
|
|
71
|
+
* The mysql and mysql2 adapters now recognize an additional
|
|
72
|
+
DatabaseLockTimeout error.
|
|
73
|
+
|
|
74
|
+
* The jdbc/mysql adapter now works correctly when using JRuby with
|
|
75
|
+
Java 11.
|
|
76
|
+
|
|
77
|
+
* The ado adapter now handles numeric values when using locales that
|
|
78
|
+
use comma instead of period as the decimal separator.
|
|
79
|
+
|
|
80
|
+
= Backwards Compatibility
|
|
81
|
+
|
|
82
|
+
* In the pg_json extension, the following singleton methods of
|
|
83
|
+
Sequel::Postgres::JSONDatabaseMethods are now deprecated:
|
|
84
|
+
|
|
85
|
+
* parse_json
|
|
86
|
+
* db_parse_json
|
|
87
|
+
* db_parse_jsonb
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* Sequel now supports Ruby 2.7+ startless ranges in filters:
|
|
4
|
+
|
|
5
|
+
DB[:table].where(:column=>(..10))
|
|
6
|
+
# SELECT * FROM table WHERE (column <= 10)
|
|
7
|
+
|
|
8
|
+
DB[:table].where(:column=>(...10))
|
|
9
|
+
# SELECT * FROM table WHERE (column < 10)
|
|
10
|
+
|
|
11
|
+
It also supports startless, endless ranges in filters, using a
|
|
12
|
+
condition that is always true:
|
|
13
|
+
|
|
14
|
+
DB[:table].where(:column=>(nil..nil))
|
|
15
|
+
# SELECT * FROM table WHERE (1 = 1)
|
|
16
|
+
|
|
17
|
+
* Sequel now supports startless ranges in the pg_range extension:
|
|
18
|
+
|
|
19
|
+
DB.extension :pg_range
|
|
20
|
+
|
|
21
|
+
DB[:table].insert(:column=>(..10))
|
|
22
|
+
# INSERT INTO "table" ("column") VALUES ('[,10]') RETURNING "id"
|
|
23
|
+
|
|
24
|
+
DB[:table].insert(:column=>(...10))
|
|
25
|
+
# INSERT INTO "table" ("column") VALUES ('[,10)') RETURNING "id"
|
|
26
|
+
|
|
27
|
+
DB[:table].insert(:column=>(nil..nil))
|
|
28
|
+
# INSERT INTO "table" ("column") VALUES ('[,]') RETURNING "id"
|
|
29
|
+
|
|
30
|
+
* Sequel now supports a :materialized option in Dataset#with on
|
|
31
|
+
PostgreSQL 12+, to control the inlining of common table expressions:
|
|
32
|
+
|
|
33
|
+
DB[:t].with(:t, DB[:t2], :materialized=>false)
|
|
34
|
+
# WITH "t" AS NOT MATERIALIZED (SELECT * FROM "t2")
|
|
35
|
+
# SELECT * FROM "t"
|
|
36
|
+
|
|
37
|
+
DB[:t].with(:t, DB[:t2], :materialized=>true)
|
|
38
|
+
# WITH "t" AS MATERIALIZED (SELECT * FROM "t2")
|
|
39
|
+
# SELECT * FROM "t"
|
|
40
|
+
|
|
41
|
+
= Other Improvements
|
|
42
|
+
|
|
43
|
+
* Database#primary_key_sequence now works for tables without serial
|
|
44
|
+
sequences on PostgreSQL 12+.
|
|
45
|
+
|
|
46
|
+
* Dataset#multi_insert and #import with return: :primary_key option
|
|
47
|
+
on Microsoft SQL Server now work correctly if the dataset uses
|
|
48
|
+
a row_proc (e.g. for model datasets).
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* An insert_conflict plugin has been added for automatically handling
|
|
4
|
+
constraint conflicts when saving new model instances. It is
|
|
5
|
+
supported on PostgreSQL 9.5+ and SQLite 3.24.0+.
|
|
6
|
+
|
|
7
|
+
Album.new(name: 'Foo', copies_sold: 1000).
|
|
8
|
+
insert_conflict(
|
|
9
|
+
target: :name,
|
|
10
|
+
update: {copies_sold: Sequel[:excluded][:b]}
|
|
11
|
+
).
|
|
12
|
+
save
|
|
13
|
+
|
|
14
|
+
* On Microsoft SQL Server, the Database :ansi option has been added,
|
|
15
|
+
which sets the following ANSI related options:
|
|
16
|
+
|
|
17
|
+
* ANSI_NULLS
|
|
18
|
+
* ANSI_PADDING
|
|
19
|
+
* ANSI_WARNINGS
|
|
20
|
+
* ANSI_NULL_DFLT_ON
|
|
21
|
+
* QUOTED_IDENTIFIER
|
|
22
|
+
* CONCAT_NULL_YIELDS_NULL
|
|
23
|
+
|
|
24
|
+
= Other Improvements
|
|
25
|
+
|
|
26
|
+
* Sequel.datetime_class = Time is now supported when using the
|
|
27
|
+
named_timezones extension. For backwards compatibility, the
|
|
28
|
+
named_timezones extension still sets
|
|
29
|
+
Sequel.datetime_class = DateTime. When using Ruby 2.6+, the
|
|
30
|
+
Time instances have the timezone set on them using Ruby 2.6+'s
|
|
31
|
+
timezone support, but basic support works correctly in earlier
|
|
32
|
+
versions of Ruby.
|
|
33
|
+
|
|
34
|
+
* On Microsoft SQL Server, Sequel now handles parsing schema for
|
|
35
|
+
tables in another database on the same server or in a database
|
|
36
|
+
on a linked server.
|
|
37
|
+
|
|
38
|
+
* The pg_json extension now correctly handles subclasses of core
|
|
39
|
+
classes when wrapping objects. This stopped working in Sequel
|
|
40
|
+
5.21.0, when support for wrapping JSON primitives was added.
|
|
41
|
+
|
|
42
|
+
* Sequel now works around a couple bugs in jdbc-sqlite 3.27.2.1,
|
|
43
|
+
allowing schema parsing and foreign key parsing to work.
|
|
44
|
+
|
|
45
|
+
* Dataset#execute* private methods now respect an explicitly given
|
|
46
|
+
:server option, fixing Dataset#paged_each in the postgres adapter
|
|
47
|
+
when using sharding.
|
|
48
|
+
|
|
49
|
+
* Timezone offsets are now handled correctly when typecasting an array
|
|
50
|
+
or hash to datetime when Sequel.datetime_class = Time.
|
|
51
|
+
|
|
52
|
+
* Sequel now avoids errors when parsing schema when using the mock
|
|
53
|
+
SQLite adapter.
|
|
54
|
+
|
|
55
|
+
* A minor thread-safety issue has been fixed in the named_timezones
|
|
56
|
+
extension.
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* A :cache_file plugin option has been added to the
|
|
4
|
+
pg_auto_constraint_validations plugin. This option specifies
|
|
5
|
+
a file to use to cache the metadata the plugin uses, so the
|
|
6
|
+
plugin does not need to run 5 queries per model at startup to
|
|
7
|
+
load the metadata. This can dramatically improve startup time
|
|
8
|
+
when using the plugin with a large number of models.
|
|
9
|
+
|
|
10
|
+
To create the metadata file, load the plugin into Sequel::Model
|
|
11
|
+
(or whatever class you are using as the base class for your
|
|
12
|
+
model classes) with the :cache_file option, and after loading
|
|
13
|
+
all of the subclasses of that class, run:
|
|
14
|
+
|
|
15
|
+
Sequel::Model.dump_pg_auto_constraint_validations_cache
|
|
16
|
+
|
|
17
|
+
As when using the schema_caching and index_caching extensions,
|
|
18
|
+
it is up to the user to ensure that the cached metadata matches
|
|
19
|
+
the current database schema. Sequel does no checking of this,
|
|
20
|
+
as checking would take more time, and the point of this plugin
|
|
21
|
+
is to improve startup performance.
|
|
22
|
+
|
|
23
|
+
* A static_cache_cache plugin has been added. This plugin allows
|
|
24
|
+
for caching rows for models using the static_cache plugin. This
|
|
25
|
+
prevents the need to issue a query at model creation time to
|
|
26
|
+
get the rows. This plugin should be loaded into Sequel::Model
|
|
27
|
+
(or whatever class you are using as the base class for your
|
|
28
|
+
model classes) before loading the models using the static_cache
|
|
29
|
+
plugin. To create the metadata file, after all subclasses of
|
|
30
|
+
that class have been loaded, run:
|
|
31
|
+
|
|
32
|
+
Sequel::Model.dump_static_cache_cache
|
|
33
|
+
|
|
34
|
+
* :unique_deferrable and :primary_key_deferrable column
|
|
35
|
+
options are now supported on PostgreSQL 9+ and Oracle. This
|
|
36
|
+
allows you to created deferrable unique and primary key
|
|
37
|
+
column constraints. You could already create deferrable
|
|
38
|
+
table constraints using the :deferrable option to the primary_key
|
|
39
|
+
and unique methods.
|
|
40
|
+
|
|
41
|
+
* A :generated_always_as column option is now supported on
|
|
42
|
+
PostgreSQL 12+, for creating generated columns.
|
|
43
|
+
|
|
44
|
+
* A Database#skip_logging? private method has been added. This
|
|
45
|
+
is designed for use in extensions, to force log timing even
|
|
46
|
+
when no loggers are configured.
|
|
47
|
+
|
|
48
|
+
= Other Improvements
|
|
49
|
+
|
|
50
|
+
* Sequel no longer sets the :host option to localhost by default
|
|
51
|
+
in the mysql2 adapter. This prevents Sequel from overriding
|
|
52
|
+
a host specified in the defaults_file.
|
|
53
|
+
|
|
54
|
+
* All database array types are converted to Ruby arrays in the
|
|
55
|
+
jdbc adapter. Previously, this was only done in the
|
|
56
|
+
jdbc/postgresql subadapter.
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* An association_multi_add_remove plugin has been added. This plugin
|
|
4
|
+
adds a shortcut for adding or removing multiple associated objects
|
|
5
|
+
in a single method call:
|
|
6
|
+
|
|
7
|
+
Artist.plugin :association_multi_add_remove
|
|
8
|
+
Artist.many_to_one :albums
|
|
9
|
+
Artist[1].add_albums([Album[2], Album[3]])
|
|
10
|
+
Artist[1].remove_albums([Album[4], Album[5]])
|
|
11
|
+
|
|
12
|
+
It also offers a setter method, which will add and remove associated
|
|
13
|
+
objects as necessary:
|
|
14
|
+
|
|
15
|
+
Artist[1].albums = [Album[3], Album[4]]
|
|
16
|
+
|
|
17
|
+
= Other Improvements
|
|
18
|
+
|
|
19
|
+
* The sharding plugin now integrates with the server_block extension.
|
|
20
|
+
This makes it so if you retrieve a model instance inside a
|
|
21
|
+
with_server block, saving the model instance will save it back to
|
|
22
|
+
the shard from which it was retrieved.
|
|
23
|
+
|
|
24
|
+
* Setting a default for a column on Microsoft SQL Server now works
|
|
25
|
+
correctly if the column already has a default.
|
|
26
|
+
|
|
27
|
+
* Sequel::SQL::NumericMethods#coerce no longer raises NoMethodError
|
|
28
|
+
if the super method is not defined. This fixes some cases when
|
|
29
|
+
comparing Date/DateTime instances to Sequel objects.
|
|
30
|
+
|
|
31
|
+
* The csv_serializer plugin now avoids keyword argument separation
|
|
32
|
+
issues on Ruby 2.7+.
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* Support for SQL/JSON path expressions has been added to the
|
|
4
|
+
pg_json_ops extension. These are supported in PostgreSQL 12+.
|
|
5
|
+
Examples:
|
|
6
|
+
|
|
7
|
+
j = Sequel.pg_json_op(:json_column)
|
|
8
|
+
j.path_exists('$.foo') # (jsonb_column @? '$.foo')
|
|
9
|
+
j.path_match('$.foo') # (jsonb_column @@ '$.foo')
|
|
10
|
+
j.path_exists!('$.foo') # jsonb_path_exists(jsonb_column, '$.foo')
|
|
11
|
+
j.path_match!('$.foo') # jsonb_path_match(jsonb_column, '$.foo')
|
|
12
|
+
j.path_query('$.foo') # jsonb_path_query(jsonb_column, '$.foo')
|
|
13
|
+
j.path_query_array('$.foo') # jsonb_path_query_array(jsonb_column, '$.foo')
|
|
14
|
+
j.path_query_first('$.foo') # jsonb_path_query_first(jsonb_column, '$.foo')
|
|
15
|
+
|
|
16
|
+
* The nested_attributes method in the nested_attributes plugin now
|
|
17
|
+
supports a :require_modification option, which can override the
|
|
18
|
+
default require_modification setting for the nested objects. This
|
|
19
|
+
can be useful to avoid errors if multiple requests are submitted
|
|
20
|
+
simultaneously to delete the same nested row.
|
|
21
|
+
|
|
22
|
+
= Other Improvements
|
|
23
|
+
|
|
24
|
+
* The dirty plugin now works correctly with the typecast_on_load
|
|
25
|
+
plugin.
|
|
26
|
+
|
|
27
|
+
* Sequel::Postgres::PGRange#hash has been added to the pg_range
|
|
28
|
+
extension, allowing PGRange instances to be usable as hash keys.
|
|
29
|
+
|
|
30
|
+
* Table aliases are now supported for single table INSERT
|
|
31
|
+
statements on PostgreSQL 9.5+, which can make some insert_conflict
|
|
32
|
+
usage easier.
|
|
33
|
+
|
|
34
|
+
* Two more foreign key constraint violation types are now recognized
|
|
35
|
+
on MySQL 8.0.13+.
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* Sequel::DEFAULT has been added a constant for the DEFAULT expression,
|
|
4
|
+
useful in inserts and especially updates:
|
|
5
|
+
|
|
6
|
+
DB[:a].where(:id=>1).update(:b=>Sequel::DEFAULT)
|
|
7
|
+
# UPDATE "a" SET "b" = DEFAULT WHERE "id" = 1
|
|
8
|
+
|
|
9
|
+
* SQL::Function#filter for filtered aggregate functions is now
|
|
10
|
+
supported on all databases. On databases not supporting it natively
|
|
11
|
+
(all except PostgreSQL 9.4+ and SQLite 3.30+), a CASE statement is
|
|
12
|
+
used to emulate the support.
|
|
13
|
+
|
|
14
|
+
= Other Improvements
|
|
15
|
+
|
|
16
|
+
* NULLS FIRST/LAST is now used without emulation on SQLite 3.30+.
|
|
17
|
+
|
|
18
|
+
* The pg_enum extension now works correctly on PostgreSQL 8.3-9.0.
|
|
19
|
+
|
|
20
|
+
* Postgres::ArrayOp#join in the pg_array_ops extension now works
|
|
21
|
+
correctly on PostgreSQL <9.1.
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* An any_not_empty extension has been added, for making Dataset#any?
|
|
4
|
+
without a block be the same as !empty?. This can result in a
|
|
5
|
+
much faster database query.
|
|
6
|
+
|
|
7
|
+
* An exclude_or_null extension has been added, adding a
|
|
8
|
+
Dataset#exclude_or_null method that returns rows where the given
|
|
9
|
+
expression is false or NULL. This extension is supported on
|
|
10
|
+
PostgreSQL, SQLite, MySQL, H2, and HSQLDB.
|
|
11
|
+
|
|
12
|
+
= Other Improvements
|
|
13
|
+
|
|
14
|
+
* When using the jdbc/postgresql adapter, calling with_fetch_size
|
|
15
|
+
on a dataset will emit a warning. This is because the driver
|
|
16
|
+
will ignore the setting.
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* An empty_failure_backtraces plugin has been added for using empty
|
|
4
|
+
backtraces for ValidationFailed and HookFailed exceptions. In many
|
|
5
|
+
cases, these exceptions are automatically handled (e.g. web form
|
|
6
|
+
submission handling to display appropriate error pages), and using
|
|
7
|
+
empty backtraces is 10-15x faster on JRuby 9.2.7.0+.
|
|
8
|
+
|
|
9
|
+
* Dataset#json_serializer_opts has been added to the json_serializer
|
|
10
|
+
plugin. This allows setting default options on a per-Dataset basis
|
|
11
|
+
for all Dataset#to_json calls.
|
|
12
|
+
|
|
13
|
+
= Other Improvements
|
|
14
|
+
|
|
15
|
+
* Another disconnect error is now recognized in the tinytds adapter.
|
|
16
|
+
|
|
17
|
+
* Using Sequel with the the CRuby master branch (what will be Ruby 3)
|
|
18
|
+
now works by supporting a second argument for
|
|
19
|
+
Dataset#initialize_clone.
|
|
20
|
+
|
|
21
|
+
* Sequel now avoids a warning in verbose mode when using the postgres
|
|
22
|
+
adapter, a recent version of ruby-pg, and bound variables.
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
= New Features
|
|
2
|
+
|
|
3
|
+
* An :extensions Database option is now supported, which will load the
|
|
4
|
+
named extensions into the Database before any connections are
|
|
5
|
+
initiated:
|
|
6
|
+
|
|
7
|
+
DB = Sequel.connect('mock:///', :extensions=>[:error_sql, :synchronize_sql])
|
|
8
|
+
DB = Sequel.connect('mock:///?extensions=error_sql,synchronize_sql')
|
|
9
|
+
|
|
10
|
+
* A :connect_sqls Database option is now supported, which will issue
|
|
11
|
+
the given queries on all new connections:
|
|
12
|
+
|
|
13
|
+
DB = Sequel.connect('postgres:///', :connect_sqls=>[
|
|
14
|
+
'SET random_page_cost = 1.0',
|
|
15
|
+
"SET default_tablespace = 'foo'"
|
|
16
|
+
])
|
|
17
|
+
|
|
18
|
+
* DatasetModule#reverse has been added for simpler use of descending
|
|
19
|
+
orders:
|
|
20
|
+
|
|
21
|
+
class Foo < Sequel::Model
|
|
22
|
+
dataset_module do
|
|
23
|
+
reverse :newest_first, :created_at
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
Foo.newest_first.first(10)
|
|
27
|
+
|
|
28
|
+
* A synchronize_sql extension has been added. This extension checks
|
|
29
|
+
out a connection around SQL string creation, and is useful in the
|
|
30
|
+
cases where escaping values in the query requires a connection and
|
|
31
|
+
a large number of values need to be escaped.
|
|
32
|
+
|
|
33
|
+
* The following features are now supported on MariaDB 10.2+:
|
|
34
|
+
|
|
35
|
+
* Common table expressions.
|
|
36
|
+
|
|
37
|
+
* Window functions.
|
|
38
|
+
|
|
39
|
+
* Dropping CHECK constraints. Older versions of MariaDB/MySQL
|
|
40
|
+
ignored CHECK constraints that were added, and Sequel did not
|
|
41
|
+
attempt to filter them out, so Sequel did not require changes to
|
|
42
|
+
add CHECK constraints. MariaDB 10.2 CHECK constraints work
|
|
43
|
+
correctly with Sequel's constraint_validations extension/plugin.
|
|
44
|
+
|
|
45
|
+
* Raising CHECK constraint violations as
|
|
46
|
+
Sequel::CheckConstraintViolation instances.
|
|
47
|
+
|
|
48
|
+
* Recognizing curdate() as Sequel::CURRENT_DATE when used as the
|
|
49
|
+
default value for a date column.
|
|
50
|
+
|
|
51
|
+
* Date::Infinity values are now supported in the
|
|
52
|
+
pg_extended_date_support extension:
|
|
53
|
+
|
|
54
|
+
DB.convert_infinite_timestamps = :date
|
|
55
|
+
|
|
56
|
+
This returns infinite dates/timestamps as Date::Infinity instances,
|
|
57
|
+
and literalizes Date::Infinity instances correctly.
|
|
58
|
+
|
|
59
|
+
= Improvements
|
|
60
|
+
|
|
61
|
+
* Database#reset_primary_key_sequence now works correctly on
|
|
62
|
+
PostgreSQL 10.
|
|
63
|
+
|
|
64
|
+
* If a commit or rollback raises an exception when using the postgres
|
|
65
|
+
adapter, Sequel will check the connection's current transaction
|
|
66
|
+
status and only send another rollback if the connection is currently
|
|
67
|
+
inside a transaction. This fixes a warning that is issued in most
|
|
68
|
+
cases if a commit or rollback fails.
|
|
69
|
+
|
|
70
|
+
* The jdbc/postgresql adapter now forces JDBC PreparedStatement
|
|
71
|
+
instances created by Dataset#call to never be prepared server side,
|
|
72
|
+
working around an caching issue in the jdbc-postgres drier in
|
|
73
|
+
versions greater than 9.4.1200.
|
|
74
|
+
|
|
75
|
+
* Database#indexes will no longer return indexes which are in the
|
|
76
|
+
process of being dropped on PostgreSQL 9.3+. Additionally,
|
|
77
|
+
Database#indexes will now return indexes that have indcheckxmin
|
|
78
|
+
set. The previous removal of indexes with indcheckxmin set is
|
|
79
|
+
more likely to cause false negatives than correctly remove
|
|
80
|
+
indexes not yet valid.
|
|
81
|
+
|
|
82
|
+
* Common table expressions are no longer hoisted from subqueries on
|
|
83
|
+
SQLite. They are still hoisted from queries used in
|
|
84
|
+
UNION/INSERT/EXCEPT, since SQLite does not support common table
|
|
85
|
+
expressions at that level.
|
|
86
|
+
|
|
87
|
+
* On Microsoft SQL Server, using an INSERT query with a subquery that
|
|
88
|
+
uses a common table expression now hoists the common table
|
|
89
|
+
expression from subquery level to main query level, allowing such
|
|
90
|
+
queries to work.
|
|
91
|
+
|
|
92
|
+
* An additional disconnect error is now recognized in the oracle
|
|
93
|
+
adapter.
|
|
94
|
+
|
|
95
|
+
* bin/sequel now adds a Database logger before the initial
|
|
96
|
+
connection is made, allowing you to see any connection setup
|
|
97
|
+
statements issued to the database.
|
|
98
|
+
|
|
99
|
+
= Backwards Compatibility
|
|
100
|
+
|
|
101
|
+
* Calling a filtering method with no argument and a virtual row
|
|
102
|
+
block that returns nil on a dataset with no existing filter is
|
|
103
|
+
deprecated in this version and will emit a warning. The behavior
|
|
104
|
+
in this version remains the same, where the dataset is not
|
|
105
|
+
modified. The behavior will change in Sequel 5.4.0 so that a
|
|
106
|
+
WHERE NULL filter will be added in that case, instead of the
|
|
107
|
+
filter being ignored, so that the behavior is similar to calling
|
|
108
|
+
the filtering method with a nil argument.
|
|
109
|
+
|
|
110
|
+
# Sequel 5.3.0
|
|
111
|
+
DB[:a].where{nil}
|
|
112
|
+
# SELECT * FROM a
|
|
113
|
+
|
|
114
|
+
# Sequel 5.4.0
|
|
115
|
+
DB[:a].where{nil}
|
|
116
|
+
# SELECT * FROM a WHERE NULL
|
|
117
|
+
|
|
118
|
+
* Support for PostgreSQL <8.1 has been dropped from Database#indexes.
|
|
119
|
+
Sequel's PostgreSQL support requires >=8.2 for Dataset#insert to
|
|
120
|
+
work, so it doesn't make sense to support earlier versions in other
|
|
121
|
+
cases.
|