activerecord 5.0.7.2 → 6.0.6.1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of activerecord might be problematic. Click here for more details.

Files changed (359) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +844 -1944
  3. data/MIT-LICENSE +3 -1
  4. data/README.rdoc +9 -7
  5. data/examples/performance.rb +31 -29
  6. data/examples/simple.rb +5 -3
  7. data/lib/active_record/advisory_lock_base.rb +18 -0
  8. data/lib/active_record/aggregations.rb +249 -247
  9. data/lib/active_record/association_relation.rb +18 -14
  10. data/lib/active_record/associations/alias_tracker.rb +24 -34
  11. data/lib/active_record/associations/association.rb +113 -55
  12. data/lib/active_record/associations/association_scope.rb +102 -96
  13. data/lib/active_record/associations/belongs_to_association.rb +58 -42
  14. data/lib/active_record/associations/belongs_to_polymorphic_association.rb +8 -12
  15. data/lib/active_record/associations/builder/association.rb +18 -25
  16. data/lib/active_record/associations/builder/belongs_to.rb +43 -54
  17. data/lib/active_record/associations/builder/collection_association.rb +7 -18
  18. data/lib/active_record/associations/builder/has_and_belongs_to_many.rb +41 -62
  19. data/lib/active_record/associations/builder/has_many.rb +4 -0
  20. data/lib/active_record/associations/builder/has_one.rb +37 -1
  21. data/lib/active_record/associations/builder/singular_association.rb +4 -0
  22. data/lib/active_record/associations/collection_association.rb +93 -254
  23. data/lib/active_record/associations/collection_proxy.rb +159 -122
  24. data/lib/active_record/associations/foreign_association.rb +9 -0
  25. data/lib/active_record/associations/has_many_association.rb +23 -30
  26. data/lib/active_record/associations/has_many_through_association.rb +58 -44
  27. data/lib/active_record/associations/has_one_association.rb +59 -54
  28. data/lib/active_record/associations/has_one_through_association.rb +20 -11
  29. data/lib/active_record/associations/join_dependency/join_association.rb +43 -85
  30. data/lib/active_record/associations/join_dependency/join_base.rb +10 -9
  31. data/lib/active_record/associations/join_dependency/join_part.rb +14 -14
  32. data/lib/active_record/associations/join_dependency.rb +152 -177
  33. data/lib/active_record/associations/preloader/association.rb +101 -97
  34. data/lib/active_record/associations/preloader/through_association.rb +77 -76
  35. data/lib/active_record/associations/preloader.rb +94 -103
  36. data/lib/active_record/associations/singular_association.rb +12 -45
  37. data/lib/active_record/associations/through_association.rb +27 -15
  38. data/lib/active_record/associations.rb +1603 -1592
  39. data/lib/active_record/attribute_assignment.rb +54 -61
  40. data/lib/active_record/attribute_decorators.rb +38 -17
  41. data/lib/active_record/attribute_methods/before_type_cast.rb +12 -8
  42. data/lib/active_record/attribute_methods/dirty.rb +179 -109
  43. data/lib/active_record/attribute_methods/primary_key.rb +85 -92
  44. data/lib/active_record/attribute_methods/query.rb +4 -3
  45. data/lib/active_record/attribute_methods/read.rb +20 -49
  46. data/lib/active_record/attribute_methods/serialization.rb +29 -7
  47. data/lib/active_record/attribute_methods/time_zone_conversion.rb +39 -66
  48. data/lib/active_record/attribute_methods/write.rb +34 -33
  49. data/lib/active_record/attribute_methods.rb +66 -106
  50. data/lib/active_record/attributes.rb +38 -25
  51. data/lib/active_record/autosave_association.rb +58 -39
  52. data/lib/active_record/base.rb +27 -24
  53. data/lib/active_record/callbacks.rb +64 -35
  54. data/lib/active_record/coders/json.rb +2 -0
  55. data/lib/active_record/coders/yaml_column.rb +34 -13
  56. data/lib/active_record/connection_adapters/abstract/connection_pool.rb +558 -323
  57. data/lib/active_record/connection_adapters/abstract/database_limits.rb +23 -5
  58. data/lib/active_record/connection_adapters/abstract/database_statements.rb +215 -94
  59. data/lib/active_record/connection_adapters/abstract/query_cache.rb +59 -35
  60. data/lib/active_record/connection_adapters/abstract/quoting.rb +128 -75
  61. data/lib/active_record/connection_adapters/abstract/savepoints.rb +2 -0
  62. data/lib/active_record/connection_adapters/abstract/schema_creation.rb +33 -28
  63. data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +233 -147
  64. data/lib/active_record/connection_adapters/abstract/schema_dumper.rb +68 -80
  65. data/lib/active_record/connection_adapters/abstract/schema_statements.rb +400 -213
  66. data/lib/active_record/connection_adapters/abstract/transaction.rb +169 -79
  67. data/lib/active_record/connection_adapters/abstract_adapter.rb +373 -202
  68. data/lib/active_record/connection_adapters/abstract_mysql_adapter.rb +401 -562
  69. data/lib/active_record/connection_adapters/column.rb +41 -13
  70. data/lib/active_record/connection_adapters/connection_specification.rb +172 -139
  71. data/lib/active_record/connection_adapters/determine_if_preparable_visitor.rb +11 -4
  72. data/lib/active_record/connection_adapters/mysql/column.rb +8 -31
  73. data/lib/active_record/connection_adapters/mysql/database_statements.rb +137 -49
  74. data/lib/active_record/connection_adapters/mysql/explain_pretty_printer.rb +24 -23
  75. data/lib/active_record/connection_adapters/mysql/quoting.rb +50 -20
  76. data/lib/active_record/connection_adapters/mysql/schema_creation.rb +49 -45
  77. data/lib/active_record/connection_adapters/mysql/schema_definitions.rb +58 -56
  78. data/lib/active_record/connection_adapters/mysql/schema_dumper.rb +70 -36
  79. data/lib/active_record/connection_adapters/mysql/schema_statements.rb +268 -0
  80. data/lib/active_record/connection_adapters/mysql/type_metadata.rb +12 -13
  81. data/lib/active_record/connection_adapters/mysql2_adapter.rb +48 -30
  82. data/lib/active_record/connection_adapters/postgresql/column.rb +19 -31
  83. data/lib/active_record/connection_adapters/postgresql/database_statements.rb +64 -54
  84. data/lib/active_record/connection_adapters/postgresql/explain_pretty_printer.rb +5 -3
  85. data/lib/active_record/connection_adapters/postgresql/oid/array.rb +22 -11
  86. data/lib/active_record/connection_adapters/postgresql/oid/bit.rb +6 -5
  87. data/lib/active_record/connection_adapters/postgresql/oid/bit_varying.rb +2 -0
  88. data/lib/active_record/connection_adapters/postgresql/oid/bytea.rb +2 -0
  89. data/lib/active_record/connection_adapters/postgresql/oid/cidr.rb +3 -1
  90. data/lib/active_record/connection_adapters/postgresql/oid/date.rb +23 -0
  91. data/lib/active_record/connection_adapters/postgresql/oid/date_time.rb +12 -2
  92. data/lib/active_record/connection_adapters/postgresql/oid/decimal.rb +3 -1
  93. data/lib/active_record/connection_adapters/postgresql/oid/enum.rb +5 -4
  94. data/lib/active_record/connection_adapters/postgresql/oid/hstore.rb +19 -18
  95. data/lib/active_record/connection_adapters/postgresql/oid/inet.rb +2 -0
  96. data/lib/active_record/connection_adapters/postgresql/oid/jsonb.rb +3 -11
  97. data/lib/active_record/connection_adapters/postgresql/oid/legacy_point.rb +44 -0
  98. data/lib/active_record/connection_adapters/postgresql/oid/money.rb +7 -5
  99. data/lib/active_record/connection_adapters/postgresql/oid/{json.rb → oid.rb} +6 -1
  100. data/lib/active_record/connection_adapters/postgresql/oid/point.rb +30 -9
  101. data/lib/active_record/connection_adapters/postgresql/oid/range.rb +52 -30
  102. data/lib/active_record/connection_adapters/postgresql/oid/specialized_string.rb +4 -1
  103. data/lib/active_record/connection_adapters/postgresql/oid/type_map_initializer.rb +58 -54
  104. data/lib/active_record/connection_adapters/postgresql/oid/uuid.rb +8 -4
  105. data/lib/active_record/connection_adapters/postgresql/oid/vector.rb +2 -0
  106. data/lib/active_record/connection_adapters/postgresql/oid/xml.rb +2 -0
  107. data/lib/active_record/connection_adapters/postgresql/oid.rb +24 -21
  108. data/lib/active_record/connection_adapters/postgresql/quoting.rb +95 -35
  109. data/lib/active_record/connection_adapters/postgresql/referential_integrity.rb +20 -26
  110. data/lib/active_record/connection_adapters/postgresql/schema_creation.rb +76 -0
  111. data/lib/active_record/connection_adapters/postgresql/schema_definitions.rb +147 -105
  112. data/lib/active_record/connection_adapters/postgresql/schema_dumper.rb +34 -32
  113. data/lib/active_record/connection_adapters/postgresql/schema_statements.rb +378 -308
  114. data/lib/active_record/connection_adapters/postgresql/type_metadata.rb +26 -25
  115. data/lib/active_record/connection_adapters/postgresql/utils.rb +9 -6
  116. data/lib/active_record/connection_adapters/postgresql_adapter.rb +383 -275
  117. data/lib/active_record/connection_adapters/schema_cache.rb +46 -12
  118. data/lib/active_record/connection_adapters/sql_type_metadata.rb +13 -8
  119. data/lib/active_record/connection_adapters/sqlite3/database_statements.rb +119 -0
  120. data/lib/active_record/connection_adapters/sqlite3/explain_pretty_printer.rb +3 -1
  121. data/lib/active_record/connection_adapters/sqlite3/quoting.rb +72 -18
  122. data/lib/active_record/connection_adapters/sqlite3/schema_creation.rb +3 -8
  123. data/lib/active_record/connection_adapters/sqlite3/schema_definitions.rb +19 -0
  124. data/lib/active_record/connection_adapters/sqlite3/schema_dumper.rb +18 -0
  125. data/lib/active_record/connection_adapters/sqlite3/schema_statements.rb +137 -0
  126. data/lib/active_record/connection_adapters/sqlite3_adapter.rb +261 -267
  127. data/lib/active_record/connection_adapters/statement_pool.rb +9 -8
  128. data/lib/active_record/connection_handling.rb +143 -40
  129. data/lib/active_record/core.rb +207 -160
  130. data/lib/active_record/counter_cache.rb +60 -28
  131. data/lib/active_record/database_configurations/database_config.rb +37 -0
  132. data/lib/active_record/database_configurations/hash_config.rb +50 -0
  133. data/lib/active_record/database_configurations/url_config.rb +78 -0
  134. data/lib/active_record/database_configurations.rb +233 -0
  135. data/lib/active_record/define_callbacks.rb +22 -0
  136. data/lib/active_record/dynamic_matchers.rb +87 -87
  137. data/lib/active_record/enum.rb +67 -23
  138. data/lib/active_record/errors.rb +114 -18
  139. data/lib/active_record/explain.rb +4 -4
  140. data/lib/active_record/explain_registry.rb +3 -1
  141. data/lib/active_record/explain_subscriber.rb +9 -4
  142. data/lib/active_record/fixture_set/file.rb +13 -8
  143. data/lib/active_record/fixture_set/model_metadata.rb +33 -0
  144. data/lib/active_record/fixture_set/render_context.rb +17 -0
  145. data/lib/active_record/fixture_set/table_row.rb +152 -0
  146. data/lib/active_record/fixture_set/table_rows.rb +46 -0
  147. data/lib/active_record/fixtures.rb +194 -504
  148. data/lib/active_record/gem_version.rb +5 -3
  149. data/lib/active_record/inheritance.rb +150 -99
  150. data/lib/active_record/insert_all.rb +179 -0
  151. data/lib/active_record/integration.rb +116 -25
  152. data/lib/active_record/internal_metadata.rb +16 -19
  153. data/lib/active_record/legacy_yaml_adapter.rb +4 -2
  154. data/lib/active_record/locking/optimistic.rb +85 -86
  155. data/lib/active_record/locking/pessimistic.rb +18 -6
  156. data/lib/active_record/log_subscriber.rb +48 -29
  157. data/lib/active_record/middleware/database_selector/resolver/session.rb +45 -0
  158. data/lib/active_record/middleware/database_selector/resolver.rb +87 -0
  159. data/lib/active_record/middleware/database_selector.rb +74 -0
  160. data/lib/active_record/migration/command_recorder.rb +134 -100
  161. data/lib/active_record/migration/compatibility.rb +174 -56
  162. data/lib/active_record/migration/join_table.rb +8 -7
  163. data/lib/active_record/migration.rb +369 -302
  164. data/lib/active_record/model_schema.rb +160 -127
  165. data/lib/active_record/nested_attributes.rb +213 -202
  166. data/lib/active_record/no_touching.rb +12 -3
  167. data/lib/active_record/null_relation.rb +12 -34
  168. data/lib/active_record/persistence.rb +446 -77
  169. data/lib/active_record/query_cache.rb +13 -12
  170. data/lib/active_record/querying.rb +37 -24
  171. data/lib/active_record/railtie.rb +128 -36
  172. data/lib/active_record/railties/collection_cache_association_loading.rb +34 -0
  173. data/lib/active_record/railties/console_sandbox.rb +2 -0
  174. data/lib/active_record/railties/controller_runtime.rb +34 -33
  175. data/lib/active_record/railties/databases.rake +312 -177
  176. data/lib/active_record/readonly_attributes.rb +5 -4
  177. data/lib/active_record/reflection.rb +214 -254
  178. data/lib/active_record/relation/batches/batch_enumerator.rb +3 -1
  179. data/lib/active_record/relation/batches.rb +98 -52
  180. data/lib/active_record/relation/calculations.rb +212 -173
  181. data/lib/active_record/relation/delegation.rb +73 -69
  182. data/lib/active_record/relation/finder_methods.rb +207 -247
  183. data/lib/active_record/relation/from_clause.rb +6 -8
  184. data/lib/active_record/relation/merger.rb +82 -61
  185. data/lib/active_record/relation/predicate_builder/array_handler.rb +20 -14
  186. data/lib/active_record/relation/predicate_builder/association_query_value.rb +43 -0
  187. data/lib/active_record/relation/predicate_builder/base_handler.rb +4 -3
  188. data/lib/active_record/relation/predicate_builder/basic_object_handler.rb +6 -4
  189. data/lib/active_record/relation/predicate_builder/polymorphic_array_value.rb +53 -0
  190. data/lib/active_record/relation/predicate_builder/range_handler.rb +7 -18
  191. data/lib/active_record/relation/predicate_builder/relation_handler.rb +6 -0
  192. data/lib/active_record/relation/predicate_builder.rb +83 -105
  193. data/lib/active_record/relation/query_attribute.rb +33 -2
  194. data/lib/active_record/relation/query_methods.rb +488 -332
  195. data/lib/active_record/relation/record_fetch_warning.rb +5 -3
  196. data/lib/active_record/relation/spawn_methods.rb +8 -8
  197. data/lib/active_record/relation/where_clause.rb +111 -96
  198. data/lib/active_record/relation/where_clause_factory.rb +6 -11
  199. data/lib/active_record/relation.rb +443 -318
  200. data/lib/active_record/result.rb +69 -40
  201. data/lib/active_record/runtime_registry.rb +5 -3
  202. data/lib/active_record/sanitization.rb +83 -99
  203. data/lib/active_record/schema.rb +7 -14
  204. data/lib/active_record/schema_dumper.rb +71 -69
  205. data/lib/active_record/schema_migration.rb +16 -6
  206. data/lib/active_record/scoping/default.rb +92 -95
  207. data/lib/active_record/scoping/named.rb +51 -26
  208. data/lib/active_record/scoping.rb +20 -20
  209. data/lib/active_record/secure_token.rb +4 -2
  210. data/lib/active_record/serialization.rb +2 -0
  211. data/lib/active_record/statement_cache.rb +63 -28
  212. data/lib/active_record/store.rb +121 -41
  213. data/lib/active_record/suppressor.rb +6 -3
  214. data/lib/active_record/table_metadata.rb +39 -18
  215. data/lib/active_record/tasks/database_tasks.rb +271 -81
  216. data/lib/active_record/tasks/mysql_database_tasks.rb +54 -91
  217. data/lib/active_record/tasks/postgresql_database_tasks.rb +77 -47
  218. data/lib/active_record/tasks/sqlite_database_tasks.rb +33 -16
  219. data/lib/active_record/test_databases.rb +23 -0
  220. data/lib/active_record/test_fixtures.rb +243 -0
  221. data/lib/active_record/timestamp.rb +70 -36
  222. data/lib/active_record/touch_later.rb +8 -6
  223. data/lib/active_record/transactions.rb +141 -157
  224. data/lib/active_record/translation.rb +3 -1
  225. data/lib/active_record/type/adapter_specific_registry.rb +44 -48
  226. data/lib/active_record/type/date.rb +2 -0
  227. data/lib/active_record/type/date_time.rb +2 -0
  228. data/lib/active_record/type/decimal_without_scale.rb +15 -0
  229. data/lib/active_record/type/hash_lookup_type_map.rb +5 -4
  230. data/lib/active_record/type/internal/timezone.rb +2 -0
  231. data/lib/active_record/type/json.rb +30 -0
  232. data/lib/active_record/type/serialized.rb +16 -9
  233. data/lib/active_record/type/text.rb +11 -0
  234. data/lib/active_record/type/time.rb +12 -1
  235. data/lib/active_record/type/type_map.rb +14 -17
  236. data/lib/active_record/type/unsigned_integer.rb +16 -0
  237. data/lib/active_record/type.rb +23 -18
  238. data/lib/active_record/type_caster/connection.rb +17 -12
  239. data/lib/active_record/type_caster/map.rb +5 -4
  240. data/lib/active_record/type_caster.rb +4 -2
  241. data/lib/active_record/validations/absence.rb +2 -0
  242. data/lib/active_record/validations/associated.rb +3 -2
  243. data/lib/active_record/validations/length.rb +2 -0
  244. data/lib/active_record/validations/presence.rb +4 -2
  245. data/lib/active_record/validations/uniqueness.rb +29 -42
  246. data/lib/active_record/validations.rb +7 -5
  247. data/lib/active_record/version.rb +3 -1
  248. data/lib/active_record.rb +37 -22
  249. data/lib/arel/alias_predication.rb +9 -0
  250. data/lib/arel/attributes/attribute.rb +37 -0
  251. data/lib/arel/attributes.rb +22 -0
  252. data/lib/arel/collectors/bind.rb +24 -0
  253. data/lib/arel/collectors/composite.rb +31 -0
  254. data/lib/arel/collectors/plain_string.rb +20 -0
  255. data/lib/arel/collectors/sql_string.rb +20 -0
  256. data/lib/arel/collectors/substitute_binds.rb +28 -0
  257. data/lib/arel/crud.rb +42 -0
  258. data/lib/arel/delete_manager.rb +18 -0
  259. data/lib/arel/errors.rb +9 -0
  260. data/lib/arel/expressions.rb +29 -0
  261. data/lib/arel/factory_methods.rb +49 -0
  262. data/lib/arel/insert_manager.rb +49 -0
  263. data/lib/arel/math.rb +45 -0
  264. data/lib/arel/nodes/and.rb +32 -0
  265. data/lib/arel/nodes/ascending.rb +23 -0
  266. data/lib/arel/nodes/binary.rb +52 -0
  267. data/lib/arel/nodes/bind_param.rb +36 -0
  268. data/lib/arel/nodes/case.rb +55 -0
  269. data/lib/arel/nodes/casted.rb +50 -0
  270. data/lib/arel/nodes/comment.rb +29 -0
  271. data/lib/arel/nodes/count.rb +12 -0
  272. data/lib/arel/nodes/delete_statement.rb +45 -0
  273. data/lib/arel/nodes/descending.rb +23 -0
  274. data/lib/arel/nodes/equality.rb +18 -0
  275. data/lib/arel/nodes/extract.rb +24 -0
  276. data/lib/arel/nodes/false.rb +16 -0
  277. data/lib/arel/nodes/full_outer_join.rb +8 -0
  278. data/lib/arel/nodes/function.rb +44 -0
  279. data/lib/arel/nodes/grouping.rb +8 -0
  280. data/lib/arel/nodes/in.rb +8 -0
  281. data/lib/arel/nodes/infix_operation.rb +80 -0
  282. data/lib/arel/nodes/inner_join.rb +8 -0
  283. data/lib/arel/nodes/insert_statement.rb +37 -0
  284. data/lib/arel/nodes/join_source.rb +20 -0
  285. data/lib/arel/nodes/matches.rb +18 -0
  286. data/lib/arel/nodes/named_function.rb +23 -0
  287. data/lib/arel/nodes/node.rb +50 -0
  288. data/lib/arel/nodes/node_expression.rb +13 -0
  289. data/lib/arel/nodes/outer_join.rb +8 -0
  290. data/lib/arel/nodes/over.rb +15 -0
  291. data/lib/arel/nodes/regexp.rb +16 -0
  292. data/lib/arel/nodes/right_outer_join.rb +8 -0
  293. data/lib/arel/nodes/select_core.rb +67 -0
  294. data/lib/arel/nodes/select_statement.rb +41 -0
  295. data/lib/arel/nodes/sql_literal.rb +16 -0
  296. data/lib/arel/nodes/string_join.rb +11 -0
  297. data/lib/arel/nodes/table_alias.rb +27 -0
  298. data/lib/arel/nodes/terminal.rb +16 -0
  299. data/lib/arel/nodes/true.rb +16 -0
  300. data/lib/arel/nodes/unary.rb +45 -0
  301. data/lib/arel/nodes/unary_operation.rb +20 -0
  302. data/lib/arel/nodes/unqualified_column.rb +22 -0
  303. data/lib/arel/nodes/update_statement.rb +41 -0
  304. data/lib/arel/nodes/values_list.rb +9 -0
  305. data/lib/arel/nodes/window.rb +126 -0
  306. data/lib/arel/nodes/with.rb +11 -0
  307. data/lib/arel/nodes.rb +68 -0
  308. data/lib/arel/order_predications.rb +13 -0
  309. data/lib/arel/predications.rb +256 -0
  310. data/lib/arel/select_manager.rb +271 -0
  311. data/lib/arel/table.rb +110 -0
  312. data/lib/arel/tree_manager.rb +72 -0
  313. data/lib/arel/update_manager.rb +34 -0
  314. data/lib/arel/visitors/depth_first.rb +203 -0
  315. data/lib/arel/visitors/dot.rb +296 -0
  316. data/lib/arel/visitors/ibm_db.rb +34 -0
  317. data/lib/arel/visitors/informix.rb +62 -0
  318. data/lib/arel/visitors/mssql.rb +156 -0
  319. data/lib/arel/visitors/mysql.rb +83 -0
  320. data/lib/arel/visitors/oracle.rb +158 -0
  321. data/lib/arel/visitors/oracle12.rb +65 -0
  322. data/lib/arel/visitors/postgresql.rb +109 -0
  323. data/lib/arel/visitors/sqlite.rb +38 -0
  324. data/lib/arel/visitors/to_sql.rb +888 -0
  325. data/lib/arel/visitors/visitor.rb +45 -0
  326. data/lib/arel/visitors/where_sql.rb +22 -0
  327. data/lib/arel/visitors.rb +20 -0
  328. data/lib/arel/window_predications.rb +9 -0
  329. data/lib/arel.rb +62 -0
  330. data/lib/rails/generators/active_record/application_record/application_record_generator.rb +26 -0
  331. data/lib/rails/generators/active_record/migration/migration_generator.rb +37 -35
  332. data/lib/rails/generators/active_record/migration/templates/{create_table_migration.rb → create_table_migration.rb.tt} +1 -1
  333. data/lib/rails/generators/active_record/migration/templates/{migration.rb → migration.rb.tt} +4 -2
  334. data/lib/rails/generators/active_record/migration.rb +17 -3
  335. data/lib/rails/generators/active_record/model/model_generator.rb +9 -30
  336. data/lib/rails/generators/active_record/model/templates/{model.rb → model.rb.tt} +10 -1
  337. data/lib/rails/generators/active_record.rb +7 -5
  338. metadata +138 -52
  339. data/lib/active_record/associations/preloader/belongs_to.rb +0 -17
  340. data/lib/active_record/associations/preloader/collection_association.rb +0 -17
  341. data/lib/active_record/associations/preloader/has_many.rb +0 -17
  342. data/lib/active_record/associations/preloader/has_many_through.rb +0 -19
  343. data/lib/active_record/associations/preloader/has_one.rb +0 -15
  344. data/lib/active_record/associations/preloader/has_one_through.rb +0 -9
  345. data/lib/active_record/associations/preloader/singular_association.rb +0 -20
  346. data/lib/active_record/attribute/user_provided_default.rb +0 -28
  347. data/lib/active_record/attribute.rb +0 -213
  348. data/lib/active_record/attribute_mutation_tracker.rb +0 -70
  349. data/lib/active_record/attribute_set/builder.rb +0 -132
  350. data/lib/active_record/attribute_set.rb +0 -110
  351. data/lib/active_record/collection_cache_key.rb +0 -50
  352. data/lib/active_record/connection_adapters/postgresql/oid/rails_5_1_point.rb +0 -50
  353. data/lib/active_record/railties/jdbcmysql_error.rb +0 -16
  354. data/lib/active_record/relation/predicate_builder/association_query_handler.rb +0 -88
  355. data/lib/active_record/relation/predicate_builder/class_handler.rb +0 -27
  356. data/lib/active_record/relation/predicate_builder/polymorphic_array_handler.rb +0 -57
  357. data/lib/active_record/type/internal/abstract_json.rb +0 -33
  358. /data/lib/rails/generators/active_record/{model/templates/application_record.rb → application_record/templates/application_record.rb.tt} +0 -0
  359. /data/lib/rails/generators/active_record/model/templates/{module.rb → module.rb.tt} +0 -0
