Come posso verificare se la colonna della tabella mysql esiste anche?

Come posso verificare se il field della tabella mysql esiste anche?

Il nome della colonna è "prezzo" e ho bisogno di vedere se esiste.

Non ho capito davvero come funzionano gli "ESISTE" …

Qualche esempio o idea?

Grazie

In PHP:

$fields = mysql_list_fields('database_name', 'table_name'); $columns = mysql_num_fields($fields); for ($i = 0; $i < $columns; $i++) {$field_arrays[] = mysql_field_name($fields, $i);} if (!in_arrays('price', $field_arrays)) { $result = mysql_query('ALTER TABLE table_name ADD price VARCHAR(10)'); } 

Questo dovrebbe anche aiutarti:

 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 

O puoi fare:

 Show columns from table like 'string'; 

C'è stata una domanda simile posta su SO qui prima.

Provare:

 IF NOT EXISTS (SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = 'TEST' AND COLUMN_NAME = 'Price') BEGIN -- do something, eg -- ALTER TABLE TEST ADD PRICE DECIMAL END 

Un altro modo di farlo in PHP:

 $chkcol = mysql_query("SELECT * FROM `table_name` LIMIT 1"); $mycol = mysql_fetch_arrays($chkcol); if(isset($mycol['price'])) echo "Column price exists! Do something..."; 

Bene, un modo è quello di fare:

 select price from your_table limit 1 

Se ricevi un errore:

 #1054 - Unknown column 'price' in 'field list' 

allora non esiste.

Ho trovato questo molto utile. Elencherà tutte le tabelle che hanno il nome di quella colonna.

 SELECT table_name, column_name FROM information_schema.columns WHERE column_name LIKE '%the_column_name%' 

bene qui è una function per verificare se una colonna particolare esiste o no.

 public function detect_column($my_db, $table, $column) { $db = mysql_select_db($my_db); //select the database $sql = "SHOW COLUMNS FROM $table LIKE '$column'"; //query $result = mysql_query($sql); //querying if(mysql_num_rows($result) == 0) //checks the absence of column echo "column $column doesn't exist !"; // write your code here! else echo "column $column exists!"; } 

beh se stai progettando un frame work, allora questa function potrebbe venire in tuo aiuto. Questa function controlla la presenza della colonna quando $ flag è impostato su '1' e assenza di colonna quando $ flag è impostato su '0'.

 public function detect_column($my_db, $table, $column, $flag) { $this->select_db($my_db); //select the database $sql = "SHOW COLUMNS FROM $table LIKE '$column'"; $result = mysql_query($sql); if(mysql_num_rows($result) == $flag) return true; else return false; } 

Puoi get una descrizione di tutte le colonne nella tua tabella.

desc your_table;

Ho appena fatto qualcosa di simile usando questa function per WordPress, questo per le tabelle di aggiornamento che hanno nuovi caratteri su di esso

 public function alterTable() { $table_name = $this->prefix . $this->tables['name']; $select = "select * from `{$table_name}` where 0=0 limit 1;"; $query = $this->db->get_results($select, ARRAY_A); if (isset($query[0]) && !key_exists('adv', $query[0])) { $sql = "ALTER TABLE `{$table_name}` ADD `me` INT NULL DEFAULT NULL ;"; $this->db->query($sql); } 

}