-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathalter_existing_field.install
More file actions
60 lines (53 loc) · 1.9 KB
/
alter_existing_field.install
File metadata and controls
60 lines (53 loc) · 1.9 KB
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
<?php
/**
* @file
* Installation and update functions for alter_existing_field module.
* Example of how to alter an existing field that already has data stored in the DB.
*/
/**
* Updates field_my_number field to allow 8 characters.
*/
function alter_existing_field_update_7000() {
$items = array();
$maxlength = 8;
_field_maxlength_fix('field_my_number', $maxlength);
return $items;
}
/**
* Updates maxlength of field_name.
*/
function _field_maxlength_fix($field_name, $maxlength) {
_alter_field_table($field_name, $maxlength);
$data = _get_field_data($field_name);
$data = _fix_field_data($data, $maxlength);
_update_field_config($data, $field_name);
}
/**
* Updates maxlength of field_data_field_name table.
*/
function _alter_field_table($field_name, $maxlength) {
db_query("ALTER TABLE field_data_" . $field_name . " CHANGE " . $field_name . "_value " . $field_name . "_value VARCHAR( " . $maxlength . " ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL");
db_query("ALTER TABLE field_revision_" . $field_name . " CHANGE " . $field_name . "_value " . $field_name . "_value VARCHAR( " . $maxlength . " ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL");
}
/**
* Retrieves field data from field_config table.
*/
function _get_field_data($field_name) {
$qry = "SELECT data FROM field_config WHERE field_name = :field_name";
$result = db_query($qry, array(':field_name' => $field_name))->fetchObject();
return unserialize($result->data);
}
/**
* Updates maxlength of field_data.
*/
function _fix_field_data($data, $maxlength) {
$data['settings']['max_length'] = (string) $maxlength;
return serialize($data);
}
/**
* Updates field_config for a field.
*/
function _update_field_config($data, $field_name) {
$qry = "UPDATE field_config SET data = :data WHERE field_name = :field_name";
db_query($qry, array(':data' => $data, ':field_name' => $field_name));
}