@@ -1,29 +1,39 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module ActiveRecord
2
4
  module ConnectionAdapters
3
5
  module MySQL
4
6
  module DatabaseStatements
5
7
  # Returns an ActiveRecord::Result instance.
6
- def select_all(arel, name = nil, binds = [], preparable: nil)
8
+ def select_all(*, **) # :nodoc:
7
9
  result = if ExplainRegistry.collect? && prepared_statements
8
10
  unprepared_statement { super }
9
11
  else
10
12
  super
11
13
  end
12
- @connection.next_result while @connection.more_results?
14
+ @connection.abandon_results!
13
15
  result
14
16
  end
15
17
 
16
- # Returns an array of arrays containing the field values.
17
- # Order is the same as that returned by +columns+.
18
- def select_rows(sql, name = nil, binds = [])
19
- select_result(sql, name, binds) do |result|
20
- @connection.next_result while @connection.more_results?
21
- result.to_a
22
- end
18
+ def query(sql, name = nil) # :nodoc:
19
+ execute(sql, name).to_a
20
+ end
21
+
22
+ READ_QUERY = ActiveRecord::ConnectionAdapters::AbstractAdapter.build_read_query_regexp(
23
+ :desc, :describe, :set, :show, :use
24
+ ) # :nodoc:
25
+ private_constant :READ_QUERY
26
+
27
+ def write_query?(sql) # :nodoc:
28
+ !READ_QUERY.match?(sql)
23
29
  end
