sequel 4.36.0 → 5.61.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 +548 -5749
- data/MIT-LICENSE +1 -1
- data/README.rdoc +265 -159
- data/bin/sequel +34 -12
- data/doc/advanced_associations.rdoc +228 -187
- data/doc/association_basics.rdoc +281 -291
- data/doc/bin_sequel.rdoc +5 -3
- data/doc/cheat_sheet.rdoc +86 -51
- data/doc/code_order.rdoc +25 -19
- 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/fork_safety.rdoc +84 -0
- data/doc/mass_assignment.rdoc +74 -31
- data/doc/migration.rdoc +59 -51
- 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 +58 -68
- data/doc/opening_databases.rdoc +85 -95
- data/doc/postgresql.rdoc +263 -38
- data/doc/prepared_statements.rdoc +29 -24
- data/doc/querying.rdoc +189 -167
- 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.38.0.txt +28 -0
- data/doc/release_notes/5.39.0.txt +19 -0
- data/doc/release_notes/5.4.0.txt +80 -0
- data/doc/release_notes/5.40.0.txt +40 -0
- data/doc/release_notes/5.41.0.txt +25 -0
- data/doc/release_notes/5.42.0.txt +136 -0
- data/doc/release_notes/5.43.0.txt +98 -0
- data/doc/release_notes/5.44.0.txt +32 -0
- data/doc/release_notes/5.45.0.txt +34 -0
- data/doc/release_notes/5.46.0.txt +87 -0
- data/doc/release_notes/5.47.0.txt +59 -0
- data/doc/release_notes/5.48.0.txt +14 -0
- data/doc/release_notes/5.49.0.txt +59 -0
- data/doc/release_notes/5.5.0.txt +61 -0
- data/doc/release_notes/5.50.0.txt +78 -0
- data/doc/release_notes/5.51.0.txt +47 -0
- data/doc/release_notes/5.52.0.txt +87 -0
- data/doc/release_notes/5.53.0.txt +23 -0
- data/doc/release_notes/5.54.0.txt +27 -0
- data/doc/release_notes/5.55.0.txt +21 -0
- data/doc/release_notes/5.56.0.txt +51 -0
- data/doc/release_notes/5.57.0.txt +23 -0
- data/doc/release_notes/5.58.0.txt +31 -0
- data/doc/release_notes/5.59.0.txt +73 -0
- data/doc/release_notes/5.6.0.txt +31 -0
- data/doc/release_notes/5.60.0.txt +22 -0
- data/doc/release_notes/5.61.0.txt +43 -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 +95 -75
- data/doc/security.rdoc +109 -80
- data/doc/sharding.rdoc +74 -47
- data/doc/sql.rdoc +147 -122
- data/doc/testing.rdoc +43 -20
- data/doc/thread_safety.rdoc +2 -4
- data/doc/transactions.rdoc +97 -18
- data/doc/validations.rdoc +52 -50
- data/doc/virtual_rows.rdoc +90 -109
- data/lib/sequel/adapters/ado/access.rb +15 -17
- data/lib/sequel/adapters/ado/mssql.rb +6 -15
- data/lib/sequel/adapters/ado.rb +150 -20
- data/lib/sequel/adapters/amalgalite.rb +11 -23
- data/lib/sequel/adapters/ibmdb.rb +47 -55
- data/lib/sequel/adapters/jdbc/db2.rb +29 -39
- data/lib/sequel/adapters/jdbc/derby.rb +58 -54
- data/lib/sequel/adapters/jdbc/h2.rb +93 -35
- data/lib/sequel/adapters/jdbc/hsqldb.rb +24 -31
- data/lib/sequel/adapters/jdbc/jtds.rb +2 -10
- data/lib/sequel/adapters/jdbc/mssql.rb +3 -11
- data/lib/sequel/adapters/jdbc/mysql.rb +17 -20
- data/lib/sequel/adapters/jdbc/oracle.rb +22 -18
- data/lib/sequel/adapters/jdbc/postgresql.rb +69 -71
- data/lib/sequel/adapters/jdbc/sqlanywhere.rb +11 -23
- data/lib/sequel/adapters/jdbc/sqlite.rb +47 -11
- data/lib/sequel/adapters/jdbc/sqlserver.rb +34 -9
- data/lib/sequel/adapters/jdbc/transactions.rb +22 -38
- data/lib/sequel/adapters/jdbc.rb +145 -130
- data/lib/sequel/adapters/mock.rb +100 -111
- data/lib/sequel/adapters/mysql.rb +114 -122
- data/lib/sequel/adapters/mysql2.rb +147 -63
- data/lib/sequel/adapters/odbc/db2.rb +1 -1
- data/lib/sequel/adapters/odbc/mssql.rb +8 -14
- data/lib/sequel/adapters/odbc/oracle.rb +11 -0
- data/lib/sequel/adapters/odbc.rb +20 -25
- data/lib/sequel/adapters/oracle.rb +50 -56
- data/lib/sequel/adapters/postgres.rb +305 -327
- data/lib/sequel/adapters/postgresql.rb +1 -1
- data/lib/sequel/adapters/shared/access.rb +74 -78
- data/lib/sequel/adapters/shared/db2.rb +118 -71
- data/lib/sequel/adapters/shared/mssql.rb +301 -220
- data/lib/sequel/adapters/shared/mysql.rb +299 -217
- data/lib/sequel/adapters/shared/oracle.rb +226 -65
- data/lib/sequel/adapters/shared/postgres.rb +935 -395
- data/lib/sequel/adapters/shared/sqlanywhere.rb +105 -126
- data/lib/sequel/adapters/shared/sqlite.rb +447 -173
- data/lib/sequel/adapters/sqlanywhere.rb +48 -35
- data/lib/sequel/adapters/sqlite.rb +156 -111
- data/lib/sequel/adapters/tinytds.rb +30 -38
- data/lib/sequel/adapters/utils/columns_limit_1.rb +22 -0
- data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +3 -6
- data/lib/sequel/adapters/utils/emulate_offset_with_row_number.rb +2 -2
- 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 +1 -4
- data/lib/sequel/adapters/utils/stored_procedures.rb +7 -22
- data/lib/sequel/adapters/utils/unmodified_identifiers.rb +28 -0
- data/lib/sequel/ast_transformer.rb +17 -89
- data/lib/sequel/connection_pool/sharded_single.rb +18 -15
- data/lib/sequel/connection_pool/sharded_threaded.rb +130 -111
- data/lib/sequel/connection_pool/single.rb +18 -13
- data/lib/sequel/connection_pool/threaded.rb +121 -120
- data/lib/sequel/connection_pool.rb +48 -29
- data/lib/sequel/core.rb +351 -301
- data/lib/sequel/database/connecting.rb +69 -57
- data/lib/sequel/database/dataset.rb +13 -5
- data/lib/sequel/database/dataset_defaults.rb +18 -102
- data/lib/sequel/database/features.rb +18 -4
- data/lib/sequel/database/logging.rb +12 -11
- data/lib/sequel/database/misc.rb +180 -122
- data/lib/sequel/database/query.rb +47 -27
- data/lib/sequel/database/schema_generator.rb +178 -84
- data/lib/sequel/database/schema_methods.rb +172 -97
- data/lib/sequel/database/transactions.rb +205 -44
- data/lib/sequel/database.rb +17 -2
- data/lib/sequel/dataset/actions.rb +339 -155
- data/lib/sequel/dataset/dataset_module.rb +46 -0
- data/lib/sequel/dataset/features.rb +90 -35
- data/lib/sequel/dataset/graph.rb +80 -58
- data/lib/sequel/dataset/misc.rb +137 -47
- data/lib/sequel/dataset/placeholder_literalizer.rb +63 -25
- data/lib/sequel/dataset/prepared_statements.rb +188 -85
- data/lib/sequel/dataset/query.rb +530 -222
- data/lib/sequel/dataset/sql.rb +590 -368
- data/lib/sequel/dataset.rb +26 -16
- data/lib/sequel/deprecated.rb +12 -2
- data/lib/sequel/exceptions.rb +46 -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 +2 -5
- data/lib/sequel/extensions/any_not_empty.rb +45 -0
- data/lib/sequel/extensions/arbitrary_servers.rb +10 -10
- data/lib/sequel/extensions/async_thread_pool.rb +438 -0
- data/lib/sequel/extensions/auto_literal_strings.rb +74 -0
- data/lib/sequel/extensions/blank.rb +8 -0
- data/lib/sequel/extensions/caller_logging.rb +79 -0
- data/lib/sequel/extensions/columns_introspection.rb +4 -3
- data/lib/sequel/extensions/connection_expiration.rb +20 -10
- data/lib/sequel/extensions/connection_validator.rb +11 -10
- data/lib/sequel/extensions/constant_sql_override.rb +65 -0
- data/lib/sequel/extensions/constraint_validations.rb +62 -39
- data/lib/sequel/extensions/core_extensions.rb +42 -48
- data/lib/sequel/extensions/core_refinements.rb +80 -59
- data/lib/sequel/extensions/current_datetime_timestamp.rb +1 -4
- data/lib/sequel/extensions/date_arithmetic.rb +98 -39
- data/lib/sequel/extensions/date_parse_input_handler.rb +67 -0
- data/lib/sequel/extensions/datetime_parse_to_time.rb +41 -0
- data/lib/sequel/extensions/duplicate_columns_handler.rb +21 -14
- data/lib/sequel/extensions/empty_array_consider_nulls.rb +2 -2
- data/lib/sequel/extensions/escaped_like.rb +100 -0
- data/lib/sequel/extensions/eval_inspect.rb +12 -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 +1 -34
- data/lib/sequel/extensions/graph_each.rb +4 -4
- 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 +13 -5
- data/lib/sequel/extensions/integer64.rb +32 -0
- data/lib/sequel/extensions/is_distinct_from.rb +141 -0
- data/lib/sequel/extensions/looser_typecasting.rb +17 -8
- data/lib/sequel/extensions/migration.rb +119 -78
- data/lib/sequel/extensions/named_timezones.rb +88 -23
- data/lib/sequel/extensions/no_auto_literal_strings.rb +2 -82
- data/lib/sequel/extensions/null_dataset.rb +8 -8
- data/lib/sequel/extensions/pagination.rb +32 -29
- data/lib/sequel/extensions/pg_array.rb +221 -287
- data/lib/sequel/extensions/pg_array_ops.rb +17 -9
- data/lib/sequel/extensions/pg_enum.rb +63 -23
- data/lib/sequel/extensions/pg_extended_date_support.rb +241 -0
- data/lib/sequel/extensions/pg_hstore.rb +45 -54
- data/lib/sequel/extensions/pg_hstore_ops.rb +58 -6
- data/lib/sequel/extensions/pg_inet.rb +31 -12
- data/lib/sequel/extensions/pg_inet_ops.rb +2 -2
- data/lib/sequel/extensions/pg_interval.rb +56 -29
- data/lib/sequel/extensions/pg_json.rb +417 -140
- data/lib/sequel/extensions/pg_json_ops.rb +270 -18
- data/lib/sequel/extensions/pg_loose_count.rb +4 -2
- data/lib/sequel/extensions/pg_multirange.rb +372 -0
- data/lib/sequel/extensions/pg_range.rb +131 -191
- data/lib/sequel/extensions/pg_range_ops.rb +42 -13
- data/lib/sequel/extensions/pg_row.rb +48 -81
- data/lib/sequel/extensions/pg_row_ops.rb +33 -14
- data/lib/sequel/extensions/pg_static_cache_updater.rb +2 -2
- data/lib/sequel/extensions/pg_timestamptz.rb +28 -0
- data/lib/sequel/extensions/query.rb +9 -7
- data/lib/sequel/extensions/round_timestamps.rb +0 -6
- data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
- data/lib/sequel/extensions/s.rb +60 -0
- data/lib/sequel/extensions/schema_caching.rb +10 -1
- data/lib/sequel/extensions/schema_dumper.rb +71 -48
- data/lib/sequel/extensions/select_remove.rb +4 -4
- data/lib/sequel/extensions/sequel_4_dataset_methods.rb +85 -0
- data/lib/sequel/extensions/server_block.rb +51 -27
- data/lib/sequel/extensions/split_array_nil.rb +4 -4
- data/lib/sequel/extensions/sql_comments.rb +119 -7
- data/lib/sequel/extensions/sql_expr.rb +2 -1
- data/lib/sequel/extensions/sql_log_normalizer.rb +108 -0
- data/lib/sequel/extensions/sqlite_json_ops.rb +255 -0
- data/lib/sequel/extensions/string_agg.rb +11 -8
- data/lib/sequel/extensions/string_date_time.rb +19 -23
- data/lib/sequel/extensions/symbol_aref.rb +55 -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/to_dot.rb +10 -4
- data/lib/sequel/extensions/virtual_row_method_block.rb +44 -0
- data/lib/sequel/model/associations.rb +1006 -284
- data/lib/sequel/model/base.rb +560 -805
- data/lib/sequel/model/dataset_module.rb +11 -10
- data/lib/sequel/model/default_inflections.rb +1 -1
- data/lib/sequel/model/errors.rb +10 -3
- data/lib/sequel/model/exceptions.rb +8 -10
- data/lib/sequel/model/inflections.rb +7 -20
- data/lib/sequel/model/plugins.rb +114 -0
- data/lib/sequel/model.rb +32 -82
- data/lib/sequel/plugins/active_model.rb +30 -14
- data/lib/sequel/plugins/after_initialize.rb +1 -1
- data/lib/sequel/plugins/association_dependencies.rb +25 -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 +147 -70
- data/lib/sequel/plugins/association_proxies.rb +33 -9
- data/lib/sequel/plugins/async_thread_pool.rb +39 -0
- data/lib/sequel/plugins/auto_restrict_eager_graph.rb +62 -0
- data/lib/sequel/plugins/auto_validations.rb +95 -28
- data/lib/sequel/plugins/auto_validations_constraint_validations_presence_message.rb +68 -0
- data/lib/sequel/plugins/before_after_save.rb +0 -42
- data/lib/sequel/plugins/blacklist_security.rb +21 -12
- data/lib/sequel/plugins/boolean_readers.rb +5 -5
- data/lib/sequel/plugins/boolean_subsets.rb +13 -8
- data/lib/sequel/plugins/caching.rb +25 -16
- data/lib/sequel/plugins/class_table_inheritance.rb +179 -100
- data/lib/sequel/plugins/column_conflicts.rb +16 -3
- data/lib/sequel/plugins/column_encryption.rb +728 -0
- data/lib/sequel/plugins/column_select.rb +7 -5
- data/lib/sequel/plugins/columns_updated.rb +42 -0
- data/lib/sequel/plugins/composition.rb +42 -26
- data/lib/sequel/plugins/concurrent_eager_loading.rb +174 -0
- data/lib/sequel/plugins/constraint_validations.rb +20 -14
- data/lib/sequel/plugins/csv_serializer.rb +56 -35
- data/lib/sequel/plugins/dataset_associations.rb +40 -17
- data/lib/sequel/plugins/def_dataset_method.rb +90 -0
- data/lib/sequel/plugins/defaults_setter.rb +65 -10
- data/lib/sequel/plugins/delay_add_association.rb +1 -1
- data/lib/sequel/plugins/dirty.rb +62 -24
- data/lib/sequel/plugins/eager_each.rb +3 -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/enum.rb +124 -0
- data/lib/sequel/plugins/error_splitter.rb +17 -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 +7 -12
- data/lib/sequel/plugins/hook_class_methods.rb +37 -54
- data/lib/sequel/plugins/input_transformer.rb +18 -10
- data/lib/sequel/plugins/insert_conflict.rb +76 -0
- data/lib/sequel/plugins/insert_returning_select.rb +2 -2
- data/lib/sequel/plugins/instance_filters.rb +10 -8
- data/lib/sequel/plugins/instance_hooks.rb +34 -17
- data/lib/sequel/plugins/instance_specific_default.rb +113 -0
- data/lib/sequel/plugins/inverted_subsets.rb +22 -13
- data/lib/sequel/plugins/json_serializer.rb +124 -64
- data/lib/sequel/plugins/lazy_attributes.rb +21 -14
- data/lib/sequel/plugins/list.rb +35 -21
- data/lib/sequel/plugins/many_through_many.rb +134 -21
- data/lib/sequel/plugins/modification_detection.rb +15 -5
- data/lib/sequel/plugins/mssql_optimistic_locking.rb +6 -5
- data/lib/sequel/plugins/nested_attributes.rb +61 -31
- data/lib/sequel/plugins/optimistic_locking.rb +3 -3
- data/lib/sequel/plugins/pg_array_associations.rb +103 -53
- data/lib/sequel/plugins/pg_auto_constraint_validations.rb +350 -0
- data/lib/sequel/plugins/pg_row.rb +5 -51
- data/lib/sequel/plugins/prepared_statements.rb +60 -72
- data/lib/sequel/plugins/prepared_statements_safe.rb +9 -4
- data/lib/sequel/plugins/rcte_tree.rb +68 -82
- data/lib/sequel/plugins/require_valid_schema.rb +67 -0
- data/lib/sequel/plugins/serialization.rb +43 -46
- data/lib/sequel/plugins/serialization_modification_detection.rb +3 -2
- data/lib/sequel/plugins/sharding.rb +15 -10
- data/lib/sequel/plugins/single_table_inheritance.rb +67 -28
- data/lib/sequel/plugins/skip_create_refresh.rb +3 -3
- data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
- data/lib/sequel/plugins/split_values.rb +11 -6
- data/lib/sequel/plugins/sql_comments.rb +189 -0
- data/lib/sequel/plugins/static_cache.rb +77 -53
- data/lib/sequel/plugins/static_cache_cache.rb +53 -0
- data/lib/sequel/plugins/string_stripper.rb +3 -3
- data/lib/sequel/plugins/subclasses.rb +43 -10
- data/lib/sequel/plugins/subset_conditions.rb +15 -5
- data/lib/sequel/plugins/table_select.rb +2 -2
- data/lib/sequel/plugins/tactical_eager_loading.rb +96 -12
- data/lib/sequel/plugins/throw_failures.rb +110 -0
- data/lib/sequel/plugins/timestamps.rb +20 -8
- data/lib/sequel/plugins/touch.rb +19 -8
- data/lib/sequel/plugins/tree.rb +62 -32
- data/lib/sequel/plugins/typecast_on_load.rb +12 -4
- data/lib/sequel/plugins/unlimited_update.rb +1 -7
- data/lib/sequel/plugins/unused_associations.rb +521 -0
- data/lib/sequel/plugins/update_or_create.rb +4 -4
- data/lib/sequel/plugins/update_primary_key.rb +1 -1
- data/lib/sequel/plugins/update_refresh.rb +26 -15
- data/lib/sequel/plugins/uuid.rb +7 -11
- data/lib/sequel/plugins/validate_associated.rb +18 -0
- data/lib/sequel/plugins/validation_class_methods.rb +38 -19
- data/lib/sequel/plugins/validation_contexts.rb +49 -0
- data/lib/sequel/plugins/validation_helpers.rb +57 -41
- data/lib/sequel/plugins/whitelist_security.rb +122 -0
- data/lib/sequel/plugins/xml_serializer.rb +30 -31
- data/lib/sequel/sql.rb +471 -331
- data/lib/sequel/timezones.rb +78 -47
- data/lib/sequel/version.rb +7 -2
- data/lib/sequel.rb +1 -1
- metadata +217 -521
- data/Rakefile +0 -164
- data/doc/active_record.rdoc +0 -928
- 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.27.0.txt +0 -78
- data/doc/release_notes/4.28.0.txt +0 -57
- data/doc/release_notes/4.29.0.txt +0 -41
- data/doc/release_notes/4.3.0.txt +0 -40
- data/doc/release_notes/4.30.0.txt +0 -37
- data/doc/release_notes/4.31.0.txt +0 -57
- data/doc/release_notes/4.32.0.txt +0 -132
- data/doc/release_notes/4.33.0.txt +0 -88
- data/doc/release_notes/4.34.0.txt +0 -86
- data/doc/release_notes/4.35.0.txt +0 -130
- data/doc/release_notes/4.36.0.txt +0 -116
- 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 -144
- data/lib/sequel/adapters/do/mysql.rb +0 -66
- data/lib/sequel/adapters/do/postgres.rb +0 -44
- data/lib/sequel/adapters/do/sqlite3.rb +0 -42
- data/lib/sequel/adapters/do.rb +0 -158
- data/lib/sequel/adapters/jdbc/as400.rb +0 -84
- data/lib/sequel/adapters/jdbc/cubrid.rb +0 -64
- data/lib/sequel/adapters/jdbc/firebirdsql.rb +0 -36
- data/lib/sequel/adapters/jdbc/informix-sqli.rb +0 -33
- data/lib/sequel/adapters/jdbc/jdbcprogress.rb +0 -33
- data/lib/sequel/adapters/odbc/progress.rb +0 -10
- data/lib/sequel/adapters/shared/cubrid.rb +0 -245
- data/lib/sequel/adapters/shared/firebird.rb +0 -247
- data/lib/sequel/adapters/shared/informix.rb +0 -54
- data/lib/sequel/adapters/shared/mysql_prepared_statements.rb +0 -152
- data/lib/sequel/adapters/shared/progress.rb +0 -40
- data/lib/sequel/adapters/swift/mysql.rb +0 -49
- data/lib/sequel/adapters/swift/postgres.rb +0 -47
- data/lib/sequel/adapters/swift/sqlite.rb +0 -49
- data/lib/sequel/adapters/swift.rb +0 -160
- data/lib/sequel/adapters/utils/pg_types.rb +0 -70
- data/lib/sequel/dataset/mutation.rb +0 -111
- data/lib/sequel/extensions/empty_array_ignore_nulls.rb +0 -5
- data/lib/sequel/extensions/filter_having.rb +0 -63
- data/lib/sequel/extensions/hash_aliases.rb +0 -49
- data/lib/sequel/extensions/meta_def.rb +0 -35
- data/lib/sequel/extensions/query_literals.rb +0 -84
- data/lib/sequel/extensions/ruby18_symbol_extensions.rb +0 -24
- data/lib/sequel/extensions/sequel_3_dataset_methods.rb +0 -122
- data/lib/sequel/extensions/set_overrides.rb +0 -76
- data/lib/sequel/no_core_ext.rb +0 -3
- data/lib/sequel/plugins/association_autoreloading.rb +0 -9
- data/lib/sequel/plugins/identifier_columns.rb +0 -47
- data/lib/sequel/plugins/many_to_one_pk_lookup.rb +0 -9
- data/lib/sequel/plugins/pg_typecast_on_load.rb +0 -81
- data/lib/sequel/plugins/prepared_statements_associations.rb +0 -119
- data/lib/sequel/plugins/prepared_statements_with_pk.rb +0 -61
- data/lib/sequel/plugins/schema.rb +0 -82
- data/lib/sequel/plugins/scissors.rb +0 -35
- data/spec/adapter_spec.rb +0 -4
- 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 -733
- data/spec/adapters/mysql_spec.rb +0 -1319
- data/spec/adapters/oracle_spec.rb +0 -313
- data/spec/adapters/postgres_spec.rb +0 -3790
- data/spec/adapters/spec_helper.rb +0 -49
- data/spec/adapters/sqlanywhere_spec.rb +0 -170
- data/spec/adapters/sqlite_spec.rb +0 -688
- data/spec/bin_spec.rb +0 -258
- data/spec/core/connection_pool_spec.rb +0 -1045
- data/spec/core/database_spec.rb +0 -2636
- data/spec/core/dataset_spec.rb +0 -5175
- data/spec/core/deprecated_spec.rb +0 -70
- data/spec/core/expression_filters_spec.rb +0 -1247
- data/spec/core/mock_adapter_spec.rb +0 -464
- 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 -203
- data/spec/core/schema_spec.rb +0 -1676
- 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/core_model_spec.rb +0 -2
- data/spec/core_spec.rb +0 -1
- data/spec/extensions/accessed_columns_spec.rb +0 -51
- data/spec/extensions/active_model_spec.rb +0 -85
- 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 -405
- data/spec/extensions/association_proxies_spec.rb +0 -86
- data/spec/extensions/auto_validations_spec.rb +0 -192
- data/spec/extensions/before_after_save_spec.rb +0 -40
- 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/boolean_subsets_spec.rb +0 -47
- data/spec/extensions/caching_spec.rb +0 -270
- data/spec/extensions/class_table_inheritance_spec.rb +0 -444
- 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_expiration_spec.rb +0 -121
- data/spec/extensions/connection_validator_spec.rb +0 -127
- data/spec/extensions/constraint_validations_plugin_spec.rb +0 -288
- data/spec/extensions/constraint_validations_spec.rb +0 -389
- data/spec/extensions/core_refinements_spec.rb +0 -519
- data/spec/extensions/csv_serializer_spec.rb +0 -180
- data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
- data/spec/extensions/dataset_associations_spec.rb +0 -343
- data/spec/extensions/dataset_source_alias_spec.rb +0 -51
- data/spec/extensions/date_arithmetic_spec.rb +0 -167
- data/spec/extensions/defaults_setter_spec.rb +0 -102
- data/spec/extensions/delay_add_association_spec.rb +0 -74
- data/spec/extensions/dirty_spec.rb +0 -180
- data/spec/extensions/duplicate_columns_handler_spec.rb +0 -110
- data/spec/extensions/eager_each_spec.rb +0 -66
- 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 -119
- data/spec/extensions/hash_aliases_spec.rb +0 -24
- data/spec/extensions/hook_class_methods_spec.rb +0 -429
- data/spec/extensions/identifier_columns_spec.rb +0 -17
- 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 -304
- data/spec/extensions/lazy_attributes_spec.rb +0 -170
- data/spec/extensions/list_spec.rb +0 -278
- 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 -728
- 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/no_auto_literal_strings_spec.rb +0 -65
- 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 -390
- 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 -275
- 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 -473
- 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 -814
- 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/server_logging_spec.rb +0 -45
- 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_comments_spec.rb +0 -27
- data/spec/extensions/sql_expr_spec.rb +0 -60
- data/spec/extensions/static_cache_spec.rb +0 -361
- data/spec/extensions/string_agg_spec.rb +0 -85
- 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/subset_conditions_spec.rb +0 -38
- data/spec/extensions/table_select_spec.rb +0 -71
- data/spec/extensions/tactical_eager_loading_spec.rb +0 -136
- 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/uuid_spec.rb +0 -106
- 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 -554
- 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/double_migration/001_create_sessions.rb +0 -9
- data/spec/files/double_migration/002_create_nodes.rb +0 -19
- data/spec/files/double_migration/003_3_create_users.rb +0 -4
- 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/empty_migration/001_create_sessions.rb +0 -9
- data/spec/files/empty_migration/002_create_nodes.rb +0 -0
- data/spec/files/empty_migration/003_3_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/reversible_migrations/006_reversible.rb +0 -10
- data/spec/files/reversible_migrations/007_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 -2506
- data/spec/integration/database_test.rb +0 -113
- data/spec/integration/dataset_test.rb +0 -1858
- data/spec/integration/eager_loader_test.rb +0 -687
- data/spec/integration/migrator_test.rb +0 -262
- data/spec/integration/model_test.rb +0 -230
- data/spec/integration/plugin_test.rb +0 -2297
- data/spec/integration/prepared_statement_test.rb +0 -467
- data/spec/integration/schema_test.rb +0 -815
- data/spec/integration/spec_helper.rb +0 -56
- data/spec/integration/timezone_test.rb +0 -86
- data/spec/integration/transaction_test.rb +0 -406
- data/spec/integration/type_test.rb +0 -133
- data/spec/model/association_reflection_spec.rb +0 -565
- data/spec/model/associations_spec.rb +0 -4589
- data/spec/model/base_spec.rb +0 -759
- data/spec/model/class_dataset_methods_spec.rb +0 -150
- data/spec/model/dataset_methods_spec.rb +0 -149
- data/spec/model/eager_loading_spec.rb +0 -2197
- data/spec/model/hooks_spec.rb +0 -604
- data/spec/model/inflector_spec.rb +0 -26
- data/spec/model/model_spec.rb +0 -1097
- data/spec/model/plugins_spec.rb +0 -299
- data/spec/model/record_spec.rb +0 -2162
- data/spec/model/spec_helper.rb +0 -46
- data/spec/model/validations_spec.rb +0 -193
- data/spec/model_no_assoc_spec.rb +0 -1
- data/spec/model_spec.rb +0 -1
- data/spec/plugin_spec.rb +0 -1
- data/spec/sequel_coverage.rb +0 -15
- data/spec/spec_config.rb +0 -10
@@ -0,0 +1,110 @@
|
|
1
|
+
= New Features
|
2
|
+
|
3
|
+
* Database#rollback_on_exit has been added, which allows you to
|
4
|
+
rollback transactions instead of committing them when exiting
|
5
|
+
the transaction block. Previously, the only way to rollback
|
6
|
+
a transaction from inside a transaction block was to raise
|
7
|
+
an exception. This allows you to tell Sequel to roll the
|
8
|
+
transaction back on exit, and then use return or throw to exit
|
9
|
+
the transaction block.
|
10
|
+
|
11
|
+
Database#rollback_on_exit supports savepoints, including
|
12
|
+
multiple savepoint levels, as well as canceling rollbacks:
|
13
|
+
|
14
|
+
DB.transaction do # BEGIN
|
15
|
+
DB.rollback_on_exit
|
16
|
+
end # ROLLBACK
|
17
|
+
|
18
|
+
DB.transaction do # BEGIN
|
19
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
20
|
+
DB.rollback_on_exit(savepoint: true)
|
21
|
+
end # ROLLBACK TO SAVEPOINT
|
22
|
+
end # COMMIT
|
23
|
+
|
24
|
+
DB.transaction do # BEGIN
|
25
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
26
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
27
|
+
DB.rollback_on_exit(savepoint: true)
|
28
|
+
end # ROLLBACK TO SAVEPOINT
|
29
|
+
end # RELEASE SAVEPOINT
|
30
|
+
end # COMMIT
|
31
|
+
|
32
|
+
DB.transaction do # BEGIN
|
33
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
34
|
+
DB.rollback_on_exit(savepoint: true)
|
35
|
+
end # ROLLBACK TO SAVEPOINT
|
36
|
+
end # COMMIT
|
37
|
+
|
38
|
+
DB.transaction do # BEGIN
|
39
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
40
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
41
|
+
DB.rollback_on_exit(savepoint: 2)
|
42
|
+
end # ROLLBACK TO SAVEPOINT
|
43
|
+
end # ROLLBACK TO SAVEPOINT
|
44
|
+
end # COMMIT
|
45
|
+
|
46
|
+
DB.transaction do # BEGIN
|
47
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
48
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
49
|
+
DB.rollback_on_exit(savepoint: 3)
|
50
|
+
end # ROLLBACK TO SAVEPOINT
|
51
|
+
end # ROLLBACK TO SAVEPOINT
|
52
|
+
end # ROLLBACK
|
53
|
+
|
54
|
+
DB.transaction do # BEGIN
|
55
|
+
DB.rollback_on_exit
|
56
|
+
DB.rollback_on_exit(cancel: true)
|
57
|
+
end # COMMIT
|
58
|
+
|
59
|
+
* Sequel now supports window functions on SQLite 3.26.0+. SQLite
|
60
|
+
technically supports window functions on 3.25.0+, but enabling
|
61
|
+
window function support in Sequel opens up a code path that
|
62
|
+
generates queries that cause older versions of SQLite to produce a
|
63
|
+
segmentation fault. This bug in SQLite has been fixed in 3.26.0.
|
64
|
+
|
65
|
+
= Other Improvements
|
66
|
+
|
67
|
+
* Sequel::Model no longer overrides existing methods when defining
|
68
|
+
getters and setters. Historically, it only checked for existing
|
69
|
+
method definitions for methods that could be directly expressed
|
70
|
+
(e.g. not requiring send). Sequel 5 broke the check for setter
|
71
|
+
methods that could be directly expressed. This fixes cases where
|
72
|
+
model inheritance is used and the setter methods are overridden
|
73
|
+
in a parent class.
|
74
|
+
|
75
|
+
* Alter table emulation now works correctly on SQLite 3.26.0+.
|
76
|
+
|
77
|
+
* The one_to_one association setter does not modify reciprocal
|
78
|
+
associations in cases where doing so is not necessary. This can
|
79
|
+
fix some cases where the nested_attributes plugin is used.
|
80
|
+
|
81
|
+
* The class_table_inheritance plugin can now take advantage of the
|
82
|
+
schema_caching extension to prevent database queries to determine
|
83
|
+
column information when the class is created.
|
84
|
+
|
85
|
+
* The nested_attributes plugin no longer validates one_to_one
|
86
|
+
associations twice when saving.
|
87
|
+
|
88
|
+
* The class_table_inheritance plugin :qualify_tables option now
|
89
|
+
correctly qualifies subclasses of subclasses.
|
90
|
+
|
91
|
+
* SQL expressions that are subscripted are now wrapped in parentheses.
|
92
|
+
This fixes at least subscripting a function expression on
|
93
|
+
PostgreSQL:
|
94
|
+
|
95
|
+
DB[:t].select{array_agg(column).sql_subscript(1)}
|
96
|
+
# SELECT (array_agg(column))[1] FROM t
|
97
|
+
|
98
|
+
* Sequel::Migrator now uses more descriptive error messages if a
|
99
|
+
missing or empty migration directory is given.
|
100
|
+
|
101
|
+
* bin/sequel -C when converting from SQLite to another database
|
102
|
+
type will now use 64-bit integer columns in the other database when
|
103
|
+
the SQLite column type is integer, as SQLite supports storing
|
104
|
+
64-bit values in integer columns, and most other databases only
|
105
|
+
support 32-bit values in integer columns.
|
106
|
+
|
107
|
+
= Backwards Compatibility
|
108
|
+
|
109
|
+
* The mysql adapter no longer attempts to load the mysqlplus driver,
|
110
|
+
it now only attempts to load the mysql driver.
|
@@ -0,0 +1,31 @@
|
|
1
|
+
= New Features
|
2
|
+
|
3
|
+
* An instance-level skip_auto_validations method has been added to
|
4
|
+
the auto_validations plugin, allowing you to skip all or specific
|
5
|
+
types of auto validations inside the block:
|
6
|
+
|
7
|
+
model_instance.skip_auto_validations(:unique) do
|
8
|
+
puts model_instance.valid?
|
9
|
+
end
|
10
|
+
|
11
|
+
* A Database :preconnect_extensions option has been added. This
|
12
|
+
option is similar to :extensions, but the extensions are loaded
|
13
|
+
before the :preconnect option is processed. This allows you to
|
14
|
+
use the server_logging extension with the :preconnect option.
|
15
|
+
|
16
|
+
* For specifying custom table aliases when using eager_graph and
|
17
|
+
association_join, you can now use:
|
18
|
+
|
19
|
+
Sequel[:association].as(:table_alias)
|
20
|
+
|
21
|
+
in addition to:
|
22
|
+
|
23
|
+
Sequel.as(:association, :table_alias)
|
24
|
+
|
25
|
+
= Other Improvements
|
26
|
+
|
27
|
+
* The ado/mssql adapter now retrieves the number of deleted or
|
28
|
+
updated rows for a query without issuing a separate query.
|
29
|
+
|
30
|
+
* Sequel now avoids the use of Proc.new with an implicit block, as
|
31
|
+
that feature will be deprecated starting in Ruby 2.7.
|
@@ -0,0 +1,69 @@
|
|
1
|
+
= New Features
|
2
|
+
|
3
|
+
* A throw_failures plugin has been added for throwing ValidationFailed
|
4
|
+
and HookFailed exceptions instead of raising them. This can improve
|
5
|
+
performance by up to 10x on JRuby and 10-15% on CRuby. However,
|
6
|
+
you would need to modify your exception handling from:
|
7
|
+
|
8
|
+
begin
|
9
|
+
# model.save
|
10
|
+
rescue Sequel::ValidationFailed => e
|
11
|
+
# handle failure
|
12
|
+
end
|
13
|
+
|
14
|
+
to:
|
15
|
+
|
16
|
+
e = catch(Sequel::ValidationFailed) do
|
17
|
+
# model.save
|
18
|
+
end
|
19
|
+
if e.is_a?(Sequel::ValidationFailed)
|
20
|
+
# handle failure
|
21
|
+
end
|
22
|
+
|
23
|
+
The throw_failures plugin will still work if you are not catching
|
24
|
+
the exception, falling back to the default behavior of raising
|
25
|
+
the exception.
|
26
|
+
|
27
|
+
* SQL::Blob.call has been added, so that SQL::Blob can be used
|
28
|
+
directly as a callable to create a new instance, resulting in
|
29
|
+
better performance in cases where a callable is needed.
|
30
|
+
|
31
|
+
= Other Improvements
|
32
|
+
|
33
|
+
* Type conversion is many adapters is now faster by switching from
|
34
|
+
Proc/Method instances to using singleton call methods on plain
|
35
|
+
objects. This can improve performance of row fetching by up to
|
36
|
+
10% in some cases.
|
37
|
+
|
38
|
+
* Row fetching is slightly faster in the jdbc and sqlite adapters,
|
39
|
+
by switching from each to while.
|
40
|
+
|
41
|
+
* tzinfo 2 is now supported when using the named_timezones extension.
|
42
|
+
tzinfo 1 remains supported.
|
43
|
+
|
44
|
+
* The optimized Dataset#paged_each methods in the postgres and mysql2
|
45
|
+
adapters now support being called without a block, returning an
|
46
|
+
Enumerator in that case, to mirror the behavior of the default
|
47
|
+
Dataset#paged_each method.
|
48
|
+
|
49
|
+
* Sequel no longer uses flow-control exceptions in the
|
50
|
+
connection_expiration and connection_validator extensions,
|
51
|
+
significantly improving performance on JRuby.
|
52
|
+
|
53
|
+
* The after_initialize plugin no longer makes the argument to
|
54
|
+
Model.call optional.
|
55
|
+
|
56
|
+
= Backwards Compatibility
|
57
|
+
|
58
|
+
* Some internal by not private constants and methods previously used
|
59
|
+
for type conversion in adapters have been removed:
|
60
|
+
|
61
|
+
* JDBC::Oracle.OracleDecimal
|
62
|
+
* JDBC::Oracle.OracleClob
|
63
|
+
* JDBC::Postgres.RubyPGArray
|
64
|
+
* JDBC::Postgres.RubyPGHstore
|
65
|
+
* JDBC::SqlAnywhere.SqlAnywhereBoolean
|
66
|
+
* JDBC::SQLServer.MSSQLRubyTime
|
67
|
+
* MySQL::TYPE_TRANSLATOR
|
68
|
+
* Postgres::TYPE_TRANSLATOR
|
69
|
+
|
@@ -0,0 +1,28 @@
|
|
1
|
+
= New Features
|
2
|
+
|
3
|
+
* A Database#rename_enum_value method has been added to the pg_enum
|
4
|
+
extension. It is supported on PostgreSQL 10+:
|
5
|
+
|
6
|
+
DB.rename_enum_value(:enum_type, 'old_name', 'new_name')
|
7
|
+
|
8
|
+
= Other Improvements
|
9
|
+
|
10
|
+
* The performance of row fetching and type conversion in the
|
11
|
+
sqlanywhere adapter has been improved.
|
12
|
+
|
13
|
+
* The performance of row fetching in the sqlite adapter has been
|
14
|
+
improved.
|
15
|
+
|
16
|
+
* Calling Database#drop_table now drops any constraint validations
|
17
|
+
metadata for the table if using the constraint_validations
|
18
|
+
extension. However, modifying the table using Database#alter_table
|
19
|
+
does not affect the constraint validations metadata.
|
20
|
+
|
21
|
+
* The sqlite adapter when used with ruby-sqlite3 1.4.0+ now uses
|
22
|
+
SQLite extended result codes for a more accurate determination of
|
23
|
+
specific database errors types.
|
24
|
+
|
25
|
+
* Performance for typecasting to decimal and floats has been improved
|
26
|
+
slightly.
|
27
|
+
|
28
|
+
* Performance when merging hashes has been improved slightly.
|
@@ -0,0 +1,33 @@
|
|
1
|
+
= New Features
|
2
|
+
|
3
|
+
* A pg_extended_date_support extension has been added. This
|
4
|
+
extension adds support for infinite and BC dates/timestamps on
|
5
|
+
PostgreSQL.
|
6
|
+
|
7
|
+
The postgres adapter already had a convert_infinite_timestamps
|
8
|
+
setting, but it wasn't supported in the jdbc/postgresql adapter
|
9
|
+
and it didn't handle BC dates/timestamps. Setting a non-default
|
10
|
+
convert_infinite_timestamps setting in the postgres adapter will
|
11
|
+
now automatically load the extension for backwards compatibility.
|
12
|
+
|
13
|
+
The pg_extended_date_support extension by default just fixes the
|
14
|
+
handling of BC dates/timestamps. To get it to handle infinite
|
15
|
+
timestamps, you need to choose the appropriate setting for your
|
16
|
+
application:
|
17
|
+
|
18
|
+
DB.extension :pg_extended_date_support
|
19
|
+
DB.convert_infinite_timestamps = :string # or :float or :nil
|
20
|
+
|
21
|
+
This extension also enables the handling of timezone offsets
|
22
|
+
with seconds, which is not natively supported by ruby's Time
|
23
|
+
class in ruby <2.5.
|
24
|
+
|
25
|
+
= Improvements
|
26
|
+
|
27
|
+
* The jdbc/mysql adapter now handles smallint unsigned and
|
28
|
+
integer unsigned column types where the value for the column
|
29
|
+
is outside of the range of a Java short or integer.
|
30
|
+
|
31
|
+
* Sequel::Model.inherited no longer modifies an existing @dataset
|
32
|
+
instance variable if one has already been set. This fixes a
|
33
|
+
regression that was introduced in Sequel 5.0.0.
|
@@ -0,0 +1,89 @@
|
|
1
|
+
= New Features
|
2
|
+
|
3
|
+
* Database#after_commit and #after_rollback transaction hook methods
|
4
|
+
now support a :savepoint option. Using the :savepoint option makes
|
5
|
+
the hooks savepoint-aware, so after_commit will only be called if
|
6
|
+
all enclosing savepoints and the transaction are committed, and
|
7
|
+
after_rollback will be called when any of the enclosing savepoints
|
8
|
+
are rolled back (which may be before transaction commit/rollback).
|
9
|
+
Examples:
|
10
|
+
|
11
|
+
x = nil
|
12
|
+
DB.transaction do # BEGIN
|
13
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
14
|
+
DB.after_commit(savepoint: true){x = 1}
|
15
|
+
DB.after_rollback(savepoint: true){x = 2}
|
16
|
+
x # nil
|
17
|
+
end # RELEASE SAVEPOINT
|
18
|
+
x # nil
|
19
|
+
end # COMMIT
|
20
|
+
x # 1
|
21
|
+
|
22
|
+
x = nil
|
23
|
+
DB.transaction do # BEGIN
|
24
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
25
|
+
DB.after_commit(savepoint: true){x = 1}
|
26
|
+
DB.after_rollback(savepoint: true){x = 2}
|
27
|
+
x # nil
|
28
|
+
raise Sequel::Rollback
|
29
|
+
end # ROLLBACK TO SAVEPOINT
|
30
|
+
x # 2
|
31
|
+
end # COMMIT
|
32
|
+
x # 2
|
33
|
+
|
34
|
+
x = nil
|
35
|
+
DB.transaction do # BEGIN
|
36
|
+
DB.transaction(savepoint: true) do # SAVEPOINT
|
37
|
+
DB.after_commit(savepoint: true){x = 1}
|
38
|
+
DB.after_rollback(savepoint: true){x = 2}
|
39
|
+
end # RELEASE SAVEPOINT
|
40
|
+
x # nil
|
41
|
+
raise Sequel::Rollback
|
42
|
+
end
|
43
|
+
x # 2
|
44
|
+
|
45
|
+
* The pg_auto_constraint_validations plugin now supports a
|
46
|
+
pg_auto_constraint_validation_override method for overriding
|
47
|
+
the columns and message for a specific constraint. This is
|
48
|
+
useful if the database cannot determine the columns (due
|
49
|
+
to the constraint containing a database function call), or
|
50
|
+
if you would like to customize the message per constraint.
|
51
|
+
|
52
|
+
= Other Improvements
|
53
|
+
|
54
|
+
* The one_to_one association setter now works with models that use
|
55
|
+
joined datasets, such as child models when using the
|
56
|
+
class_table_inheritance plugin.
|
57
|
+
|
58
|
+
* Database#check_constraints on PostgreSQL now also includes CHECK
|
59
|
+
constraints where the related columns are not known. The :columns
|
60
|
+
entry in the hash will be an empty array in such cases. The
|
61
|
+
exclusion of such constraints in previous versions was not
|
62
|
+
intentional, and the documentation implied that all CHECK
|
63
|
+
constraints were returned.
|
64
|
+
|
65
|
+
* Many cases where instance_exec was previously used on model
|
66
|
+
instances have been changed so that instance methods are defined
|
67
|
+
and called instead. This avoids the creation of singleton classes
|
68
|
+
for model instances, and can significantly improve performance in
|
69
|
+
some cases. This affects all associations as well as the
|
70
|
+
following plugins:
|
71
|
+
|
72
|
+
* composition
|
73
|
+
* hook_class_methods
|
74
|
+
* validation_class_methods
|
75
|
+
|
76
|
+
Other cases where instance_exec is now avoided and a different
|
77
|
+
approach is used:
|
78
|
+
|
79
|
+
* association_dependencies plugin
|
80
|
+
* PlaceholderLiteralString#with_dataset
|
81
|
+
|
82
|
+
* The auto_validations plugin now works with child models when using
|
83
|
+
the class_table_inheritance plugin.
|
84
|
+
|
85
|
+
* Database#server_version now works correctly in the mysql2 adapter
|
86
|
+
when using the MySQL driver with MariaDB 10+.
|
87
|
+
|
88
|
+
* The float unsigned type is now recognized and supported in the
|
89
|
+
schema parser and schema_dumper extension.
|
@@ -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+.
|