-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathMySQL.cfc
102 lines (82 loc) · 4.34 KB
/
MySQL.cfc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
component extends="types.Driver" output="no" implements="types.IDatasource" {
fields=array(
field("Use Unicode","useUnicode","true,false",false,
"Should the driver use Unicode character encodings when handling strings? Should only be used when the driver can't determine the character set mapping, or you are trying to 'force' the driver to use a character set that MySQL either doesn't natively support (such as UTF-8)"
,"radio"),
field("Charset","characterEncoding","UTF-8",false,
"If 'Use Unicode' is set to true, what character encoding should the driver use when dealing with strings?"),
field("Alias Handling","useOldAliasMetadataBehavior","true,false",false,
"Should the driver use the legacy behavior for ""AS"" clauses on columns and tables,
and only return aliases (if any) rather than the original column/table name? In 5.0.x, the default value was true."
,"radio"),
field('Allow multiple Queries','allowMultiQueries','true,false',false,
'Allow the use of ";" to delimit multiple queries during one statement'
,"radio"),
field('Zero DateTime behavior','zeroDateTimeBehavior','EXCEPTION,ROUND,CONVERT_TO_NULL',false,
'What should happen when the driver encounters DATETIME values that are composed entirely of zeroes (used by MySQL to represent invalid dates)? Valid values are "exception", "round" and "convert_to_null"'
,"radio"),
field('SSL','useSSL','true,false',false,
'Use SSL for connectiong the database.'
,"radio"),
field('Verify Server Certificate','verifyServerCertificate','true,false',false,
'When SSL is enable verify the server certificate.'
,"radio"),
field('Throw error upon data truncation','jdbcCompliantTruncation','true,false',false,
'If set to false then values for table fields are automatically truncated so that they fit into the field.'
,"radio"),
field('TinyInt(1) is bit','tinyInt1isBit','true,false',false,'this defines the data type returned for tinyInt(1), if set to "true" (default) tinyInt(1) is converted to a bit value otherwise as integer.'
,"radio"),
field('Legacy Datetime Code','useLegacyDatetimeCode','true,false',false,
'Use code for DATE/TIME/DATETIME/TIMESTAMP handling in result sets and statements that consistently handles timezone conversions from client to server and back again, or use the legacy code for these datatypes that has been in the driver for backwards-compatibility?'
,"radio"),
field('Auto Reconnect','autoReconnect','true,false',false,
'Should the driver try to re-establish stale and/or dead connections? If enabled the driver will throw an exception for a queries issued on a stale or dead connection, which belong to the current transaction, but will attempt reconnect before the next query issued on the connection in a new transaction. The use of this feature is not recommended, because it has side effects related to session state and data consistency when applications don''t handle SQLExceptions properly, and is only designed to be used when you are unable to configure your application to handle SQLExceptions resulting from dead and stale connections properly. Alternatively, as a last option, investigate setting the MySQL server variable "wait_timeout" to a high value, rather than the default of 8 hours.'
,"radio",2),
field('Max Reconnects','maxReconnects','3,5,8,12,15',3,
'Maximum number of reconnects to attempt if autoReconnect is true.'
,"radio")
);
this.type.port=this.TYPE_FREE;
this.value.host="localhost";
this.value.port=3306;
this.className="{class-name}";
this.bundleName="{bundle-name}";
this.dsn="{connString}";
public void function onBeforeUpdate() {
custom_useUnicode=true;
// Timezone
if(!isNull(form.timezone) && !isEmpty(form.timezone)) local.tz=form.timezone;
else local.tz=toString(getTimezone());
form['custom_serverTimezone']=tz;
}
/**
* returns display name of the driver
*/
public string function getName() {
return "{label}";
}
/**
* returns the id of the driver
*/
public string function getId() {
return "{id}";
}
/**
* returns the description of the driver
*/
public string function getDescription() {
return {description};
}
/**
* returns array of fields
*/
public array function getFields() {
return fields;
}
public boolean function literalTimestampWithTSOffset() {
return false;
}
public boolean function alwaysSetTimeout() {
return true;
}
}