24
30
 
25
31
  # Executes the SQL statement in the context of this connection.
26
32
  def execute(sql, name = nil)
33
+ if preventing_writes? && write_query?(sql)
34
+ raise ActiveRecord::ReadOnlyError, "Write query attempted while in readonly mode: #{sql}"
35
+ end
36
+
27
37
  # make sure we carry over any changes to ActiveRecord::Base.default_timezone that have been
28
38
  # made since we established the connection
29
39
  @connection.query_options[:database_timezone] = ActiveRecord::Base.default_timezone
@@ -31,77 +41,155 @@ module ActiveRecord
31
41
  super
32
42
  end
33
43
 
34
- def exec_query(sql, name = 'SQL', binds = [], prepare: false)
44
+ def exec_query(sql, name = "SQL", binds = [], prepare: false)
35
45
  if without_prepared_statement?(binds)
36
46
  execute_and_free(sql, name) do |result|
37
- ActiveRecord::Result.new(result.fields, result.to_a) if result
47
+ if result
48
+ ActiveRecord::Result.new(result.fields, result.to_a)
49
+ else
50
+ ActiveRecord::Result.new([], [])
51
+ end
38
52
  end
39
53
  else
40
54
  exec_stmt_and_free(sql, name, binds, cache_stmt: prepare) do |_, result|
