composite_primary_keys 12.0.8 → 13.0.1

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 (58) hide show
  1. checksums.yaml +4 -4
  2. data/History.rdoc +888 -874
  3. data/README.rdoc +181 -180
  4. data/lib/composite_primary_keys/active_model/attribute_assignment.rb +19 -19
  5. data/lib/composite_primary_keys/associations/association_scope.rb +66 -68
  6. data/lib/composite_primary_keys/associations/join_dependency.rb +137 -103
  7. data/lib/composite_primary_keys/attribute_methods/primary_key.rb +0 -2
  8. data/lib/composite_primary_keys/attribute_methods/read.rb +30 -30
  9. data/lib/composite_primary_keys/attribute_methods/write.rb +35 -35
  10. data/lib/composite_primary_keys/attribute_methods.rb +21 -9
  11. data/lib/composite_primary_keys/base.rb +141 -141
  12. data/lib/composite_primary_keys/composite_predicates.rb +2 -1
  13. data/lib/composite_primary_keys/connection_adapters/abstract/database_statements.rb +37 -22
  14. data/lib/composite_primary_keys/connection_adapters/sqlserver/database_statements.rb +44 -44
  15. data/lib/composite_primary_keys/core.rb +48 -48
  16. data/lib/composite_primary_keys/nested_attributes.rb +1 -1
  17. data/lib/composite_primary_keys/persistence.rb +82 -81
  18. data/lib/composite_primary_keys/reflection.rb +91 -29
  19. data/lib/composite_primary_keys/relation/batches.rb +15 -7
  20. data/lib/composite_primary_keys/relation/calculations.rb +104 -81
  21. data/lib/composite_primary_keys/relation/finder_methods.rb +235 -235
  22. data/lib/composite_primary_keys/relation/predicate_builder/association_query_value.rb +39 -20
  23. data/lib/composite_primary_keys/relation/query_methods.rb +42 -42
  24. data/lib/composite_primary_keys/relation/where_clause.rb +18 -23
  25. data/lib/composite_primary_keys/relation.rb +197 -193
  26. data/lib/composite_primary_keys/table_metadata.rb +11 -0
  27. data/lib/composite_primary_keys/version.rb +8 -8
  28. data/lib/composite_primary_keys.rb +119 -119
  29. data/test/abstract_unit.rb +114 -114
  30. data/test/connections/databases.ci.yml +22 -22
  31. data/test/fixtures/db_definitions/db2-create-tables.sql +112 -112
  32. data/test/fixtures/db_definitions/db2-drop-tables.sql +16 -16
  33. data/test/fixtures/db_definitions/mysql.sql +180 -180
  34. data/test/fixtures/db_definitions/oracle.drop.sql +41 -41
  35. data/test/fixtures/db_definitions/oracle.sql +199 -199
  36. data/test/fixtures/db_definitions/postgresql.sql +182 -182
  37. data/test/fixtures/db_definitions/sqlite.sql +169 -169
  38. data/test/fixtures/db_definitions/sqlserver.sql +176 -176
  39. data/test/fixtures/department.rb +16 -16
  40. data/test/fixtures/departments.yml +19 -15
  41. data/test/fixtures/employees.yml +33 -28
  42. data/test/fixtures/membership.rb +8 -6
  43. data/test/fixtures/restaurants_suburbs.yml +10 -10
  44. data/test/fixtures/streets.yml +16 -16
  45. data/test/fixtures/suburbs.yml +14 -14
  46. data/test/fixtures/user.rb +11 -11
  47. data/test/test_associations.rb +372 -358
  48. data/test/test_attributes.rb +75 -60
  49. data/test/test_calculations.rb +49 -42
  50. data/test/test_create.rb +218 -206
  51. data/test/test_delete.rb +188 -179
  52. data/test/test_exists.rb +39 -39
  53. data/test/test_find.rb +170 -164
  54. data/test/test_ids.rb +112 -112
  55. data/test/test_nested_attributes.rb +67 -67
  56. data/test/test_update.rb +102 -96
  57. metadata +6 -6
  58. data/lib/composite_primary_keys/connection_adapters/mysql/database_statements.rb +0 -24
