sequel 5.8.0 → 5.38.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.
Files changed (510) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG +409 -1795
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +4 -4
  5. data/bin/sequel +4 -0
  6. data/doc/advanced_associations.rdoc +136 -18
  7. data/doc/association_basics.rdoc +10 -5
  8. data/doc/cheat_sheet.rdoc +1 -0
  9. data/doc/code_order.rdoc +12 -2
  10. data/doc/dataset_filtering.rdoc +17 -2
  11. data/doc/mass_assignment.rdoc +3 -3
  12. data/doc/model_dataset_method_design.rdoc +1 -1
  13. data/doc/model_plugins.rdoc +1 -1
  14. data/doc/opening_databases.rdoc +30 -8
  15. data/doc/postgresql.rdoc +107 -2
  16. data/doc/release_notes/5.10.0.txt +84 -0
  17. data/doc/release_notes/5.11.0.txt +83 -0
  18. data/doc/release_notes/5.12.0.txt +141 -0
  19. data/doc/release_notes/5.13.0.txt +27 -0
  20. data/doc/release_notes/5.14.0.txt +63 -0
  21. data/doc/release_notes/5.15.0.txt +39 -0
  22. data/doc/release_notes/5.16.0.txt +110 -0
  23. data/doc/release_notes/5.17.0.txt +31 -0
  24. data/doc/release_notes/5.18.0.txt +69 -0
  25. data/doc/release_notes/5.19.0.txt +28 -0
  26. data/doc/release_notes/5.20.0.txt +89 -0
  27. data/doc/release_notes/5.21.0.txt +87 -0
  28. data/doc/release_notes/5.22.0.txt +48 -0
  29. data/doc/release_notes/5.23.0.txt +56 -0
  30. data/doc/release_notes/5.24.0.txt +56 -0
  31. data/doc/release_notes/5.25.0.txt +32 -0
  32. data/doc/release_notes/5.26.0.txt +35 -0
  33. data/doc/release_notes/5.27.0.txt +21 -0
  34. data/doc/release_notes/5.28.0.txt +16 -0
  35. data/doc/release_notes/5.29.0.txt +22 -0
  36. data/doc/release_notes/5.30.0.txt +20 -0
  37. data/doc/release_notes/5.31.0.txt +148 -0
  38. data/doc/release_notes/5.32.0.txt +46 -0
  39. data/doc/release_notes/5.33.0.txt +24 -0
  40. data/doc/release_notes/5.34.0.txt +40 -0
  41. data/doc/release_notes/5.35.0.txt +56 -0
  42. data/doc/release_notes/5.36.0.txt +60 -0
  43. data/doc/release_notes/5.37.0.txt +30 -0
  44. data/doc/release_notes/5.38.0.txt +28 -0
  45. data/doc/release_notes/5.9.0.txt +99 -0
  46. data/doc/security.rdoc +10 -0
  47. data/doc/sharding.rdoc +42 -28
  48. data/doc/sql.rdoc +12 -0
  49. data/doc/testing.rdoc +24 -17
  50. data/doc/transactions.rdoc +78 -0
  51. data/doc/validations.rdoc +2 -2
  52. data/lib/sequel/adapters/ado.rb +26 -18
  53. data/lib/sequel/adapters/ado/access.rb +2 -2
  54. data/lib/sequel/adapters/ado/mssql.rb +5 -8
  55. data/lib/sequel/adapters/amalgalite.rb +1 -1
  56. data/lib/sequel/adapters/jdbc.rb +71 -27
  57. data/lib/sequel/adapters/jdbc/mysql.rb +6 -6
  58. data/lib/sequel/adapters/jdbc/oracle.rb +7 -6
  59. data/lib/sequel/adapters/jdbc/postgresql.rb +17 -28
  60. data/lib/sequel/adapters/jdbc/sqlanywhere.rb +5 -6
  61. data/lib/sequel/adapters/jdbc/sqlite.rb +33 -2
  62. data/lib/sequel/adapters/jdbc/sqlserver.rb +4 -3
  63. data/lib/sequel/adapters/jdbc/transactions.rb +14 -28
  64. data/lib/sequel/adapters/mysql.rb +14 -15
  65. data/lib/sequel/adapters/mysql2.rb +5 -3
  66. data/lib/sequel/adapters/odbc.rb +4 -6
  67. data/lib/sequel/adapters/oracle.rb +7 -7
  68. data/lib/sequel/adapters/postgres.rb +52 -16
  69. data/lib/sequel/adapters/shared/access.rb +16 -12
  70. data/lib/sequel/adapters/shared/db2.rb +5 -0
  71. data/lib/sequel/adapters/shared/mssql.rb +41 -18
  72. data/lib/sequel/adapters/shared/mysql.rb +66 -19
  73. data/lib/sequel/adapters/shared/oracle.rb +29 -23
  74. data/lib/sequel/adapters/shared/postgres.rb +341 -95
  75. data/lib/sequel/adapters/shared/sqlanywhere.rb +23 -10
  76. data/lib/sequel/adapters/shared/sqlite.rb +174 -21
  77. data/lib/sequel/adapters/sqlanywhere.rb +33 -17
  78. data/lib/sequel/adapters/sqlite.rb +78 -68
  79. data/lib/sequel/adapters/tinytds.rb +14 -6
  80. data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +2 -5
  81. data/lib/sequel/adapters/utils/mysql_mysql2.rb +5 -1
  82. data/lib/sequel/connection_pool.rb +2 -6
  83. data/lib/sequel/connection_pool/sharded_single.rb +7 -4
  84. data/lib/sequel/connection_pool/sharded_threaded.rb +32 -21
  85. data/lib/sequel/connection_pool/single.rb +1 -1
  86. data/lib/sequel/connection_pool/threaded.rb +26 -11
  87. data/lib/sequel/core.rb +327 -319
  88. data/lib/sequel/database/connecting.rb +7 -8
  89. data/lib/sequel/database/logging.rb +7 -1
  90. data/lib/sequel/database/misc.rb +68 -34
  91. data/lib/sequel/database/query.rb +6 -4
  92. data/lib/sequel/database/schema_generator.rb +31 -11
  93. data/lib/sequel/database/schema_methods.rb +32 -22
  94. data/lib/sequel/database/transactions.rb +129 -25
  95. data/lib/sequel/dataset.rb +4 -2
  96. data/lib/sequel/dataset/actions.rb +34 -23
  97. data/lib/sequel/dataset/features.rb +34 -0
  98. data/lib/sequel/dataset/graph.rb +27 -11
  99. data/lib/sequel/dataset/misc.rb +17 -3
  100. data/lib/sequel/dataset/placeholder_literalizer.rb +50 -21
  101. data/lib/sequel/dataset/prepared_statements.rb +96 -26
  102. data/lib/sequel/dataset/query.rb +43 -8
  103. data/lib/sequel/dataset/sql.rb +189 -41
  104. data/lib/sequel/deprecated.rb +3 -1
  105. data/lib/sequel/exceptions.rb +2 -0
  106. data/lib/sequel/extensions/_pretty_table.rb +1 -2
  107. data/lib/sequel/extensions/any_not_empty.rb +45 -0
  108. data/lib/sequel/extensions/caller_logging.rb +79 -0
  109. data/lib/sequel/extensions/columns_introspection.rb +1 -2
  110. data/lib/sequel/extensions/connection_expiration.rb +6 -6
  111. data/lib/sequel/extensions/connection_validator.rb +7 -6
  112. data/lib/sequel/extensions/constant_sql_override.rb +65 -0
  113. data/lib/sequel/extensions/constraint_validations.rb +53 -28
  114. data/lib/sequel/extensions/core_refinements.rb +2 -0
  115. data/lib/sequel/extensions/duplicate_columns_handler.rb +2 -0
  116. data/lib/sequel/extensions/escaped_like.rb +100 -0
  117. data/lib/sequel/extensions/eval_inspect.rb +3 -1
  118. data/lib/sequel/extensions/exclude_or_null.rb +68 -0
  119. data/lib/sequel/extensions/fiber_concurrency.rb +24 -0
  120. data/lib/sequel/extensions/index_caching.rb +9 -7
  121. data/lib/sequel/extensions/integer64.rb +3 -1
  122. data/lib/sequel/extensions/looser_typecasting.rb +3 -3
  123. data/lib/sequel/extensions/migration.rb +13 -6
  124. data/lib/sequel/extensions/named_timezones.rb +84 -23
  125. data/lib/sequel/extensions/pg_array.rb +87 -79
  126. data/lib/sequel/extensions/pg_array_ops.rb +14 -6
  127. data/lib/sequel/extensions/pg_enum.rb +34 -18
  128. data/lib/sequel/extensions/pg_extended_date_support.rb +34 -14
  129. data/lib/sequel/extensions/pg_hstore.rb +6 -0
  130. data/lib/sequel/extensions/pg_hstore_ops.rb +2 -0
  131. data/lib/sequel/extensions/pg_inet.rb +15 -5
  132. data/lib/sequel/extensions/pg_interval.rb +2 -0
  133. data/lib/sequel/extensions/pg_json.rb +387 -123
  134. data/lib/sequel/extensions/pg_json_ops.rb +168 -0
  135. data/lib/sequel/extensions/pg_range.rb +20 -10
  136. data/lib/sequel/extensions/pg_range_ops.rb +2 -0
  137. data/lib/sequel/extensions/pg_row.rb +3 -2
  138. data/lib/sequel/extensions/pg_row_ops.rb +24 -0
  139. data/lib/sequel/extensions/pg_static_cache_updater.rb +2 -2
  140. data/lib/sequel/extensions/pg_timestamptz.rb +2 -0
  141. data/lib/sequel/extensions/query.rb +1 -0
  142. data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
  143. data/lib/sequel/extensions/s.rb +2 -0
  144. data/lib/sequel/extensions/schema_dumper.rb +13 -7
  145. data/lib/sequel/extensions/sequel_4_dataset_methods.rb +4 -2
  146. data/lib/sequel/extensions/server_block.rb +18 -7
  147. data/lib/sequel/extensions/sql_comments.rb +2 -2
  148. data/lib/sequel/extensions/symbol_aref_refinement.rb +2 -0
  149. data/lib/sequel/extensions/symbol_as_refinement.rb +2 -0
  150. data/lib/sequel/extensions/to_dot.rb +9 -3
  151. data/lib/sequel/model.rb +3 -1
  152. data/lib/sequel/model/associations.rb +403 -69
  153. data/lib/sequel/model/base.rb +170 -90
  154. data/lib/sequel/model/plugins.rb +105 -0
  155. data/lib/sequel/plugins/after_initialize.rb +1 -1
  156. data/lib/sequel/plugins/association_dependencies.rb +3 -3
  157. data/lib/sequel/plugins/association_lazy_eager_option.rb +66 -0
  158. data/lib/sequel/plugins/association_multi_add_remove.rb +85 -0
  159. data/lib/sequel/plugins/association_pks.rb +74 -22
  160. data/lib/sequel/plugins/association_proxies.rb +6 -2
  161. data/lib/sequel/plugins/auto_validations.rb +36 -17
  162. data/lib/sequel/plugins/blacklist_security.rb +1 -2
  163. data/lib/sequel/plugins/boolean_subsets.rb +4 -1
  164. data/lib/sequel/plugins/caching.rb +3 -0
  165. data/lib/sequel/plugins/class_table_inheritance.rb +62 -34
  166. data/lib/sequel/plugins/composition.rb +13 -9
  167. data/lib/sequel/plugins/csv_serializer.rb +28 -9
  168. data/lib/sequel/plugins/defaults_setter.rb +2 -2
  169. data/lib/sequel/plugins/dirty.rb +60 -22
  170. data/lib/sequel/plugins/eager_graph_eager.rb +139 -0
  171. data/lib/sequel/plugins/empty_failure_backtraces.rb +38 -0
  172. data/lib/sequel/plugins/finder.rb +2 -2
  173. data/lib/sequel/plugins/forbid_lazy_load.rb +216 -0
  174. data/lib/sequel/plugins/hook_class_methods.rb +17 -5
  175. data/lib/sequel/plugins/insert_conflict.rb +72 -0
  176. data/lib/sequel/plugins/instance_specific_default.rb +113 -0
  177. data/lib/sequel/plugins/inverted_subsets.rb +2 -2
  178. data/lib/sequel/plugins/json_serializer.rb +21 -14
  179. data/lib/sequel/plugins/lazy_attributes.rb +1 -1
  180. data/lib/sequel/plugins/list.rb +22 -10
  181. data/lib/sequel/plugins/many_through_many.rb +1 -1
  182. data/lib/sequel/plugins/nested_attributes.rb +27 -5
  183. data/lib/sequel/plugins/pg_array_associations.rb +12 -9
  184. data/lib/sequel/plugins/pg_auto_constraint_validations.rb +149 -61
  185. data/lib/sequel/plugins/prepared_statements.rb +6 -12
  186. data/lib/sequel/plugins/prepared_statements_safe.rb +1 -3
  187. data/lib/sequel/plugins/rcte_tree.rb +20 -22
  188. data/lib/sequel/plugins/sharding.rb +13 -7
  189. data/lib/sequel/plugins/single_table_inheritance.rb +20 -15
  190. data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
  191. data/lib/sequel/plugins/static_cache.rb +36 -17
  192. data/lib/sequel/plugins/static_cache_cache.rb +53 -0
  193. data/lib/sequel/plugins/string_stripper.rb +1 -1
  194. data/lib/sequel/plugins/subclasses.rb +2 -0
  195. data/lib/sequel/plugins/subset_conditions.rb +2 -2
  196. data/lib/sequel/plugins/tactical_eager_loading.rb +73 -2
  197. data/lib/sequel/plugins/throw_failures.rb +110 -0
  198. data/lib/sequel/plugins/tree.rb +49 -31
  199. data/lib/sequel/plugins/typecast_on_load.rb +3 -2
  200. data/lib/sequel/plugins/validation_class_methods.rb +11 -5
  201. data/lib/sequel/plugins/validation_helpers.rb +2 -2
  202. data/lib/sequel/sql.rb +120 -30
  203. data/lib/sequel/timezones.rb +55 -14
  204. data/lib/sequel/version.rb +6 -1
  205. metadata +101 -361
  206. data/Rakefile +0 -151
  207. data/doc/release_notes/4.0.0.txt +0 -262
  208. data/doc/release_notes/4.1.0.txt +0 -85
  209. data/doc/release_notes/4.10.0.txt +0 -226
  210. data/doc/release_notes/4.11.0.txt +0 -147
  211. data/doc/release_notes/4.12.0.txt +0 -105
  212. data/doc/release_notes/4.13.0.txt +0 -169
  213. data/doc/release_notes/4.14.0.txt +0 -68
  214. data/doc/release_notes/4.15.0.txt +0 -56
  215. data/doc/release_notes/4.16.0.txt +0 -36
  216. data/doc/release_notes/4.17.0.txt +0 -38
  217. data/doc/release_notes/4.18.0.txt +0 -36
  218. data/doc/release_notes/4.19.0.txt +0 -45
  219. data/doc/release_notes/4.2.0.txt +0 -129
  220. data/doc/release_notes/4.20.0.txt +0 -79
  221. data/doc/release_notes/4.21.0.txt +0 -94
  222. data/doc/release_notes/4.22.0.txt +0 -72
  223. data/doc/release_notes/4.23.0.txt +0 -65
  224. data/doc/release_notes/4.24.0.txt +0 -99
  225. data/doc/release_notes/4.25.0.txt +0 -181
  226. data/doc/release_notes/4.26.0.txt +0 -44
  227. data/doc/release_notes/4.27.0.txt +0 -78
  228. data/doc/release_notes/4.28.0.txt +0 -57
  229. data/doc/release_notes/4.29.0.txt +0 -41
  230. data/doc/release_notes/4.3.0.txt +0 -40
  231. data/doc/release_notes/4.30.0.txt +0 -37
  232. data/doc/release_notes/4.31.0.txt +0 -57
  233. data/doc/release_notes/4.32.0.txt +0 -132
  234. data/doc/release_notes/4.33.0.txt +0 -88
  235. data/doc/release_notes/4.34.0.txt +0 -86
  236. data/doc/release_notes/4.35.0.txt +0 -130
  237. data/doc/release_notes/4.36.0.txt +0 -116
  238. data/doc/release_notes/4.37.0.txt +0 -50
  239. data/doc/release_notes/4.38.0.txt +0 -67
  240. data/doc/release_notes/4.39.0.txt +0 -127
  241. data/doc/release_notes/4.4.0.txt +0 -92
  242. data/doc/release_notes/4.40.0.txt +0 -179
  243. data/doc/release_notes/4.41.0.txt +0 -77
  244. data/doc/release_notes/4.42.0.txt +0 -221
  245. data/doc/release_notes/4.43.0.txt +0 -87
  246. data/doc/release_notes/4.44.0.txt +0 -125
  247. data/doc/release_notes/4.45.0.txt +0 -370
  248. data/doc/release_notes/4.46.0.txt +0 -404
  249. data/doc/release_notes/4.47.0.txt +0 -56
  250. data/doc/release_notes/4.48.0.txt +0 -293
  251. data/doc/release_notes/4.49.0.txt +0 -222
  252. data/doc/release_notes/4.5.0.txt +0 -34
  253. data/doc/release_notes/4.6.0.txt +0 -30
  254. data/doc/release_notes/4.7.0.txt +0 -103
  255. data/doc/release_notes/4.8.0.txt +0 -175
  256. data/doc/release_notes/4.9.0.txt +0 -190
  257. data/spec/adapter_spec.rb +0 -4
  258. data/spec/adapters/db2_spec.rb +0 -170
  259. data/spec/adapters/mssql_spec.rb +0 -804
  260. data/spec/adapters/mysql_spec.rb +0 -1041
  261. data/spec/adapters/oracle_spec.rb +0 -327
  262. data/spec/adapters/postgres_spec.rb +0 -4000
  263. data/spec/adapters/spec_helper.rb +0 -43
  264. data/spec/adapters/sqlanywhere_spec.rb +0 -97
  265. data/spec/adapters/sqlite_spec.rb +0 -600
  266. data/spec/bin_spec.rb +0 -269
  267. data/spec/core/connection_pool_spec.rb +0 -1228
  268. data/spec/core/database_spec.rb +0 -2673
  269. data/spec/core/dataset_spec.rb +0 -5419
  270. data/spec/core/deprecated_spec.rb +0 -70
  271. data/spec/core/expression_filters_spec.rb +0 -1344
  272. data/spec/core/mock_adapter_spec.rb +0 -722
  273. data/spec/core/object_graph_spec.rb +0 -306
  274. data/spec/core/placeholder_literalizer_spec.rb +0 -166
  275. data/spec/core/schema_generator_spec.rb +0 -214
  276. data/spec/core/schema_spec.rb +0 -1820
  277. data/spec/core/spec_helper.rb +0 -23
  278. data/spec/core/version_spec.rb +0 -7
  279. data/spec/core_extensions_spec.rb +0 -762
  280. data/spec/core_model_spec.rb +0 -2
  281. data/spec/core_spec.rb +0 -1
  282. data/spec/deprecation_helper.rb +0 -30
  283. data/spec/extensions/accessed_columns_spec.rb +0 -51
  284. data/spec/extensions/active_model_spec.rb +0 -99
  285. data/spec/extensions/after_initialize_spec.rb +0 -24
  286. data/spec/extensions/arbitrary_servers_spec.rb +0 -109
  287. data/spec/extensions/association_dependencies_spec.rb +0 -125
  288. data/spec/extensions/association_pks_spec.rb +0 -423
  289. data/spec/extensions/association_proxies_spec.rb +0 -100
  290. data/spec/extensions/auto_literal_strings_spec.rb +0 -205
  291. data/spec/extensions/auto_validations_spec.rb +0 -202
  292. data/spec/extensions/blacklist_security_spec.rb +0 -95
  293. data/spec/extensions/blank_spec.rb +0 -69
  294. data/spec/extensions/boolean_readers_spec.rb +0 -93
  295. data/spec/extensions/boolean_subsets_spec.rb +0 -47
  296. data/spec/extensions/caching_spec.rb +0 -273
  297. data/spec/extensions/class_table_inheritance_spec.rb +0 -568
  298. data/spec/extensions/column_conflicts_spec.rb +0 -75
  299. data/spec/extensions/column_select_spec.rb +0 -129
  300. data/spec/extensions/columns_introspection_spec.rb +0 -90
  301. data/spec/extensions/columns_updated_spec.rb +0 -35
  302. data/spec/extensions/composition_spec.rb +0 -248
  303. data/spec/extensions/connection_expiration_spec.rb +0 -133
  304. data/spec/extensions/connection_validator_spec.rb +0 -127
  305. data/spec/extensions/constraint_validations_plugin_spec.rb +0 -300
  306. data/spec/extensions/constraint_validations_spec.rb +0 -395
  307. data/spec/extensions/core_refinements_spec.rb +0 -528
  308. data/spec/extensions/csv_serializer_spec.rb +0 -183
  309. data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
  310. data/spec/extensions/dataset_associations_spec.rb +0 -365
  311. data/spec/extensions/dataset_source_alias_spec.rb +0 -51
  312. data/spec/extensions/date_arithmetic_spec.rb +0 -181
  313. data/spec/extensions/datetime_parse_to_time_spec.rb +0 -169
  314. data/spec/extensions/def_dataset_method_spec.rb +0 -100
  315. data/spec/extensions/defaults_setter_spec.rb +0 -141
  316. data/spec/extensions/delay_add_association_spec.rb +0 -73
  317. data/spec/extensions/dirty_spec.rb +0 -189
  318. data/spec/extensions/duplicate_columns_handler_spec.rb +0 -104
  319. data/spec/extensions/eager_each_spec.rb +0 -62
  320. data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
  321. data/spec/extensions/error_splitter_spec.rb +0 -18
  322. data/spec/extensions/error_sql_spec.rb +0 -20
  323. data/spec/extensions/eval_inspect_spec.rb +0 -74
  324. data/spec/extensions/finder_spec.rb +0 -260
  325. data/spec/extensions/force_encoding_spec.rb +0 -126
  326. data/spec/extensions/freeze_datasets_spec.rb +0 -31
  327. data/spec/extensions/graph_each_spec.rb +0 -113
  328. data/spec/extensions/hook_class_methods_spec.rb +0 -380
  329. data/spec/extensions/identifier_mangling_spec.rb +0 -201
  330. data/spec/extensions/implicit_subquery_spec.rb +0 -58
  331. data/spec/extensions/index_caching_spec.rb +0 -66
  332. data/spec/extensions/inflector_spec.rb +0 -183
  333. data/spec/extensions/input_transformer_spec.rb +0 -69
  334. data/spec/extensions/insert_returning_select_spec.rb +0 -72
  335. data/spec/extensions/instance_filters_spec.rb +0 -79
  336. data/spec/extensions/instance_hooks_spec.rb +0 -246
  337. data/spec/extensions/integer64_spec.rb +0 -22
  338. data/spec/extensions/inverted_subsets_spec.rb +0 -33
  339. data/spec/extensions/json_serializer_spec.rb +0 -336
  340. data/spec/extensions/lazy_attributes_spec.rb +0 -183
  341. data/spec/extensions/list_spec.rb +0 -275
  342. data/spec/extensions/looser_typecasting_spec.rb +0 -43
  343. data/spec/extensions/many_through_many_spec.rb +0 -2177
  344. data/spec/extensions/migration_spec.rb +0 -840
  345. data/spec/extensions/modification_detection_spec.rb +0 -93
  346. data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -92
  347. data/spec/extensions/named_timezones_spec.rb +0 -109
  348. data/spec/extensions/nested_attributes_spec.rb +0 -703
  349. data/spec/extensions/null_dataset_spec.rb +0 -85
  350. data/spec/extensions/optimistic_locking_spec.rb +0 -127
  351. data/spec/extensions/pagination_spec.rb +0 -116
  352. data/spec/extensions/pg_array_associations_spec.rb +0 -802
  353. data/spec/extensions/pg_array_ops_spec.rb +0 -144
  354. data/spec/extensions/pg_array_spec.rb +0 -398
  355. data/spec/extensions/pg_auto_constraint_validations_spec.rb +0 -165
  356. data/spec/extensions/pg_enum_spec.rb +0 -113
  357. data/spec/extensions/pg_extended_date_support_spec.rb +0 -126
  358. data/spec/extensions/pg_hstore_ops_spec.rb +0 -238
  359. data/spec/extensions/pg_hstore_spec.rb +0 -219
  360. data/spec/extensions/pg_inet_ops_spec.rb +0 -102
  361. data/spec/extensions/pg_inet_spec.rb +0 -72
  362. data/spec/extensions/pg_interval_spec.rb +0 -103
  363. data/spec/extensions/pg_json_ops_spec.rb +0 -289
  364. data/spec/extensions/pg_json_spec.rb +0 -262
  365. data/spec/extensions/pg_loose_count_spec.rb +0 -23
  366. data/spec/extensions/pg_range_ops_spec.rb +0 -60
  367. data/spec/extensions/pg_range_spec.rb +0 -487
  368. data/spec/extensions/pg_row_ops_spec.rb +0 -61
  369. data/spec/extensions/pg_row_plugin_spec.rb +0 -60
  370. data/spec/extensions/pg_row_spec.rb +0 -363
  371. data/spec/extensions/pg_static_cache_updater_spec.rb +0 -93
  372. data/spec/extensions/pg_timestamptz_spec.rb +0 -17
  373. data/spec/extensions/prepared_statements_safe_spec.rb +0 -66
  374. data/spec/extensions/prepared_statements_spec.rb +0 -182
  375. data/spec/extensions/pretty_table_spec.rb +0 -123
  376. data/spec/extensions/query_spec.rb +0 -94
  377. data/spec/extensions/rcte_tree_spec.rb +0 -381
  378. data/spec/extensions/round_timestamps_spec.rb +0 -39
  379. data/spec/extensions/s_spec.rb +0 -60
  380. data/spec/extensions/schema_caching_spec.rb +0 -64
  381. data/spec/extensions/schema_dumper_spec.rb +0 -868
  382. data/spec/extensions/select_remove_spec.rb +0 -38
  383. data/spec/extensions/sequel_4_dataset_methods_spec.rb +0 -121
  384. data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
  385. data/spec/extensions/serialization_spec.rb +0 -365
  386. data/spec/extensions/server_block_spec.rb +0 -97
  387. data/spec/extensions/server_logging_spec.rb +0 -45
  388. data/spec/extensions/sharding_spec.rb +0 -189
  389. data/spec/extensions/shared_caching_spec.rb +0 -151
  390. data/spec/extensions/single_table_inheritance_spec.rb +0 -347
  391. data/spec/extensions/singular_table_names_spec.rb +0 -22
  392. data/spec/extensions/skip_create_refresh_spec.rb +0 -18
  393. data/spec/extensions/spec_helper.rb +0 -61
  394. data/spec/extensions/split_array_nil_spec.rb +0 -24
  395. data/spec/extensions/split_values_spec.rb +0 -57
  396. data/spec/extensions/sql_comments_spec.rb +0 -33
  397. data/spec/extensions/sql_expr_spec.rb +0 -59
  398. data/spec/extensions/static_cache_spec.rb +0 -410
  399. data/spec/extensions/string_agg_spec.rb +0 -90
  400. data/spec/extensions/string_date_time_spec.rb +0 -95
  401. data/spec/extensions/string_stripper_spec.rb +0 -68
  402. data/spec/extensions/subclasses_spec.rb +0 -79
  403. data/spec/extensions/subset_conditions_spec.rb +0 -38
  404. data/spec/extensions/symbol_aref_refinement_spec.rb +0 -28
  405. data/spec/extensions/symbol_as_refinement_spec.rb +0 -21
  406. data/spec/extensions/synchronize_sql_spec.rb +0 -124
  407. data/spec/extensions/table_select_spec.rb +0 -83
  408. data/spec/extensions/tactical_eager_loading_spec.rb +0 -141
  409. data/spec/extensions/thread_local_timezones_spec.rb +0 -67
  410. data/spec/extensions/timestamps_spec.rb +0 -209
  411. data/spec/extensions/to_dot_spec.rb +0 -153
  412. data/spec/extensions/touch_spec.rb +0 -226
  413. data/spec/extensions/tree_spec.rb +0 -284
  414. data/spec/extensions/typecast_on_load_spec.rb +0 -86
  415. data/spec/extensions/unlimited_update_spec.rb +0 -21
  416. data/spec/extensions/update_or_create_spec.rb +0 -83
  417. data/spec/extensions/update_primary_key_spec.rb +0 -105
  418. data/spec/extensions/update_refresh_spec.rb +0 -59
  419. data/spec/extensions/uuid_spec.rb +0 -101
  420. data/spec/extensions/validate_associated_spec.rb +0 -52
  421. data/spec/extensions/validation_class_methods_spec.rb +0 -1040
  422. data/spec/extensions/validation_contexts_spec.rb +0 -31
  423. data/spec/extensions/validation_helpers_spec.rb +0 -525
  424. data/spec/extensions/whitelist_security_spec.rb +0 -157
  425. data/spec/extensions/xml_serializer_spec.rb +0 -213
  426. data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
  427. data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
  428. data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  429. data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  430. data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
  431. data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
  432. data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
  433. data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
  434. data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
  435. data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
  436. data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
  437. data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
  438. data/spec/files/double_migration/001_create_sessions.rb +0 -9
  439. data/spec/files/double_migration/002_create_nodes.rb +0 -19
  440. data/spec/files/double_migration/003_3_create_users.rb +0 -4
  441. data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
  442. data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
  443. data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  444. data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
  445. data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
  446. data/spec/files/empty_migration/001_create_sessions.rb +0 -9
  447. data/spec/files/empty_migration/002_create_nodes.rb +0 -0
  448. data/spec/files/empty_migration/003_3_create_users.rb +0 -4
  449. data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
  450. data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
  451. data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
  452. data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  453. data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
  454. data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  455. data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
  456. data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  457. data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
  458. data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
  459. data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  460. data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  461. data/spec/files/reversible_migrations/001_reversible.rb +0 -5
  462. data/spec/files/reversible_migrations/002_reversible.rb +0 -5
  463. data/spec/files/reversible_migrations/003_reversible.rb +0 -5
  464. data/spec/files/reversible_migrations/004_reversible.rb +0 -5
  465. data/spec/files/reversible_migrations/005_reversible.rb +0 -10
  466. data/spec/files/reversible_migrations/006_reversible.rb +0 -10
  467. data/spec/files/reversible_migrations/007_reversible.rb +0 -10
  468. data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
  469. data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
  470. data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
  471. data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
  472. data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
  473. data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
  474. data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
  475. data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
  476. data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
  477. data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
  478. data/spec/guards_helper.rb +0 -58
  479. data/spec/integration/associations_test.rb +0 -2513
  480. data/spec/integration/database_test.rb +0 -113
  481. data/spec/integration/dataset_test.rb +0 -1880
  482. data/spec/integration/eager_loader_test.rb +0 -687
  483. data/spec/integration/migrator_test.rb +0 -262
  484. data/spec/integration/model_test.rb +0 -203
  485. data/spec/integration/plugin_test.rb +0 -2302
  486. data/spec/integration/prepared_statement_test.rb +0 -398
  487. data/spec/integration/schema_test.rb +0 -869
  488. data/spec/integration/spec_helper.rb +0 -64
  489. data/spec/integration/timezone_test.rb +0 -86
  490. data/spec/integration/transaction_test.rb +0 -354
  491. data/spec/integration/type_test.rb +0 -127
  492. data/spec/model/association_reflection_spec.rb +0 -803
  493. data/spec/model/associations_spec.rb +0 -4538
  494. data/spec/model/base_spec.rb +0 -817
  495. data/spec/model/class_dataset_methods_spec.rb +0 -146
  496. data/spec/model/dataset_methods_spec.rb +0 -198
  497. data/spec/model/eager_loading_spec.rb +0 -2262
  498. data/spec/model/hooks_spec.rb +0 -370
  499. data/spec/model/inflector_spec.rb +0 -26
  500. data/spec/model/model_spec.rb +0 -953
  501. data/spec/model/plugins_spec.rb +0 -318
  502. data/spec/model/record_spec.rb +0 -2107
  503. data/spec/model/spec_helper.rb +0 -45
  504. data/spec/model/validations_spec.rb +0 -193
  505. data/spec/model_no_assoc_spec.rb +0 -1
  506. data/spec/model_spec.rb +0 -1
  507. data/spec/plugin_spec.rb +0 -1
  508. data/spec/sequel_coverage.rb +0 -15
  509. data/spec/sequel_warning.rb +0 -4
  510. data/spec/spec_config.rb +0 -12