41
- ActiveRecord::Result.new(result.fields, result.to_a) if result
55
+ if result
56
+ ActiveRecord::Result.new(result.fields, result.to_a)
57
+ else
58
+ ActiveRecord::Result.new([], [])
59
+ end
42
60
  end
43
61
  end
44
62
  end
45
63
 
46
- def exec_delete(sql, name, binds)
64
+ def exec_delete(sql, name = nil, binds = [])
47
65
  if without_prepared_statement?(binds)
48
- execute_and_free(sql, name) { @connection.affected_rows }
66
+ @lock.synchronize do
67
+ execute_and_free(sql, name) { @connection.affected_rows }
68
+ end
49
69
  else
50
70
  exec_stmt_and_free(sql, name, binds) { |stmt| stmt.affected_rows }
51
71
  end
52
72
  end
53
73
  alias :exec_update :exec_delete
54
74
 
55
- protected
75
+ private
76
+ def execute_batch(statements, name = nil)
77
+ combine_multi_statements(statements).each do |statement|
78
+ execute(statement, name)
79
+ end
80
+ @connection.abandon_results!
81
+ end
56
82
 
57
- def last_inserted_id(result)
58
- @connection.last_id
59
- end
83
+ def default_insert_value(column)
84
+ super unless column.auto_increment?
85
+ end
60
86
 
