2 回答
TA贡献2080条经验 获得超4个赞
我不知道为什么你的输出改变了,但我认为要得到你想要的输出,你可以使用一个ORDER BY子句按序号位置排序。
ORDER BY c.ORDINAL_POSITION
当我在我自己的一个 MySQL 数据库上运行您的查询时,我在您的ed 列c.*列表中添加了一个。SELECT从显示的所有额外列中,这ORDINAL_POSITION似乎就是您要查找的内容。
所以你的最终查询可能看起来像这样:
SELECT c.COLUMN_NAME as column_name,
c.COLUMN_TYPE as column_type,
c.CHARACTER_MAXIMUM_LENGTH as length,
c.TABLE_NAME as table_name,
c.COLUMN_COMMENT as column_comment,
k.REFERENCED_TABLE_NAME as reference_table,
k.REFERENCED_COLUMN_NAME as reference_column
FROM information_schema.COLUMNS as c
LEFT JOIN information_schema.KEY_COLUMN_USAGE as k
ON (k.TABLE_SCHEMA=c.TABLE_SCHEMA
AND k.TABLE_NAME=c.TABLE_NAME
AND k.COLUMN_NAME=c.COLUMN_NAME
AND k.POSITION_IN_UNIQUE_CONSTRAINT IS NOT NULL)
WHERE c.TABLE_SCHEMA='$db_name'
AND c.TABLE_NAME='$table_name'
ORDER BY c.ORDINAL_POSITION
TA贡献1868条经验 获得超4个赞
SQL 表中没有“默认”排序顺序,至少没有 ANSI 标准要求的排序顺序(或者,正如您在此处看到的,由 MySQL 实现)。如果您希望结果集按特定顺序排列,则应添加适当的ORDER BY子句,例如
SELECT
c.COLUMN_NAME as column_name,
c.COLUMN_TYPE as column_type,
...
ORDER BY
c.COLUMN_NAME;
至于为什么感知的排序顺序发生了变化,可能与从数据库中获取记录的方式有关。随着底层数据的变化,MySQL 选择访问记录的方式也可能发生变化。
- 2 回答
- 0 关注
- 151 浏览
添加回答
举报