@@ -1,116 +0,0 @@
1
- = New Features
2
-
3
- * Sequel::Model::Model() has been added, which allows for
4
- Sequel::Model() like behavior where the base class used is a
5
- subclass of Sequel::Model. To make it easier to use,
6
- Sequel::Model.def_Model has also been added, which takes a module
7
- and adds a Model() method to the module that calls Model() on the
8
- receiver.
9
-
10
- A :class_namespace association option has been added to make it
11
- possible to set a default namespace for the :class option if given
12
- as a symbol or string.
13
-
14
- Sequel::Model.Model.cache_anonymous_models has been added and
15
- controls whether to cache anonymous model subclasses created by
16
- Sequel::Model::Model() on a per-class basis.
17
-
18
- These changes are designed to make it easier to use namespaced
19
- models, for example:
20
-
21
- module Foo
22
- Model = Class.new(Sequel::Model)
23
- Model.def_Model(self)
24
- DB = Model.db = Sequel.connect(ENV['FOO_DATABASE_URL'])
25
- Model.plugin :prepared_statements
26
- Model.default_association_options[:class_namespace] = 'Foo'
27
-
28
- class Bar < Model
29
- # Uses Foo::DB[:bars] as dataset
30
-
31
- # Implicitly uses Foo::Baz as associated class
32
- one_to_many :bazes
33
-
34
- # Uses Foo::Baz due to :class_namespace option
35
- one_to_many :oldest_bazes, :class=>:Baz, :order=>:id
36
- end
37
-
38
- class Baz < Model(:my_baz)
39
- # Uses Foo::DB[:my_baz] as dataset
40
-
41
- # Implicitly uses Foo::Bar as associated class
42
- one_to_many :bars
43
-
44
- # Uses Foo::Bar due to :class_namespace option
45
- one_to_many :oldest_bars, :class=>:Bar, :order=>:id
46
- end
47
- end
48
-
49
- * A string_agg extension has been added for aggregate string
50
- concatentation support on PostgreSQL 9+, SQLAnywhere 12+,
51
- Oracle11g+, DB 9.7+, MySQL, HSQLDB, H2, and CUBRID:
52
-
53
- DB.extension :string_agg
54
- ds = DB[:table]
55
- ds.get(Sequel.string_agg(:c)) # ',' default separator
56
- ds.get(Sequel.string_agg(:c, ' - ')) # custom separator
57
- ds.get(Sequel.string_agg(:c).order(:bar)) # force order
58
- ds.get(Sequel.string_agg(:c).distinct) # remove duplicates
59
-
60
- * A connection_expiration extension has been added, for automatically
61
- removing connections from the connection pool after they have been
62
- open for a given amount of time (4 hours by default).
63
-
64
- * Support for <, <=, >, and >= operator validations when using integer
65
- and string arguments has been added to the constraint_validations
66
- extension and plugin.
67
-
68
- * Sequel::SQL::Function#order has been added to support ordered
69
- aggregate functions:
70
-
71
- Sequel.function(:foo, :bar).order(:baz)
72
- # foo(bar ORDER BY baz)
73
-
74
- = Other Improvements
75
-
76
- * The validates_operator validation in validation_helpers now
77
- considers nil values as invalid unless :allow_nil or a similar
78
- option is used. Previously, using validates_operator with a nil
79
- value would probably raise a NoMethodError. This makes
80
- validates_operator more similar to other validations.
81
-
82
- * The threaded connection pools no longer hold the pool mutex when
83
- disconnecting connections, which is useful if the driver blocks
84
- when disconnecting connections.
85
-
86
- * The connection_validator extension no longer holds a reference
87
- to connections that have been disconnected.
88
-
89
- * The connection_validator extension no longer overwrites the
90
- connection_validation_timeout if loaded a second time.
91
-
92
- * Sequel now closes cursors as soon as it is done using them in the
93
- oracle adapter, instead of waiting for GC to clean them up.
94
-
95
- * Sequel now handles disconnect errors that occur when literalizing
96
- strings in the mysql2 and postgres adapters.
97
-
98
- = Backwards Compatibility
99
-
100
- * Using the Bignum class as a generic type is now deprecated. As
101
- announced in the 4.35.0 release notes, ruby 2.4 is unifying the
102
- Fixnum and Bignum classes into Integer, which results in the
103
- behavior of the Bignum class changing. 4.35.0 added support for
104
- using the :Bignum symbol as a generic 64-bit integer type, and
105
- Sequel users now need to switch to that to avoid the deprecation
106
- warning.
107
-
108
- Sequel 4.41.0 (to be released in December), will drop support
109
- for using the Bignum class as a generic type. This is being done
110
- before the release of ruby 2.4 to hopefully make it unlikely that
111
- users will be subject to a behavior changes when upgrading ruby
112
- versions.
113
-
114
- Related to this change, external adapters need to switch from
115
- overriding Database#type_literal_generic_bignum to
116
- Database#type_literal_generic_bignum_symbol.
@@ -1,50 +0,0 @@
1
- = New Features
2
-
3
- * Database#values has been added on SQLite#3.8.3+, operating similarly
4
- to the support on PostgreSQL:
5
-
6
- DB.values([[1, 2], [3, 4]]).select_map([:column1, :column2])
7
- # => [[1, 2], [3, 4]]
8
-
9
- * Regular expressions in dataset filters are now supported on Oracle
10
- 10g+:
11
-
12
- DB[:t].where(:c=>/re/)
13
- # SELECT * FROM "T" WHERE REGEXP_LIKE("C",'re')
14
-
15
- = Other Improvements
16
-
17
- * Sequel now supports the use of native prepared statements and bound
18
- variables in the mysql2 adapter, when mysql2 0.4+ is used.
19
- Previously, the mysql2 adapter supported database prepared
20
- statements, but variables were always literalized. That is still
21
- supported when mysql2 <0.4 is used.
22
-
23
- * The connection pool now removes connections if it detects a
24
- disconnect error that is not raised as a
25
- Sequel::DatabaseDisconnectError. Such exceptions are reraised
26
- without converted them to Sequel::DatabaseDisconnectError, but the
27
- related connection is now removed from the pool.
28
-
29
- * The reversible migration support now handles add_constraint with an
30
- options hash as the first argument.
31
-
32
- * ASTTransformer now handles Sequel.extract, allowing Dataset#qualify
33
- and other uses of ASTTransformer to work with such values.
34
-
35
- * The create_view :columns option is now suppported on SQLite 3.9.0+.
36
-
37
- * An additional disconnect error is now recognized in the postgres
38
- adapter.
39
-
40
- * A frozen string literal issue has been fixed when multiple different
41
- database connection approaches have failed in the jdbc adapter.
42
-
43
- = Backwards Compatibility
44
-
45
- * External database adapters need to make sure that
46
- Database#database_error_classes returns a valid result if called
47
- during Database#initialize. If you have an external adapter where
48
- one of the error classes depends on an argument given when
49
- connecting (such as the connection string), you may have to make
50
- some changes.
@@ -1,67 +0,0 @@
1
- = New Features
2
-
3
- * Sequel::SQL::NumericMethods#coerce has been added, which adds
4
- support for ruby's coercion protocol when performing numeric
5
- operations. Previously, Sequel supported code like:
6
-
7
- Sequel.expr{a - 1}
8
-
9
- This is because a in this case returns a Sequel::SQL::Indentifier,
10
- which defines #- to return a Sequel::SQL::NumericExpression. By
11
- supporting #coerce, the following code now also works:
12
-
13
- Sequel.expr{1 - a}
14
-
15
- This is because Integer#- calls #coerce on the argument if it is
16
- defined (ruby's coercion protocol). Previously, you had to handle
17
- this differently, using something like:
18
-
19
- Sequel.expr(1) - a
20
- # or
21
- Sequel.-(1, a)
22
-
23
- * Sequel now supports the ** operator for exponentiation on
24
- expressions, similar to the +, -, *, and / operators. Sequel uses
25
- the database power function to implement this by default on the
26
- databases that support it (most of them). On Access, it uses the ^
27
- operator, on Derby it is emulated using a combination of exp/ln
28
- (with some loss of precision). SQLite doesn't support a power
29
- function at all, but Sequel emulates it using multiplication for
30
- known integer exponents.
31
-
32
- * Sequel::SQLTime.date= has been added, which allows you to set the
33
- date used for Sequel::SQLTime instances. Sequel::SQLTime is a
34
- subclass of Time that is literalized using only the time components,
35
- and is the ruby class used to store values of database time columns
36
- on most adapters. Sequel::SQLTime defaults to using the current
37
- date, but you can now set a specific date, for more consistency with
38
- some drivers (Mysql2 uses 2000-01-01, tiny_tds uses 1900-01-01).
39
-
40
- * The postgres adapter now supports a :driver_options option when
41
- using the pg driver, which is passed directly to pg. This can be
42
- used to specify a client SSL certificate or to specify the
43
- certificate authority root certificate when using
44
- :sslmode=>'verify-full'.
45
-
46
- = Other Improvements
47
-
48
- * Sequel no longer uses after_commit/rollback database hooks by
49
- default if the after_commit/after_rollback model methods are not
50
- overridden. This provides a performance speedup, but the main
51
- benefit is that it no longer causes memory issues when saving a
52
- large number of model instances in a single transaction, and it
53
- also works with prepared transactions/2 phase commit. You can
54
- still set use_after_commit_rollback= manually to force the
55
- after_commit/rollback setting.
56
-
57
- Note that Sequel 5 will move after_commit/rollback model hooks to
58
- a plugin, and the default and recommended approach will be to use
59
- the database after_commit/rollback hooks in the after_save or
60
- similar model hooks.
61
-
62
- = Backwards Compatibility
63
-
64
- * The Sequel::Model use_after_commit_rollback class and instance
65
- methods now return nil by default instead of true. nil now
66
- indicates the default behavior of checking whether the appropriate
67
- model hook has been defined, and only adding a database hook if so.
@@ -1,127 +0,0 @@
1
- = New Features
2
-
3
- * Sequel.[] has been added as an alias to Sequel.expr. This makes it
4
- a little easier to get Sequel-specific objects:
5
-
6
- Sequel[:table].* # "table".*
7
- Sequel[:table__column].as(:alias) # "table"."column" AS "alias"
8
- Sequel[:column] + 1 # ("column" + 1)
9
-
10
- * The timestamps plugin now supports an :allow_manual_update option.
11
- If this option is used, the timestamps plugin will not override the
12
- update timestamp when saving if the user has modified it since
13
- retrieving the object.
14
-
15
- * The touch plugin now also touches associations on create in addition
16
- to update and delete.
17
-
18
- * The IntegerMigrator now supports a :relative option, which will
19
- migrate that many migrations up (for positive numbers) or down (for
20
- negative numbers).
21
-
22
- * Database#rollback_checker has been added, which returns a callable
23
- that can be called later to determine whether the transaction ended
24
- up committing or rolling back. So if you may need to check
25
- transaction status at some future point, and don't need immediate
26
- action on rollback/commit, it is better to use a rollback checker
27
- than to add an after commit/rollback hook.
28
-
29
- rbc = nil
30
- DB.transaction do
31
- rbc = DB.rollback_checker
32
- rbc.call #=> nil
33
- end
34
- rbc.call # => false
35
-
36
- DB.transaction(:rollback=>:always) do
37
- rbc = DB.rollback_checker
38
- end
39
- rbc.call # => true
40
-
41
- * The add_column schema method now supports an :if_not_exists option
42
- on PostgreSQL 9.6+, which will only add the column if it does not
43
- already exist:
44
-
45
- DB.add_column :t, :c, Integer, :if_not_exists=>true
46
- # ALTER TABLE "t" ADD COLUMN IF NOT EXISTS "c" integer
47
-
48
- * The add_column schema method now supports an :after and :first
49
- option on MySQL to add the column after an existing column or as
50
- the first column:
51
-
52
- DB.add_column :t, :c, Integer, :first=>true
53
- # ALTER TABLE `t` ADD COLUMN `c` integer FIRST
54
- DB.add_column :t, :c1, Integer, :after=>:c2
55
- # ALTER TABLE `t` ADD COLUMN `c1` integer AFTER `c2`
56
-
57
- * JSONBOp#insert has been added to the pg_json_ops extension, which
58
- supports the new jsonb_insert function added in PostgreSQL 9.6+:
59
-
60
- Sequel.pg_jsonb_op(:c).insert(%w'0 a', 'a'=>1)
61
- # jsonb_insert("c", ARRAY['0','a'], '{"a":1}'::jsonb, false)
62
-
63
- * Dataset#full_text_search on PostgreSQL now supports a
64
- :to_tsquery=>:phrase option, to enable the native phrase searching
65
- added in PostgreSQL 9.6+:
66
-
67
- DB[:t].full_text_search(:c, 'foo bar', :to_tsquery=>:phrase)
68
- # SELECT * FROM "t"
69
- # WHERE
70
- # (to_tsvector(CAST('simple' AS regconfig), (COALESCE("c", '')))
71
- # @@ phraseto_tsquery(CAST('simple' AS regconfig), 'foo bar'))
72
-
73
- * Sequel::Database.set_shared_adapter_scheme has been added, allowing
74
- external adapters to add support for Sequel's mock adapter.
75
- External adapters should have a shared adapter requirable at
76
- sequel/adapters/shared/adapter_name, that uses the following
77
- format:
78
-
79
- # in sequel/adapters/shared/mydb
80
- module Sequel::MyDB
81
- Sequel::Database.set_shared_adapter_scheme :mydb, self
82
-
83
- def self.mock_adapter_setup(db)
84
- # Any mock-adapter specific setup to perform on the
85
- # given Database instance
86
- end
87
-
88
- module DatabaseMethods
89
- # methods for all Database objects using this adapter
90
- end
91
-
92
- module DatasetMethods
93
- # methods for all Dataset objects using this adapter
94
- end
95
- end
96
-
97
-
98
- = Other Improvements
99
-
100
- * The hook_class_methods plugin only adds a Database transaction
101
- hook if one of the after commit/rollback hook class methods is
102
- actually used. This means that loading the plugin no longer
103
- keeps all saved/deleted objects in memory until transaction
104
- commit.
105
-
106
- * The active_model plugin now uses a rollback checker instead of
107
- an after_rollback hook, so models that use the active_model plugin
108
- no longer store all saved model instances in memory until
109
- transaction commit.
110
-
111
- * When using the IntegerMigrator, attempting to migrate to a
112
- migration number above the maximum will now migrate to the lastest
113
- version, and attempting to migrate to a migration number below 0
114
- will now migrate all the way down.
115
-
116
- * The pg_interval extension now supports ActiveSupport::Duration
117
- objects that use week and hour parts (new in ActiveSupport 5).
118
-
119
- = Backwards Compatibility
120
-
121
- * The change to the touch plugin to touch associations on create could
122
- possibly affect existing behavior, so if you are using this plugin,
123
- you should test that this does not cause any problems.
124
-
125
- * External adapters that tried to add support for the mock adapter
126
- now need to update their code to use the new
127
- Sequel::Database.set_shared_adapter_scheme method.
@@ -1,92 +0,0 @@
1
- = New Features
2
-
3
- * Sequel now supports Sybase SQLAnywhere, via the sqlanywhere and
4
- jdbc/sqlanywhere adapters.
5
-
6
- * The filter by associations support now handles cases where the
7
- association has :conditions or a block (as long as the block
8
- does not rely on instance-specific behavior). This allows
9
- you to handle the following:
10
-
11
- Album.many_to_many :popular_tags, :class=>:Tag do |ds|
12
- ds.where{tags__popularity > 9000}
13
- end
14
- Album.where(:popular_tags=>[Tag[1], Tag[2]])
15
-
16
- This will return all albums whose popular_tags would include
17
- at least one of those two tags. Previously, the block would
18
- be ignored, returning albums containing one those tags even if
19
- the tags weren't popular.
20
-
21
- * A table_select plugin has been added that changes the default
22
- selection for models from * to table.*. This is useful for
23
- people who want ActiveRecord-like behavior instead of SQL-like
24
- behavior, where joining tables doesn't automatically include
25
- columns in the other table.
26
-
27
- This can fix issues where joining another table that has columns
28
- with the same name as columns in the model table without
29
- specifying an explicit selection results in model objects being
30
- returned where the values in the model object are the values
31
- from the joined table instead of the model table.
32
-
33
- * Dataset#offset has been added, for specifying offset separately
34
- from limit. Previous this was possible via:
35
-
36
- ds.limit(nil, offset)
37
-
38
- but this is a friendlier API.
39
-
40
- * The jdbc adapter now has support for foreign key parsing. This
41
- is used if there is no specific support for the underlying
42
- database.
43
-
44
- * Foreign key parsing is now supported on Oracle.
45
-
46
- = Other Improvements
47
-
48
- * Association add_*/remove_*/remove_all_* methods for
49
- pg_array_to_many associations now work on unsaved model objects.
50
-
51
- * In the constraint_validations extension, deletes from the
52
- metadata table are now processed before inserts, so that dropping
53
- an existing constraint and readding a constraint with the same
54
- name now works correctly.
55
-
56
- * Cloning an association now copies the :eager_block option
57
- correctly from the source association if it was passed as
58
- the block to the source association method.
59
-
60
- * Cloning a cloned association now copies the block for the
61
- association.
62
-
63
- * The descendants method in the tree plugin no longer modifies an
64
- array it is iterating over.
65
-
66
- * The jdbc/postgresql adapter now supports PostgreSQL-specific types,
67
- with pretty much the same support as the postgres adapter. When
68
- using the pg_* extensions, the dataset will now handle the
69
- PostgreSQL types correctly and return instances of the correct
70
- Ruby classes (e.g. hstore is returned as Sequel::Postgres::HStore).
71
-
72
- You should no longer need to use the typecast_on_load or
73
- pg_typecast_on_load plugins when using model objects that use these
74
- types when using the jdbc/postgresql adapter.
75
-
76
- * Offset emulation on Oracle now handles cases where selected
77
- columns can't be ordered.
78
-
79
- * Offset emulation on DB2 no longer automatically orders on all
80
- columns if the dataset itself is unordered.
81
-
82
- * Types containing spaces are now returning correctly when
83
- parsing the schema in the oracle adapter.
84
-
85
- * Database#tables no longer returns tables in the recycle bin on
86
- Oracle.
87
-
88
- * add_foreign_key now works correctly on HSQLDB, by splitting the
89
- column addition and constraint addition into two separate
90
- statements.
91
-
92
- * add_primary_key now works correctly on H2.