61
- private
87
+ def last_inserted_id(result)
88
+ @connection.last_id
89
+ end
62
90
 
63
- def select_result(sql, name = nil, binds = [])
64
- if without_prepared_statement?(binds)
65
- execute_and_free(sql, name) { |result| yield result }
66
- else
67
- exec_stmt_and_free(sql, name, binds, cache_stmt: true) { |_, result| yield result }
91
+ def supports_set_server_option?
92
+ @connection.respond_to?(:set_server_option)
68
93
  end
69
- end
70
94
 
71
- def exec_stmt_and_free(sql, name, binds, cache_stmt: false)
72
- # make sure we carry over any changes to ActiveRecord::Base.default_timezone that have been
73
- # made since we established the connection
74
- @connection.query_options[:database_timezone] = ActiveRecord::Base.default_timezone
95
+ def multi_statements_enabled?(flags)
96
+ if flags.is_a?(Array)
97
+ flags.include?("MULTI_STATEMENTS")
98
+ else
99
+ (flags & Mysql2::Client::MULTI_STATEMENTS) != 0
100
+ end
101
+ end
75
102
 
76
- type_casted_binds = type_casted_binds(binds)
103
+ def with_multi_statements
104
+ previous_flags = @config[:flags]
77
105
 
78
- log(sql, name, binds, type_casted_binds) do
79
- if cache_stmt
80
- cache = @statements[sql] ||= {
81
- stmt: @connection.prepare(sql)
82
- }
83
- stmt = cache[:stmt]
106
+ unless multi_statements_enabled?(previous_flags)
107
+ if supports_set_server_option?
108
+ @connection.set_server_option(Mysql2::Client::OPTION_MULTI_STATEMENTS_ON)
109
+ else
110
+ @config[:flags] = Mysql2::Client::MULTI_STATEMENTS
111
+ reconnect!
112
+ end
113
+ end
114
+
115
+ yield
116
+ ensure
117
+ unless multi_statements_enabled?(previous_flags)
118
+ if supports_set_server_option?
119
+ @connection.set_server_option(Mysql2::Client::OPTION_MULTI_STATEMENTS_OFF)
120
+ else
121
+ @config[:flags] = previous_flags
122
+ reconnect!
123
+ end
124
+ end
125
+ end
126
+
127
+ def combine_multi_statements(total_sql)
128
+ total_sql.each_with_object([]) do |sql, total_sql_chunks|
129
+ previous_packet = total_sql_chunks.last
130
+ if max_allowed_packet_reached?(sql, previous_packet)
131
+ total_sql_chunks << +sql
132
+ else
133
+ previous_packet << ";\n"
134
+ previous_packet << sql
135
+ end
136
+ end
137
+ end
138
+
139
+ def max_allowed_packet_reached?(current_packet, previous_packet)
140
+ if current_packet.bytesize > max_allowed_packet
141
+ raise ActiveRecordError,
142
+ "Fixtures set is too large #{current_packet.bytesize}. Consider increasing the max_allowed_packet variable."
143
+ elsif previous_packet.nil?
144
+ true
84
145
  else
