MySQL 查询 returns 更新后不同顺序的列
MySQL query returns columns in different order after update
我的一个程序正在使用此查询来获取所选 table 列的详细信息:
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'
以前的结果是:
array(36) { [0]=> array(7) { ["column_name"]=> string(2) "id" ["column_type"]=> string(7) ...
table 中的第一列是 id
,在结果数组中,第一个索引是 id
(应该是)。
但是现在,在更新 PHP(从 5.6 到 7.3)和 MySQL 之后,结果排序不同。
不是根据列的创建日期优先级排序,而是根据某些未知元素排序(id
是数组中的第 3 个索引)。
这是错误还是什么?我怎样才能恢复原来的排序顺序?
好的,我刚刚想通了一些事情。 MySQL 首先对带有外键的列进行排序,然后对其余列进行排序。
我不要这个! 如何恢复原来的排序顺序?
这是我的结果。首先是当前(错误)输出,然后是预期输出。
输出不正确
column_name column_type length table_name column_comment reference_table reference_column
qdqe_group varchar(15) 15 md_report name/Mach_Name mach Op_ID
owner varchar(25) 25 md_report users uName
Pile varchar(12) 12 md_report depo Depo_ID
Co_ID varchar(3) 3 md_report name/Co_NameF contractors Co_ID
Region_ID varchar(2) 2 md_report dependent/Mine_ID regions Region_ID
id int(11) NULL md_report NULL NULL
Submit_Date timestamp NULL md_report NULL NULL
asd_ID varchar(2) 2 md_report input/multiple- NULL Null
asd-asd_ID,asd_
nameF
wer_Report date NULL md_report NULL NULL
sdf_Qty int(2) NULL md_report NULL NULL
jyu_Time time NULL md_report NULL NULL
yuj_Work float(6,2) NULL md_report NULL NULL
Al2O3 float(4,2) NULL md_report NULL NULL
SiO2 float(4,2) NULL md_report NULL NULL
nh_Time time NULL md_report NULL NULL
ju_Work float(6,2) NULL md_report NULL NULL
we_Time time NULL md_report NULL NULL
xcv_Work float(6,2) NULL md_report NULL NULL
trh_Time time NULL md_report NULL NULL
ewr_Work float(6,2) NULL md_report NULL NULL
fgh_Time time NULL md_report NULL NULL
ert_Work float(6,2) NULL md_report NULL NULL
dfg_Time time NULL md_report NULL NULL
vf_Work float(9,2) NULL md_report NULL NULL
as_Time time NULL md_report NULL NULL
这是他们在 MySQL 中的真实位置:
(因为个人原因改了一些名字)
预期输出
column_name column_type length table_name column_comment reference_table reference_column
id int(11) NULL md_report NULL NULL
Submit_Date timestamp NULL md_report NULL NULL
owner varchar(25) 25 md_report users uName
wer_Report date NULL md_report NULL NULL
Co_ID varchar(3) 3 md_report name/Co_NameF contractors Co_ID
Region_ID varchar(2) 2 md_report dependent/Mine_ID regions Region_ID
asd_ID varchar(2) 2 md_report input/multiple- NULL NULL
asd-asd_ID,asd_
nameF
qdqe_group varchar(15) 15 md_report name/Mach_Name mach Op_ID
sdf_Qty int(2) NULL md_report NULL NULL
jyu_Time time NULL md_report NULL NULL
yuj_Work float(6,2) NULL md_report NULL NULL
Pile varchar(12) 12 md_report depo Depo_ID
Al2O3 float(4,2) NULL md_report NULL NULL
SiO2 float(4,2) NULL md_report NULL NULL
nh_Time time NULL md_report NULL NULL
ju_Work float(6,2) NULL md_report NULL NULL
we_Time time NULL md_report NULL NULL
xcv_Work float(6,2) NULL md_report NULL NULL
trh_Time time NULL md_report NULL NULL
ewr_Work float(6,2) NULL md_report NULL NULL
fgh_Time time NULL md_report NULL NULL
ert_Work float(6,2) NULL md_report NULL NULL
dfg_Time time NULL md_report NULL NULL
vf_Work float(9,2) NULL md_report NULL NULL
as_Time time NULL md_report NULL NULL
如您所见,MySQL 对结果顶部带有引用的所有列进行了排序。
我想通过这些细节让他们处于真实位置。
新的结果无论如何都不符合逻辑。如果你能向我解释这里发生了什么,我将不胜感激。
SQL table 中没有 "default" 排序顺序,至少 none 是 ANSI 标准所要求的(或者,正如您在此处看到的那样,由 MySQL 实施)。如果您希望结果集按特定顺序排列,则应添加适当的 ORDER BY
子句,例如
SELECT
c.COLUMN_NAME as column_name,
c.COLUMN_TYPE as column_type,
...
ORDER BY
c.COLUMN_NAME;
至于为什么感知到的排序顺序发生了变化,这可能与如何从数据库中获取记录有关。随着基础数据的变化,MySQL 选择访问记录的方式也可能发生变化。
我不知道为什么你的输出改变了,但我认为要得到你想要的输出,你可以使用一个 ORDER BY
子句来按序号位置排序。
ORDER BY c.ORDINAL_POSITION
当我 运行 你在我自己的一个 MySQL 数据库上查询时,我在你的 SELECT
列列表中添加了 c.*
。从显示的所有额外列来看,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
我的一个程序正在使用此查询来获取所选 table 列的详细信息:
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'
以前的结果是:
array(36) { [0]=> array(7) { ["column_name"]=> string(2) "id" ["column_type"]=> string(7) ...
table 中的第一列是 id
,在结果数组中,第一个索引是 id
(应该是)。
但是现在,在更新 PHP(从 5.6 到 7.3)和 MySQL 之后,结果排序不同。
不是根据列的创建日期优先级排序,而是根据某些未知元素排序(id
是数组中的第 3 个索引)。
这是错误还是什么?我怎样才能恢复原来的排序顺序?
好的,我刚刚想通了一些事情。 MySQL 首先对带有外键的列进行排序,然后对其余列进行排序。
我不要这个! 如何恢复原来的排序顺序?
这是我的结果。首先是当前(错误)输出,然后是预期输出。
输出不正确
column_name column_type length table_name column_comment reference_table reference_column
qdqe_group varchar(15) 15 md_report name/Mach_Name mach Op_ID
owner varchar(25) 25 md_report users uName
Pile varchar(12) 12 md_report depo Depo_ID
Co_ID varchar(3) 3 md_report name/Co_NameF contractors Co_ID
Region_ID varchar(2) 2 md_report dependent/Mine_ID regions Region_ID
id int(11) NULL md_report NULL NULL
Submit_Date timestamp NULL md_report NULL NULL
asd_ID varchar(2) 2 md_report input/multiple- NULL Null
asd-asd_ID,asd_
nameF
wer_Report date NULL md_report NULL NULL
sdf_Qty int(2) NULL md_report NULL NULL
jyu_Time time NULL md_report NULL NULL
yuj_Work float(6,2) NULL md_report NULL NULL
Al2O3 float(4,2) NULL md_report NULL NULL
SiO2 float(4,2) NULL md_report NULL NULL
nh_Time time NULL md_report NULL NULL
ju_Work float(6,2) NULL md_report NULL NULL
we_Time time NULL md_report NULL NULL
xcv_Work float(6,2) NULL md_report NULL NULL
trh_Time time NULL md_report NULL NULL
ewr_Work float(6,2) NULL md_report NULL NULL
fgh_Time time NULL md_report NULL NULL
ert_Work float(6,2) NULL md_report NULL NULL
dfg_Time time NULL md_report NULL NULL
vf_Work float(9,2) NULL md_report NULL NULL
as_Time time NULL md_report NULL NULL
这是他们在 MySQL 中的真实位置: (因为个人原因改了一些名字)
预期输出
column_name column_type length table_name column_comment reference_table reference_column
id int(11) NULL md_report NULL NULL
Submit_Date timestamp NULL md_report NULL NULL
owner varchar(25) 25 md_report users uName
wer_Report date NULL md_report NULL NULL
Co_ID varchar(3) 3 md_report name/Co_NameF contractors Co_ID
Region_ID varchar(2) 2 md_report dependent/Mine_ID regions Region_ID
asd_ID varchar(2) 2 md_report input/multiple- NULL NULL
asd-asd_ID,asd_
nameF
qdqe_group varchar(15) 15 md_report name/Mach_Name mach Op_ID
sdf_Qty int(2) NULL md_report NULL NULL
jyu_Time time NULL md_report NULL NULL
yuj_Work float(6,2) NULL md_report NULL NULL
Pile varchar(12) 12 md_report depo Depo_ID
Al2O3 float(4,2) NULL md_report NULL NULL
SiO2 float(4,2) NULL md_report NULL NULL
nh_Time time NULL md_report NULL NULL
ju_Work float(6,2) NULL md_report NULL NULL
we_Time time NULL md_report NULL NULL
xcv_Work float(6,2) NULL md_report NULL NULL
trh_Time time NULL md_report NULL NULL
ewr_Work float(6,2) NULL md_report NULL NULL
fgh_Time time NULL md_report NULL NULL
ert_Work float(6,2) NULL md_report NULL NULL
dfg_Time time NULL md_report NULL NULL
vf_Work float(9,2) NULL md_report NULL NULL
as_Time time NULL md_report NULL NULL
如您所见,MySQL 对结果顶部带有引用的所有列进行了排序。
我想通过这些细节让他们处于真实位置。
新的结果无论如何都不符合逻辑。如果你能向我解释这里发生了什么,我将不胜感激。
SQL table 中没有 "default" 排序顺序,至少 none 是 ANSI 标准所要求的(或者,正如您在此处看到的那样,由 MySQL 实施)。如果您希望结果集按特定顺序排列,则应添加适当的 ORDER BY
子句,例如
SELECT
c.COLUMN_NAME as column_name,
c.COLUMN_TYPE as column_type,
...
ORDER BY
c.COLUMN_NAME;
至于为什么感知到的排序顺序发生了变化,这可能与如何从数据库中获取记录有关。随着基础数据的变化,MySQL 选择访问记录的方式也可能发生变化。
我不知道为什么你的输出改变了,但我认为要得到你想要的输出,你可以使用一个 ORDER BY
子句来按序号位置排序。
ORDER BY c.ORDINAL_POSITION
当我 运行 你在我自己的一个 MySQL 数据库上查询时,我在你的 SELECT
列列表中添加了 c.*
。从显示的所有额外列来看,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