簡體   English   中英

MySQL查詢在更新后以不同的順序返回列

[英]MySQL query returns columns in different order after update

我的一個程序正在使用此查詢來獲取所選表的列的詳細信息:

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) ...

該表中的第一列是id ,在結果數組中,第一個索引是id (它應該是)。

但是,現在更新 PHP(從 5.6 到 7.3)和 MySQL 后,結果排序有所不同。

不是基於列的創建日期優先級排序,而是基於某些未知元素( id是數組中的第三個索引)進行排序。

這是錯誤還是什么? 我怎樣才能恢復原來的排序順序?


好吧,我剛剛想到了一些東西。 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 表中沒有“默認”排序順序,至少沒有 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 ed 列列表中添加了一個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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM