Tüm tabloları MySQL
listelemek zorunda kalmadan, tüm tablolardan tüm sütun adlarını almanın hızlı bir yolu var mı ?
Tüm tabloları MySQL
listelemek zorunda kalmadan, tüm tablolardan tüm sütun adlarını almanın hızlı bir yolu var mı ?
Yanıtlar:
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
tüm sütun adlarını kolayca almak için aşağıdaki sorguyu kullanmanız daha iyidir
Show columns from tablename
SELECT * FROM information_schema.columns
WHERE table_schema = DATABASE()
ORDER BY table_name, ordinal_position
Değiştirilmesi: Ben yorumuna yeterince temsilcisi olmadığı için, burada nick RuLez mükemmel cevap üzerinde (Bence) küçük bir gelişmedir WHERE table_schema = 'your_db'
ile WHERE table_schema = DATABASE()
.
Başkaları için yararlı olması durumunda, bu size her bir tablodaki sütunların virgülle ayrılmış bir listesini verecektir:
SELECT table_name,GROUP_CONCAT(column_name ORDER BY ordinal_position)
FROM information_schema.columns
WHERE table_schema = DATABASE()
GROUP BY table_name
ORDER BY table_name
Not: Çok sayıda sütuna ve / veya uzun alan adlarına sahip tablolar kullanırken , verilerin kesilmesine neden olabilecek group_concat_max_len sınırına dikkat edin .
<?php
$table = 'orders';
$query = "SHOW COLUMNS FROM $table";
if($output = mysql_query($query)):
$columns = array();
while($result = mysql_fetch_assoc($output)):
$columns[] = $result['Field'];
endwhile;
endif;
echo '<pre>';
print_r($columns);
echo '</pre>';
?>
@Suganya tarafından gönderilen cevaba benzer şekilde bu doğrudan soruyu cevaplamamakla birlikte tek bir tablo için daha hızlı bir alternatiftir:
DESCRIBE column_name;
Soru şuydu:
Tüm tabloları listelemek zorunda kalmadan MySQL'deki tüm tablolardan tüm COLUMN NAMES'leri almanın hızlı bir yolu var mı?
Her sütun için tüm bilgileri almak için SQL
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Tüm COLUMN NAMES'ları almak için SQL
select COLUMN_NAME from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
Bu saçma şeyi uzun zaman önce yazdım ve hala şimdi ve sonra kullanıyorum:
https://gist.github.com/kphretiq/e2f924416a326895233d
Temel olarak, bir "GÖSTER TABLOLARI", ardından her tabloda bir "DESCRIBE" ifadesi, daha sonra bunu işaretleme olarak tükürür.
Sadece "if name " altında düzenleme yapın ve devam edin. Yüklü pymysql olması gerekir.
Bazı okunabilir php ile Nicola'nın cevabı üzerine piggybacking
$a = mysqli_query($conn,"select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position");
$b = mysqli_fetch_all($a,MYSQLI_ASSOC);
$d = array();
foreach($b as $c){
if(!is_array($d[$c['TABLE_NAME']])){
$d[$c['TABLE_NAME']] = array();
}
$d[$c['TABLE_NAME']][] = $c['COLUMN_NAME'];
}
echo "<pre>",print_r($d),"</pre>";