1Rose::DB::MySQL(3) User Contributed Perl Documentation Rose::DB::MySQL(3)
2
3
4
6 Rose::DB::MySQL - MySQL driver class for Rose::DB.
7
9 use Rose::DB;
10
11 Rose::DB->register_db(
12 domain => 'development',
13 type => 'main',
14 driver => 'mysql',
15 database => 'dev_db',
16 host => 'localhost',
17 username => 'devuser',
18 password => 'mysecret',
19 );
20
21
22 Rose::DB->default_domain('development');
23 Rose::DB->default_type('main');
24 ...
25
26 # Set max length of varchar columns used to emulate the array data type
27 Rose::DB::MySQL->max_array_characters(128);
28
29 $db = Rose::DB->new; # $db is really a Rose::DB::MySQL-derived object
30 ...
31
33 Rose::DB blesses objects into a class derived from Rose::DB::MySQL when
34 the driver is "mysql". This mapping of driver names to class names is
35 configurable. See the documentation for Rose::DB's new() and
36 driver_class() methods for more information.
37
38 This class cannot be used directly. You must use Rose::DB and let its
39 new() method return an object blessed into the appropriate class for
40 you, according to its driver_class() mappings.
41
42 Only the methods that are new or have different behaviors than those in
43 Rose::DB are documented here. See the Rose::DB documentation for the
44 full list of methods.
45
47 coerce_autoincrement_to_serial [BOOL]
48 Get or set a boolean value that indicates whether or not "auto-
49 increment" columns will be considered to have the column type
50 "serial." If true, "integer" columns are coerced to the "serial"
51 column type, and "bigint" columns use the "bigserial" column type.
52 The default value is true.
53
54 This setting comes into play when Rose::DB::Object::Loader is used
55 to auto-create column metadata based on an existing database
56 schema.
57
58 max_array_characters [INT]
59 Get or set the maximum length of varchar columns used to emulate
60 the array data type. The default value is 255.
61
62 MySQL does not have a native "ARRAY" data type, but this data type
63 can be emulated using a "VARCHAR" column and a specially formatted
64 string. The formatting and parsing of this string is handled by
65 the format_array and parse_array object methods. The maximum
66 length limit is honored by the format_array object method.
67
68 max_interval_characters [INT]
69 Get or set the maximum length of varchar columns used to emulate
70 the interval data type. The default value is 255.
71
72 MySQL does not have a native "interval" data type, but this data
73 type can be emulated using a "VARCHAR" column and a specially
74 formatted string. The formatting and parsing of this string is
75 handled by the format_interval and parse_interval object methods.
76 The maximum length limit is honored by the format_interval object
77 method.
78
80 mysql_auto_reconnect [BOOL]
81 Get or set the mysql_auto_reconnect database handle attribute.
82 This is set directly on the dbh, if one exists. Otherwise, it will
83 be set when the dbh is created. If no value for this attribute is
84 defined (the default) then it will not be set when the dbh is
85 created, deferring instead to whatever default value DBD::mysql
86 chooses.
87
88 Returns the value of this attribute in the dbh, if one exists, or
89 the value that will be set when the dbh is next created.
90
91 See the DBD::mysql documentation to learn more about this
92 attribute.
93
94 mysql_bind_type_guessing [BOOL]
95 Get or set the mysql_bind_type_guessing database handle attribute.
96 This is set directly on the dbh, if one exists. Otherwise, it will
97 be set when the dbh is created. If no value for this attribute is
98 defined (the default) then it will not be set when the dbh is
99 created, deferring instead to whatever default value DBD::mysql
100 chooses.
101
102 Returns the value of this attribute in the dbh, if one exists, or
103 the value that will be set when the dbh is next created.
104
105 See the DBD::mysql documentation to learn more about this
106 attribute.
107
108 mysql_client_found_rows [BOOL]
109 Get or set the mysql_client_found_rows database handle attribute.
110 This is set directly on the dbh, if one exists. Otherwise, it will
111 be set when the dbh is created. If no value for this attribute is
112 defined (the default) then it will not be set when the dbh is
113 created, deferring instead to whatever default value DBD::mysql
114 chooses.
115
116 Returns the value of this attribute in the dbh, if one exists, or
117 the value that will be set when the dbh is next created.
118
119 See the DBD::mysql documentation to learn more about this
120 attribute.
121
122 mysql_compression [BOOL]
123 Get or set the mysql_compression database handle attribute. This
124 is set directly on the dbh, if one exists. Otherwise, it will be
125 set when the dbh is created. If no value for this attribute is
126 defined (the default) then it will not be set when the dbh is
127 created, deferring instead to whatever default value DBD::mysql
128 chooses.
129
130 Returns the value of this attribute in the dbh, if one exists, or
131 the value that will be set when the dbh is next created.
132
133 See the DBD::mysql documentation to learn more about this
134 attribute.
135
136 mysql_connect_timeout [BOOL]
137 Get or set the mysql_connect_timeout database handle attribute.
138 This is set directly on the dbh, if one exists. Otherwise, it will
139 be set when the dbh is created. If no value for this attribute is
140 defined (the default) then it will not be set when the dbh is
141 created, deferring instead to whatever default value DBD::mysql
142 chooses.
143
144 Returns the value of this attribute in the dbh, if one exists, or
145 the value that will be set when the dbh is next created.
146
147 See the DBD::mysql documentation to learn more about this
148 attribute.
149
150 mysql_embedded_groups [STRING]
151 Get or set the mysql_embedded_groups database handle attribute.
152 This is set directly on the dbh, if one exists. Otherwise, it will
153 be set when the dbh is created. If no value for this attribute is
154 defined (the default) then it will not be set when the dbh is
155 created, deferring instead to whatever default value DBD::mysql
156 chooses.
157
158 Returns the value of this attribute in the dbh, if one exists, or
159 the value that will be set when the dbh is next created.
160
161 See the DBD::mysql documentation to learn more about this
162 attribute.
163
164 mysql_embedded_options [STRING]
165 Get or set the mysql_embedded_options database handle attribute.
166 This is set directly on the dbh, if one exists. Otherwise, it will
167 be set when the dbh is created. If no value for this attribute is
168 defined (the default) then it will not be set when the dbh is
169 created, deferring instead to whatever default value DBD::mysql
170 chooses.
171
172 Returns the value of this attribute in the dbh, if one exists, or
173 the value that will be set when the dbh is next created.
174
175 See the DBD::mysql documentation to learn more about this
176 attribute.
177
178 mysql_enable_utf8 [BOOL]
179 Get or set the mysql_enable_utf8 database handle attribute. This
180 is set directly on the dbh, if one exists, by executing the SQL
181 "SET NAMES utf8". Otherwise, it will be set when the dbh is
182 created. If no value for this attribute is defined (the default)
183 then it will not be set when the dbh is created, deferring instead
184 to whatever default value DBD::mysql chooses.
185
186 Returns the value of this attribute in the dbh, if one exists, or
187 the value that will be set when the dbh is next created.
188
189 See the DBD::mysql documentation to learn more about this
190 attribute.
191
192 mysql_enable_utf8mb4 [BOOL]
193 Get or set the mysql_enable_utf8mb4 database handle attribute.
194 This is set directly on the dbh, if one exists, by executing the
195 SQL "SET NAMES utf8mb4". Otherwise, it will be set when the dbh is
196 created. If no value for this attribute is defined (the default)
197 then it will not be set when the dbh is created, deferring instead
198 to whatever default value DBD::mysql chooses.
199
200 Returns the value of this attribute in the dbh, if one exists, or
201 the value that will be set when the dbh is next created.
202
203 See the DBD::mysql documentation to learn more about this
204 attribute.
205
206 mysql_local_infile [STRING]
207 Get or set the mysql_local_infile database handle attribute. This
208 is set directly on the dbh, if one exists. Otherwise, it will be
209 set when the dbh is created. If no value for this attribute is
210 defined (the default) then it will not be set when the dbh is
211 created, deferring instead to whatever default value DBD::mysql
212 chooses.
213
214 Returns the value of this attribute in the dbh, if one exists, or
215 the value that will be set when the dbh is next created.
216
217 See the DBD::mysql documentation to learn more about this
218 attribute.
219
220 mysql_multi_statements [BOOL]
221 Get or set the mysql_multi_statements database handle attribute.
222 This is set directly on the dbh, if one exists. Otherwise, it will
223 be set when the dbh is created. If no value for this attribute is
224 defined (the default) then it will not be set when the dbh is
225 created, deferring instead to whatever default value DBD::mysql
226 chooses.
227
228 Returns the value of this attribute in the dbh, if one exists, or
229 the value that will be set when the dbh is next created.
230
231 See the DBD::mysql documentation to learn more about this
232 attribute.
233
234 mysql_read_default_file [STRING]
235 Get or set the mysql_read_default_file database handle attribute.
236 This is set directly on the dbh, if one exists. Otherwise, it will
237 be set when the dbh is created. If no value for this attribute is
238 defined (the default) then it will not be set when the dbh is
239 created, deferring instead to whatever default value DBD::mysql
240 chooses.
241
242 Returns the value of this attribute in the dbh, if one exists, or
243 the value that will be set when the dbh is next created.
244
245 See the DBD::mysql documentation to learn more about this
246 attribute.
247
248 mysql_read_default_group [STRING]
249 Get or set the mysql_read_default_group database handle attribute.
250 This is set directly on the dbh, if one exists. Otherwise, it will
251 be set when the dbh is created. If no value for this attribute is
252 defined (the default) then it will not be set when the dbh is
253 created, deferring instead to whatever default value DBD::mysql
254 chooses.
255
256 Returns the value of this attribute in the dbh, if one exists, or
257 the value that will be set when the dbh is next created.
258
259 See the DBD::mysql documentation to learn more about this
260 attribute.
261
262 mysql_socket [STRING]
263 Get or set the mysql_socket database handle attribute. This is set
264 directly on the dbh, if one exists. Otherwise, it will be set when
265 the dbh is created. If no value for this attribute is defined (the
266 default) then it will not be set when the dbh is created, deferring
267 instead to whatever default value DBD::mysql chooses.
268
269 Returns the value of this attribute in the dbh, if one exists, or
270 the value that will be set when the dbh is next created.
271
272 See the DBD::mysql documentation to learn more about this
273 attribute.
274
275 mysql_ssl [BOOL]
276 Get or set the mysql_ssl database handle attribute. This is set
277 directly on the dbh, if one exists. Otherwise, it will be set when
278 the dbh is created. If no value for this attribute is defined (the
279 default) then it will not be set when the dbh is created, deferring
280 instead to whatever default value DBD::mysql chooses.
281
282 Returns the value of this attribute in the dbh, if one exists, or
283 the value that will be set when the dbh is next created.
284
285 See the DBD::mysql documentation to learn more about this
286 attribute.
287
288 mysql_ssl_ca_file [STRING]
289 Get or set the mysql_ssl_ca_file database handle attribute. This
290 is set directly on the dbh, if one exists. Otherwise, it will be
291 set when the dbh is created. If no value for this attribute is
292 defined (the default) then it will not be set when the dbh is
293 created, deferring instead to whatever default value DBD::mysql
294 chooses.
295
296 Returns the value of this attribute in the dbh, if one exists, or
297 the value that will be set when the dbh is next created.
298
299 See the DBD::mysql documentation to learn more about this
300 attribute.
301
302 mysql_ssl_ca_path [STRING]
303 Get or set the mysql_ssl_ca_path database handle attribute. This
304 is set directly on the dbh, if one exists. Otherwise, it will be
305 set when the dbh is created. If no value for this attribute is
306 defined (the default) then it will not be set when the dbh is
307 created, deferring instead to whatever default value DBD::mysql
308 chooses.
309
310 Returns the value of this attribute in the dbh, if one exists, or
311 the value that will be set when the dbh is next created.
312
313 See the DBD::mysql documentation to learn more about this
314 attribute.
315
316 mysql_ssl_cipher [STRING]
317 Get or set the mysql_ssl_cipher database handle attribute. This is
318 set directly on the dbh, if one exists. Otherwise, it will be set
319 when the dbh is created. If no value for this attribute is defined
320 (the default) then it will not be set when the dbh is created,
321 deferring instead to whatever default value DBD::mysql chooses.
322
323 Returns the value of this attribute in the dbh, if one exists, or
324 the value that will be set when the dbh is next created.
325
326 See the DBD::mysql documentation to learn more about this
327 attribute.
328
329 mysql_ssl_client_cert [STRING]
330 Get or set the mysql_ssl_client_cert database handle attribute.
331 This is set directly on the dbh, if one exists. Otherwise, it will
332 be set when the dbh is created. If no value for this attribute is
333 defined (the default) then it will not be set when the dbh is
334 created, deferring instead to whatever default value DBD::mysql
335 chooses.
336
337 Returns the value of this attribute in the dbh, if one exists, or
338 the value that will be set when the dbh is next created.
339
340 See the DBD::mysql documentation to learn more about this
341 attribute.
342
343 mysql_ssl_client_key [STRING]
344 Get or set the mysql_ssl_client_key database handle attribute.
345 This is set directly on the dbh, if one exists. Otherwise, it will
346 be set when the dbh is created. If no value for this attribute is
347 defined (the default) then it will not be set when the dbh is
348 created, deferring instead to whatever default value DBD::mysql
349 chooses.
350
351 Returns the value of this attribute in the dbh, if one exists, or
352 the value that will be set when the dbh is next created.
353
354 See the DBD::mysql documentation to learn more about this
355 attribute.
356
357 mysql_use_result [BOOL]
358 Get or set the mysql_use_result database handle attribute. This is
359 set directly on the dbh, if one exists. Otherwise, it will be set
360 when the dbh is created. If no value for this attribute is defined
361 (the default) then it will not be set when the dbh is created,
362 deferring instead to whatever default value DBD::mysql chooses.
363
364 Returns the value of this attribute in the dbh, if one exists, or
365 the value that will be set when the dbh is next created.
366
367 See the DBD::mysql documentation to learn more about this
368 attribute.
369
370 Value Parsing and Formatting
371 format_array ARRAYREF | LIST
372 Given a reference to an array or a list of values, return a
373 specially formatted string. Undef is returned if ARRAYREF points
374 to an empty array or if LIST is not passed. The array or list must
375 not contain undefined values.
376
377 If the resulting string is longer than max_array_characters, a
378 fatal error will occur.
379
380 format_interval DURATION
381 Given a DateTime::Duration object, return a string formatted
382 according to the rules of PostgreSQL's "INTERVAL" column type. If
383 DURATION is undefined, a DateTime::Duration object, a valid
384 interval keyword (according to validate_interval_keyword), or if it
385 looks like a function call (matches "/^\w+\(.*\)$/") and
386 keyword_function_calls is true, then it is returned unmodified.
387
388 If the resulting string is longer than max_interval_characters, a
389 fatal error will occur.
390
391 format_set ARRAYREF | LIST
392 Given a reference to an array or a list of values, return a string
393 formatted according to the rules of MySQL's "SET" data type. Undef
394 is returned if ARRAYREF points to an empty array or if LIST is not
395 passed. If the array or list contains undefined values, a fatal
396 error will occur.
397
398 parse_array STRING | LIST | ARRAYREF
399 Parse STRING and return a reference to an array. STRING should be
400 formatted according to the MySQL array data type emulation format
401 returned by format_array(). Undef is returned if STRING is
402 undefined.
403
404 If a LIST of more than one item is passed, a reference to an array
405 containing the values in LIST is returned.
406
407 If a an ARRAYREF is passed, it is returned as-is.
408
409 parse_interval STRING
410 Parse STRING and return a DateTime::Duration object. STRING should
411 be formatted according to the PostgreSQL native "interval" (years,
412 months, days, hours, minutes, seconds) data type.
413
414 If STRING is a DateTime::Duration object, a valid interval keyword
415 (according to validate_interval_keyword), or if it looks like a
416 function call (matches "/^\w+\(.*\)$/") and keyword_function_calls
417 is true, then it is returned unmodified. Otherwise, undef is
418 returned if STRING could not be parsed as a valid "interval" value.
419
420 parse_set STRING | LIST | ARRAYREF
421 Parse STRING and return a reference to an array. STRING should be
422 formatted according to MySQL's "SET" data type. Undef is returned
423 if STRING is undefined.
424
425 If a LIST of more than one item is passed, a reference to an array
426 containing the values in LIST is returned.
427
428 If a an ARRAYREF is passed, it is returned as-is.
429
430 validate_date_keyword STRING
431 Returns true if STRING is a valid keyword for the MySQL "date" data
432 type. Valid (case-insensitive) date keywords are:
433
434 curdate()
435 current_date
436 current_date()
437 now()
438 sysdate()
439 00000-00-00
440
441 Any string that looks like a function call (matches /^\w+\(.*\)$/)
442 is also considered a valid date keyword if keyword_function_calls
443 is true.
444
445 validate_datetime_keyword STRING
446 Returns true if STRING is a valid keyword for the MySQL "datetime"
447 data type, false otherwise. Valid (case-insensitive) datetime
448 keywords are:
449
450 curdate()
451 current_date
452 current_date()
453 current_time
454 current_time()
455 current_timestamp
456 current_timestamp()
457 curtime()
458 now()
459 sysdate()
460 0000-00-00 00:00:00
461
462 Any string that looks like a function call (matches /^\w+\(.*\)$/)
463 is also considered a valid datetime keyword if
464 keyword_function_calls is true.
465
466 validate_timestamp_keyword STRING
467 Returns true if STRING is a valid keyword for the MySQL "timestamp"
468 data type, false otherwise. Valid (case-insensitive) timestamp
469 keywords are:
470
471 curdate()
472 current_date
473 current_date()
474 current_time
475 current_time()
476 current_timestamp
477 current_timestamp()
478 curtime()
479 now()
480 sysdate()
481 0000-00-00 00:00:00
482 00000000000000
483
484 Any string that looks like a function call (matches /^\w+\(.*\)$/)
485 is also considered a valid timestamp keyword if
486 keyword_function_calls is true.
487
489 John C. Siracusa (siracusa@gmail.com)
490
492 Copyright (c) 2010 by John C. Siracusa. All rights reserved. This
493 program is free software; you can redistribute it and/or modify it
494 under the same terms as Perl itself.
495
496
497
498perl v5.34.0 2022-01-21 Rose::DB::MySQL(3)