Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wie kann ich überprüfen, ob die MySQL-Tabellenspalte überhaupt existiert?

In PHP:

$fields = mysql_list_fields('database_name', 'table_name');
$columns = mysql_num_fields($fields);
for ($i = 0; $i < $columns; $i++) {$field_array[] = mysql_field_name($fields, $i);}

if (!in_array('price', $field_array))
{
$result = mysql_query('ALTER TABLE table_name ADD price VARCHAR(10)');
}

Dies sollte Ihnen auch helfen:

IF NOT EXISTS (SELECT * FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = ‘TEST’ AND COLUMN_NAME = ‘TEST_DATE’)
BEGIN
  ALTER TABLE TEST ADD TEST_DATE DATETIME
END

Oder Sie können Folgendes tun:

Show columns from table like 'string';

Es wurde eine ähnliche Frage auf SO hier vorher.