是否有一种快速的方法从MySQL中所有表中获得所有列名,而不必列出所有表?
当前回答
我很久以前写了这个愚蠢的东西,现在仍然时不时地使用它:
https://gist.github.com/kphretiq/e2f924416a326895233d
基本上,它先执行“SHOW TABLES”,然后对每个表执行“DESCRIBE”,然后将其作为markdown输出。
只要在“if name”下面编辑,就可以了。您需要安装pymysql。
其他回答
在Nicola的回答上加上一些可读的php
$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>";
最好使用以下查询来获取所有列名 很容易
显示tablename中的列
问题是:
是否有一个快速的方法,从MySQL所有表中获得所有的列名,而不必列出所有的表?
SQL来获取每列的所有信息
select * from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
获取所有的列名
select COLUMN_NAME from information_schema.columns
where table_schema = 'your_db'
order by table_name,ordinal_position
列出MySQL表中的所有字段:
select *
from information_schema.columns
where table_schema = 'your_DB_name'
and table_name = 'Your_tablename'
<?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>';
?>
推荐文章
- MySQL现在()+1天
- MySQL索引的最佳实践是什么?
- 如何在Mac OS安装时停止MySQL ?
- 外键约束:何时使用ON UPDATE和ON DELETE
- 在MySQL中使用INDEX和KEY有什么区别?
- 连接查询vs多个查询
- MySQL:在同一个MySQL实例上克隆MySQL数据库
- 如何获得MySQL中所有表的所有列的名称?
- 使用一次更新设置多个列
- 错误的日期时间值:'0000-00-00 00:00:00'
- 如何获得列中每个不同值的计数?
- 插入……ON重复键(什么都不做)
- MySQL,更好地插入NULL或空字符串?
- 找到两个Lat/Long点之间距离的最快方法
- 如何使用Laravel迁移将时间戳列的默认值设置为当前时间戳?