85
- stmt = @connection.prepare(sql)
146
+ (current_packet.bytesize + previous_packet.bytesize + 2) > max_allowed_packet
86
147
  end
148
+ end
149
+
150
+ def max_allowed_packet
151
+ @max_allowed_packet ||= show_variable("max_allowed_packet")
152
+ end
153
+
154
+ def exec_stmt_and_free(sql, name, binds, cache_stmt: false)
155
+ if preventing_writes? && write_query?(sql)
156
+ raise ActiveRecord::ReadOnlyError, "Write query attempted while in readonly mode: #{sql}"
157
+ end
158
+
159
+ materialize_transactions
160
+
161
+ # make sure we carry over any changes to ActiveRecord::Base.default_timezone that have been
162
+ # made since we established the connection
163
+ @connection.query_options[:database_timezone] = ActiveRecord::Base.default_timezone
87
164
 
88
- begin
89
- result = stmt.execute(*type_casted_binds)
90
- rescue Mysql2::Error => e
165
+ type_casted_binds = type_casted_binds(binds)
166
+
167
+ log(sql, name, binds, type_casted_binds) do
91
168
  if cache_stmt
92
- @statements.delete(sql)
169
+ stmt = @statements[sql] ||= @connection.prepare(sql)
93
170
  else
94
- stmt.close
171
+ stmt = @connection.prepare(sql)
172
+ end
173
+
174
+ begin
175
+ result = ActiveSupport::Dependencies.interlock.permit_concurrent_loads do
176
+ stmt.execute(*type_casted_binds)
177
+ end
178
+ rescue Mysql2::Error => e
179
+ if cache_stmt
180
+ @statements.delete(sql)
181
+ else
182
+ stmt.close
183
+ end
184
+ raise e
95
185
  end
96
- raise e
97
- end
98
186
 
99
- ret = yield stmt, result
100
- result.free if result
101
- stmt.close unless cache_stmt
102
- ret
187
+ ret = yield stmt, result
188
+ result.free if result
189
+ stmt.close unless cache_stmt
190
+ ret
191
+ end
103
192
  end
104
- end
105
193
  end
106
194
  end
107
195
  end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module ActiveRecord
2
4
  module ConnectionAdapters
3
5
  module MySQL
@@ -35,35 +37,34 @@ module ActiveRecord
35
37
  end
36
38
 
37
39
  private
38
-
39
- def compute_column_widths(result)
40
- [].tap do |widths|
41
- result.columns.each_with_index do |column, i|
42
- cells_in_column = [column] + result.rows.map {|r| r[i].nil? ? 'NULL' : r[i].to_s}
43
- widths << cells_in_column.map(&:length).max
40
+ def compute_column_widths(result)
41
+ [].tap do |widths|
42
+ result.columns.each_with_index do |column, i|
43
+ cells_in_column = [column] + result.rows.map { |r| r[i].nil? ? "NULL" : r[i].to_s }
44
+ widths << cells_in_column.map(&:length).max
45
+ end
44
46
  end
45
47
  end
46
- end
47
48
 
48
- def build_separator(widths)
49
- padding = 1
50
- '+' + widths.map {|w| '-' * (w + (padding*2))}.join('+') + '+'
51
- end
49
+ def build_separator(widths)
50
+ padding = 1
51
+ "+" + widths.map { |w| "-" * (w + (padding * 2)) }.join("+") + "+"
52
+ end
52
53
 
53
- def build_cells(items, widths)
54
- cells = []
55
- items.each_with_index do |item, i|
56
- item = 'NULL' if item.nil?
57
- justifier = item.is_a?(Numeric) ? 'rjust' : 'ljust'
58
- cells << item.to_s.send(justifier, widths[i])
54
+ def build_cells(items, widths)
55
+ cells = []
56
+ items.each_with_index do |item, i|
57
+ item = "NULL" if item.nil?
58
+ justifier = item.is_a?(Numeric) ? "rjust" : "ljust"
59
+ cells << item.to_s.send(justifier, widths[i])
60
+ end
61
+ "| " + cells.join(" | ") + " |"
59
62
  end
60
- '| ' + cells.join(' | ') + ' |'
61
- end
62
63
 
63
- def build_footer(nrows, elapsed)
64
- rows_label = nrows == 1 ? 'row' : 'rows'
65
- "#{nrows} #{rows_label} in set (%.2f sec)" % elapsed
66
- end
64
+ def build_footer(nrows, elapsed)
65
+ rows_label = nrows == 1 ? "row" : "rows"
66
+ "#{nrows} #{rows_label} in set (%.2f sec)" % elapsed
67
+ end
67
68
  end
68
69
  end
69
70
  end
@@ -1,29 +1,21 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module ActiveRecord
2
4
  module ConnectionAdapters
3
5
  module MySQL
4
6
  module Quoting # :nodoc:
