我的一个程序是使用此查询来获取所选表列的详细信息:
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'
以前的结果是:
数组(36) { [0]=> 数组(7) { ["column_name"]=> 字符串(2) "id" ["column_type"]=> 字符串(7) ...
该表中的第一列是id,在结果数组中,第一个索引是id(因为它应该是)。
然而,现在,在更新 PHP(从 5.6 到 7.3)和 MySQL 之后,结果排序有所不同。
它不是根据列的创建日期优先级进行排序,而是根据一些未知元素(id数组中的第三个索引)进行排序。
这是一个错误还是什么?我怎样才能找回原来的排序顺序?
好吧,我刚刚想通了一些事情。MySQL首先使用外键对列进行排序,然后是其余列。
我不要这个!我怎样才能找回原来的排序顺序?
犯罪嫌疑人X
MYYA