@@ -1,183 +1,183 @@
1
- create table reference_types (
2
- reference_type_id serial not null,
3
- type_label varchar(50) default null,
4
- abbreviation varchar(50) default null,
5
- description varchar(50) default null,
6
- primary key (reference_type_id)
7
- );
8
-
9
- create table reference_codes (
10
- reference_type_id int,
11
- reference_code int not null,
12
- code_label varchar(50) default null,
13
- abbreviation varchar(50) default null,
14
- description varchar(50) default null,
15
- primary key (reference_type_id, reference_code)
16
- );
17
-
18
- create table products (
19
- id serial not null,
20
- name varchar(50) default null,
21
- primary key (id),
22
- created_at timestamp without time zone NOT NULL,
23
- updated_at timestamp without time zone NOT NULL
24
- );
25
-
26
- create table tariffs (
27
- tariff_id int not null,
28
- start_date date not null,
29
- amount int default null,
30
- created_at timestamp without time zone NOT NULL,
31
- updated_at timestamp without time zone NOT NULL,
32
- primary key (tariff_id, start_date)
33
- );
34
-
35
- create table product_tariffs (
36
- product_id int not null,
37
- tariff_id int not null,
38
- tariff_start_date date not null,
39
- primary key (product_id, tariff_id, tariff_start_date)
40
- );
41
-
42
- create table suburbs (
43
- city_id serial not null,
44
- suburb_id serial not null,
45
- name varchar(50) not null,
46
- primary key (city_id, suburb_id)
47
- );
48
-
49
- create table streets (
50
- id serial not null,
51
- city_id int not null,
52
- suburb_id int not null,
53
- name varchar(50) not null,
54
- primary key (id)
55
- );
56
-
57
- create table users (
58
- id serial not null,
59
- name varchar(50) not null,
60
- primary key (id)
61
- );
62
-
63
- create table articles (
64
- id serial not null,
65
- name varchar(50) not null,
66
- primary key (id)
67
- );
68
-
69
- create table readings (
70
- id serial not null,
71
- user_id int not null,
72
- article_id int not null,
73
- rating int not null,
74
- primary key (id)
75
- );
76
-
77
- create table groups (
78
- id serial not null,
79
- name varchar(50) not null,
80
- primary key (id)
81
- );
82
-
83
- create table memberships (
84
- user_id int not null,
85
- group_id int not null,
86
- primary key (user_id, group_id)
87
- );
88
-
89
- create table membership_statuses (
90
- id serial not null,
91
- user_id int not null,
92
- group_id int not null,
93
- status varchar(50) not null,
94
- primary key (id)
95
- );
96
-
97
- create table departments (
98
- id serial not null,
99
- location_id int not null,
100
- primary key (id, location_id)
101
- );
102
-
103
- create table employees (
104
- id serial not null,
105
- department_id int default null,
106
- location_id int default null,
107
- name text not null,
108
- primary key (id)
109
- );
110
-
111
- create table comments (
112
- id serial not null,
113
- article_id int not null references articles (id),
114
- person_id int not null,
115
- person_type varchar(100) not null,
116
- primary key (id)
117
- );
118
-
119
- create table restaurants (
120
- franchise_id int not null,
121
- store_id int not null,
122
- name varchar(100),
123
- lock_version int default 0,
124
- primary key (franchise_id, store_id)
125
- );
126
-
127
- create table restaurants_suburbs (
128
- franchise_id int not null,
129
- store_id int not null,
130
- city_id int not null,
131
- suburb_id int not null
132
- );
133
-
134
- create table dorms (
135
- id serial not null,
136
- primary key (id)
137
- );
138
-
139
- create table rooms (
140
- dorm_id int not null,
141
- room_id int not null,
142
- primary key (dorm_id, room_id)
143
- );
144
-
145
- create table room_attributes (
146
- id serial not null,
147
- name varchar(50),
148
- primary key (id)
149
- );
150
-
151
- create table room_attribute_assignments (
152
- dorm_id int not null,
153
- room_id int not null,
154
- room_attribute_id int not null
155
- );
156
-
157
- create table students (
158
- id serial not null,
159
- primary key (id)
160
- );
161
-
162
- create table room_assignments (
163
- student_id int not null,
164
- dorm_id int not null,
165
- room_id int not null
166
- );
167
-
168
- create table capitols (
169
- country text not null,
170
- city text not null,
171
- primary key (country, city)
172
- );
173
-
174
- create table products_restaurants (
175
- product_id int not null,
176
- franchise_id int not null,
177
- store_id int not null
178
- );
179
-
180
- create table employees_groups (
181
- employee_id int not null,
182
- group_id int not null
1
+ create table reference_types (
2
+ reference_type_id serial not null,
3
+ type_label varchar(50) default null,
4
+ abbreviation varchar(50) default null,
5
+ description varchar(50) default null,
6
+ primary key (reference_type_id)
7
+ );
8
+
9
+ create table reference_codes (
10
+ reference_type_id int,
11
+ reference_code int not null,
12
+ code_label varchar(50) default null,
13
+ abbreviation varchar(50) default null,
14
+ description varchar(50) default null,
15
+ primary key (reference_type_id, reference_code)
16
+ );
17
+
18
+ create table products (
19
+ id serial not null,
20
+ name varchar(50) default null,
21
+ primary key (id),
22
+ created_at timestamp without time zone NOT NULL,
23
+ updated_at timestamp without time zone NOT NULL
24
+ );
25
+
26
+ create table tariffs (
27
+ tariff_id int not null,
28
+ start_date date not null,
29
+ amount int default null,
30
+ created_at timestamp without time zone NOT NULL,
31
+ updated_at timestamp without time zone NOT NULL,
32
+ primary key (tariff_id, start_date)
33
+ );
34
+
35
+ create table product_tariffs (
36
+ product_id int not null,
37
+ tariff_id int not null,
38
+ tariff_start_date date not null,
39
+ primary key (product_id, tariff_id, tariff_start_date)
40
+ );
41
+
42
+ create table suburbs (
43
+ city_id serial not null,
44
+ suburb_id serial not null,
45
+ name varchar(50) not null,
46
+ primary key (city_id, suburb_id)
47
+ );
48
+
49
+ create table streets (
50
+ id serial not null,
51
+ city_id int not null,
52
+ suburb_id int not null,
53
+ name varchar(50) not null,
54
+ primary key (id)
55
+ );
56
+
57
+ create table users (
58
+ id serial not null,
59
+ name varchar(50) not null,
60
+ primary key (id)
61
+ );
62
+
63
+ create table articles (
64
+ id serial not null,
65
+ name varchar(50) not null,
66
+ primary key (id)
67
+ );
68
+
69
+ create table readings (
70
+ id serial not null,
71
+ user_id int not null,
72
+ article_id int not null,
73
+ rating int not null,
74
+ primary key (id)
75
+ );
76
+
77
+ create table groups (
78
+ id serial not null,
79
+ name varchar(50) not null,
80
+ primary key (id)
81
+ );
82
+
83
+ create table memberships (
84
+ user_id int not null,
85
+ group_id int not null,
86
+ primary key (user_id, group_id)
87
+ );
88
+
89
+ create table membership_statuses (
90
+ id serial not null,
91
+ user_id int not null,
92
+ group_id int not null,
93
+ status varchar(50) not null,
94
+ primary key (id)
95
+ );
96
+
97
+ create table departments (
98
+ id serial not null,
99
+ location_id int not null,
100
+ primary key (id, location_id)
101
+ );
102
+
103
+ create table employees (
104
+ id serial not null,
105
+ department_id int default null,
106
+ location_id int default null,
107
+ name text not null,
108
+ primary key (id)
109
+ );
110
+
111
+ create table comments (
112
+ id serial not null,
113
+ article_id int not null references articles (id),
114
+ person_id int not null,
115
+ person_type varchar(100) not null,
116
+ primary key (id)
117
+ );
118
+
119
+ create table restaurants (
120
+ franchise_id int not null,
121
+ store_id int not null,
122
+ name varchar(100),
123
+ lock_version int default 0,
124
+ primary key (franchise_id, store_id)
125
+ );
126
+
127
+ create table restaurants_suburbs (
128
+ franchise_id int not null,
129
+ store_id int not null,
130
+ city_id int not null,
131
+ suburb_id int not null
132
+ );
133
+
134
+ create table dorms (
135
+ id serial not null,
136
+ primary key (id)
137
+ );
138
+
139
+ create table rooms (
140
+ dorm_id int not null,
141
+ room_id int not null,
142
+ primary key (dorm_id, room_id)
143
+ );
144
+
145
+ create table room_attributes (
146
+ id serial not null,
147
+ name varchar(50),
148
+ primary key (id)
149
+ );
150
+
151
+ create table room_attribute_assignments (
152
+ dorm_id int not null,
153
+ room_id int not null,
154
+ room_attribute_id int not null
155
+ );
156
+
157
+ create table students (
158
+ id serial not null,
159
+ primary key (id)
160
+ );
161
+
162
+ create table room_assignments (
163
+ student_id int not null,
164
+ dorm_id int not null,
165
+ room_id int not null
166
+ );
167
+
168
+ create table capitols (
169
+ country text not null,
170
+ city text not null,
171
+ primary key (country, city)
172
+ );
173
+
174
+ create table products_restaurants (
175
+ product_id int not null,
176
+ franchise_id int not null,
177
+ store_id int not null
178
+ );
179
+
180
+ create table employees_groups (
181
+ employee_id int not null,
182
+ group_id int not null
183
183
  );