5
- QUOTED_TRUE, QUOTED_FALSE = '1'.freeze, '0'.freeze
6
-
7
7
  def quote_column_name(name)
8
- @quoted_column_names[name] ||= "`#{super.gsub('`', '``')}`"
8
+ self.class.quoted_column_names[name] ||= "`#{super.gsub('`', '``')}`"
9
9
  end
10
10
 
11
11
  def quote_table_name(name)
12
- @quoted_table_names[name] ||= super.gsub('.', '`.`')
13
- end
14
-
15
- def quoted_true
16
- QUOTED_TRUE
12
+ self.class.quoted_table_names[name] ||= super.gsub(".", "`.`").freeze
17
13
  end
18
14
 
19
15
  def unquoted_true
20
16
  1
21
17
  end
22
18
 
23
- def quoted_false
24
- QUOTED_FALSE
25
- end
26
-
27
19
  def unquoted_false
28
20
  0
29
21
  end
@@ -32,19 +24,57 @@ module ActiveRecord
32
24
  if supports_datetime_with_precision?
33
25
  super
34
26
  else
35
- super.sub(/\.\d{6}\z/, '')
27
+ super.sub(/\.\d{6}\z/, "")
36
28
  end
37
29
  end
38
30
 
39
- private
31
+ def quoted_binary(value)
32
+ "x'#{value.hex}'"
33
+ end
40
34
 
41
- def _quote(value)
42
- if value.is_a?(Type::Binary::Data)
43
- "x'#{value.hex}'"
44
- else
45
- super
46
- end
35
+ def column_name_matcher
36
+ COLUMN_NAME
37
+ end
38
+
39
+ def column_name_with_order_matcher
40
+ COLUMN_NAME_WITH_ORDER
47
41
  end
42
+
43
+ COLUMN_NAME = /
44
+ \A
45
+ (
46
+ (?:
47
+ # `table_name`.`column_name` | function(one or no argument)
48
+ ((?:\w+\.|`\w+`\.)?(?:\w+|`\w+`)) | \w+\((?:|\g<2>)\)
49
+ )
50
+ (?:\s+AS\s+(?:\w+|`\w+`))?
51
+ )
52
+ (?:\s*,\s*\g<1>)*
53
+ \z
54
+ /ix
55
+
56
+ COLUMN_NAME_WITH_ORDER = /
57
+ \A
58
+ (
59
+ (?:
60
+ # `table_name`.`column_name` | function(one or no argument)
61
+ ((?:\w+\.|`\w+`\.)?(?:\w+|`\w+`)) | \w+\((?:|\g<2>)\)
62
+ )
63
+ (?:\s+ASC|\s+DESC)?
64
+ )
65
+ (?:\s*,\s*\g<1>)*
66
+ \z
67
+ /ix
68
+
69
+ private_constant :COLUMN_NAME, :COLUMN_NAME_WITH_ORDER
70
+
71
+ private
72
+ def _type_cast(value)
73
+ case value
74
+ when Date, Time then value
75
+ else super
76
+ end
77
+ end
48
78
  end
49
79
  end
50
80
  end
@@ -1,66 +1,70 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module ActiveRecord
2
4
  module ConnectionAdapters
3
5
  module MySQL
4
- class SchemaCreation < AbstractAdapter::SchemaCreation
5
- delegate :add_sql_comment!, to: :@conn
6
- private :add_sql_comment!
6
+ class SchemaCreation < AbstractAdapter::SchemaCreation # :nodoc:
7
+ delegate :add_sql_comment!, :mariadb?, to: :@conn, private: true
7
8
 
8
9
  private
10
+ def visit_DropForeignKey(name)
11
+ "DROP FOREIGN KEY #{name}"
12
+ end
9
13
 
10
- def visit_DropForeignKey(name)
11
- "DROP FOREIGN KEY #{name}"
12
- end
14
+ def visit_AddColumnDefinition(o)
15
+ add_column_position!(super, column_options(o.column))
16
+ end
13
17
 
14
- def visit_ColumnDefinition(o)
15
- o.sql_type = type_to_sql(o.type, o.limit, o.precision, o.scale, o.unsigned)
16
- super
17
- end
18
+ def visit_ChangeColumnDefinition(o)
19
+ change_column_sql = +"CHANGE #{quote_column_name(o.name)} #{accept(o.column)}"
20
+ add_column_position!(change_column_sql, column_options(o.column))
21
+ end
18
22
 
19
- def visit_AddColumnDefinition(o)
20
- add_column_position!(super, column_options(o.column))
21
- end
23
+ def add_table_options!(create_sql, options)
24
+ add_sql_comment!(super, options[:comment])
25
+ end
22
26
 
23
- def visit_ChangeColumnDefinition(o)
24
- change_column_sql = "CHANGE #{quote_column_name(o.name)} #{accept(o.column)}"
25
- add_column_position!(change_column_sql, column_options(o.column))
26
- end
27
+ def add_column_options!(sql, options)
28
+ # By default, TIMESTAMP columns are NOT NULL, cannot contain NULL values,
29
+ # and assigning NULL assigns the current timestamp. To permit a TIMESTAMP
30
+ # column to contain NULL, explicitly declare it with the NULL attribute.
31
+ # See https://dev.mysql.com/doc/refman/5.7/en/timestamp-initialization.html
32
+ if /\Atimestamp\b/.match?(options[:column].sql_type) && !options[:primary_key]
33
+ sql << " NULL" unless options[:null] == false || options_include_default?(options)
34
+ end
27
35
 
28
- def add_table_options!(create_sql, options)
29
- add_sql_comment!(super, options[:comment])
30
- end
36
+ if charset = options[:charset]
37
+ sql << " CHARACTER SET #{charset}"
38
+ end
31
39
 
32
- def column_options(o)
33
- column_options = super
34
- column_options[:charset] = o.charset
35
- column_options
36
- end
40
+ if collation = options[:collation]
41
+ sql << " COLLATE #{collation}"
42
+ end
37
43
 
38
- def add_column_options!(sql, options)
39
- if charset = options[:charset]
40
- sql << " CHARACTER SET #{charset}"
41
- end
44
+ if as = options[:as]
45
+ sql << " AS (#{as})"
46
+ if options[:stored]
47
+ sql << (mariadb? ? " PERSISTENT" : " STORED")
48
+ end
49
+ end
42
50
 
43
- if collation = options[:collation]
44
- sql << " COLLATE #{collation}"
51
+ add_sql_comment!(super, options[:comment])
45
52
  end
