91 if (!is_array($fields) || empty($fields)) {
93 'missing any fields', __FUNCTION__);
95 foreach ($fields as $field_name => $field) {
96 $query = $db->getDeclaration($field[
'type'], $field_name, $field);
102 return implode(
', ', $query_fields);
123 $seq_pattern =
'/^'.preg_replace(
'/%s/',
'([a-z0-9_]+)', $db->options[
'seqname_format']).
'$/i';
124 $seq_name = preg_replace($seq_pattern,
'\\1', $sqn);
125 if ($seq_name && !strcasecmp($sqn, $db->getSequenceName($seq_name))) {
151 $idx_pattern =
'/^'.preg_replace(
'/%s/',
'([a-z0-9_]+)', $db->options[
'idxname_format']).
'$/i';
152 $idx_name = preg_replace($idx_pattern,
'\\1', $idx);
153 if ($idx_name && !strcasecmp($idx, $db->getIndexName($idx_name))) {
177 'method not implemented', __FUNCTION__);
198 'method not implemented', __FUNCTION__);
221 'no valid table name specified', __FUNCTION__);
223 if (empty($fields)) {
225 'no fields specified for table "'.
$name.
'"', __FUNCTION__);
229 return $query_fields;
231 if (!empty($options[
'primary'])) {
232 $query_fields.=
', PRIMARY KEY ('.implode(
', ', array_keys($options[
'primary'])).
')';
237 if (!empty($options[
'temporary'])) {
240 $result .=
" TABLE $name ($query_fields)";
332 return $db->exec(
"DROP TABLE $name");
436 'method not implemented', __FUNCTION__);
456 'method not implementedd', __FUNCTION__);
476 'method not implemented', __FUNCTION__);
499 'method not implemented', __FUNCTION__);
520 'method not implemented', __FUNCTION__);
541 'method not implemented', __FUNCTION__);
561 'method not implemented', __FUNCTION__);
584 'method not implemented', __FUNCTION__);
605 'method not implemented', __FUNCTION__);
650 $table = $db->quoteIdentifier($table,
true);
651 $name = $db->quoteIdentifier($db->getIndexName(
$name),
true);
652 $query =
"CREATE INDEX $name ON $table";
654 foreach (array_keys($definition[
'fields']) as $field) {
655 $fields[] = $db->quoteIdentifier($field,
true);
657 $query .=
' ('. implode(
', ', $fields) .
')';
679 $name = $db->quoteIdentifier($db->getIndexName(
$name),
true);
680 return $db->exec(
"DROP INDEX $name");
701 'method not implemented', __FUNCTION__);
735 $table = $db->quoteIdentifier($table,
true);
736 $name = $db->quoteIdentifier($db->getIndexName(
$name),
true);
737 $query =
"ALTER TABLE $table ADD CONSTRAINT $name";
738 if (!empty($definition[
'primary'])) {
740 } elseif (!empty($definition[
'unique'])) {
744 foreach (array_keys($definition[
'fields']) as $field) {
745 $fields[] = $db->quoteIdentifier($field,
true);
747 $query .=
' ('. implode(
', ', $fields) .
')';
770 $table = $db->quoteIdentifier($table,
true);
771 $name = $db->quoteIdentifier($db->getIndexName(
$name),
true);
772 return $db->exec(
"ALTER TABLE $table DROP CONSTRAINT $name");
793 'method not implemented', __FUNCTION__);
815 'method not implemented', __FUNCTION__);
836 'method not implemented', __FUNCTION__);
859 'method not implemented', __FUNCTION__);