46
53
 
47
- add_sql_comment!(super, options[:comment])
48
- end
54
+ def add_column_position!(sql, options)
55
+ if options[:first]
56
+ sql << " FIRST"
57
+ elsif options[:after]
58
+ sql << " AFTER #{quote_column_name(options[:after])}"
59
+ end
49
60
 
50
- def add_column_position!(sql, options)
51
- if options[:first]
52
- sql << " FIRST"
53
- elsif options[:after]
54
- sql << " AFTER #{quote_column_name(options[:after])}"
61
+ sql
55
62
  end
56
63
 
57
- sql
58
- end
59
-
60
- def index_in_create(table_name, column_name, options)
61
- index_name, index_type, index_columns, _, _, index_using, comment = @conn.add_index_options(table_name, column_name, options)
62
- add_sql_comment!("#{index_type} INDEX #{quote_column_name(index_name)} #{index_using} (#{index_columns})", comment)
63
- end
64
+ def index_in_create(table_name, column_name, options)
65
+ index_name, index_type, index_columns, _, _, index_using, comment = @conn.add_index_options(table_name, column_name, **options)
66
+ add_sql_comment!((+"#{index_type} INDEX #{quote_column_name(index_name)} #{index_using} (#{index_columns})"), comment)
67
+ end
64
68
  end
65
69
  end
66
70
  end
@@ -1,88 +1,90 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module ActiveRecord
2
4
  module ConnectionAdapters
3
5
  module MySQL
4
6
  module ColumnMethods
5
- def primary_key(name, type = :primary_key, **options)
6
- options[:auto_increment] = true if type == :bigint && !options.key?(:default)
7
- super
8
- end
7
+ extend ActiveSupport::Concern
9
8
 
10
- def blob(*args, **options)
11
- args.each { |name| column(name, :blob, options) }
12
- end
9
+ ##
10
+ # :method: blob
11
+ # :call-seq: blob(*names, **options)
13
12
 
14
- def tinyblob(*args, **options)
15
- args.each { |name| column(name, :tinyblob, options) }
16
- end
13
+ ##
14
+ # :method: tinyblob
15
+ # :call-seq: tinyblob(*names, **options)
17
16
 
18
- def mediumblob(*args, **options)
19
- args.each { |name| column(name, :mediumblob, options) }
20
- end
17
+ ##
18
+ # :method: mediumblob
19
+ # :call-seq: mediumblob(*names, **options)
21
20
 
22
- def longblob(*args, **options)
23
- args.each { |name| column(name, :longblob, options) }
24
- end
21
+ ##
22
+ # :method: longblob
23
+ # :call-seq: longblob(*names, **options)
25
24
 
26
- def tinytext(*args, **options)
27
- args.each { |name| column(name, :tinytext, options) }
28
- end
25
+ ##
26
+ # :method: tinytext
27
+ # :call-seq: tinytext(*names, **options)
29
28
 
30
- def mediumtext(*args, **options)
31
- args.each { |name| column(name, :mediumtext, options) }
32
- end
29
+ ##
30
+ # :method: mediumtext
31
+ # :call-seq: mediumtext(*names, **options)
33
32
 
34
- def longtext(*args, **options)
35
- args.each { |name| column(name, :longtext, options) }
36
- end
33
+ ##
34
+ # :method: longtext
35
+ # :call-seq: longtext(*names, **options)
37
36
 
38
- def json(*args, **options)
39
- args.each { |name| column(name, :json, options) }
40
- end
37
+ ##
38
+ # :method: unsigned_integer
39
+ # :call-seq: unsigned_integer(*names, **options)
41
40
 
42
- def unsigned_integer(*args, **options)
43
- args.each { |name| column(name, :unsigned_integer, options) }
44
- end
41
+ ##
42
+ # :method: unsigned_bigint
43
+ # :call-seq: unsigned_bigint(*names, **options)
45
44
 
46
- def unsigned_bigint(*args, **options)
47
- args.each { |name| column(name, :unsigned_bigint, options) }
48
- end
45
+ ##
46
+ # :method: unsigned_float
47
+ # :call-seq: unsigned_float(*names, **options)
49
48
 
50
- def unsigned_float(*args, **options)
51
- args.each { |name| column(name, :unsigned_float, options) }
52
- end
49
+ ##
50
+ # :method: unsigned_decimal
51
+ # :call-seq: unsigned_decimal(*names, **options)
53
52
 
54
- def unsigned_decimal(*args, **options)
55
- args.each { |name| column(name, :unsigned_decimal, options) }
53
+ included do
54
+ define_column_methods :blob, :tinyblob, :mediumblob, :longblob,
55
+ :tinytext, :mediumtext, :longtext, :unsigned_integer, :unsigned_bigint,
56
+ :unsigned_float, :unsigned_decimal
56
57
  end
57
58
  end
58
59
 
59
- class ColumnDefinition < ActiveRecord::ConnectionAdapters::ColumnDefinition
60
- attr_accessor :charset, :unsigned
61
- end
62
-
63
60
  class TableDefinition < ActiveRecord::ConnectionAdapters::TableDefinition
64
61
  include ColumnMethods
65
62
 
66
- def new_column_definition(name, type, options) # :nodoc:
67
- column = super
68
- case column.type
63
+ def new_column_definition(name, type, **options) # :nodoc:
64
+ case type
65
+ when :virtual
66
+ type = options[:type]
69
67
  when :primary_key
70
- column.type = :integer
71
- column.auto_increment = true
68
+ type = :integer
69
+ options[:limit] ||= 8
70
+ options[:primary_key] = true
72
71
  when /\Aunsigned_(?<type>.+)\z/
73
- column.type = $~[:type].to_sym
74
- column.unsigned = true
72
+ type = $~[:type].to_sym
73
+ options[:unsigned] = true
75
74
  end
76
- column.unsigned ||= options[:unsigned]
77
- column.charset = options[:charset]
78
- column
75
+
76
+ super
79
77
  end
80
78
 
81
79
  private
80
+ def aliased_types(name, fallback)
81
+ fallback
82
+ end
82
83
 
83
- def create_column_definition(name, type)
84
- MySQL::ColumnDefinition.new(name, type)
85
- end
84
+ def integer_like_primary_key_type(type, options)
85
+ options[:auto_increment] = true
86
+ type
87
+ end
86
88
  end
87
89
 
88
90
  class Table < ActiveRecord::ConnectionAdapters::Table