mysql - 關于數據庫中系統(tǒng)metadata方法的問題
問題描述
使用metadata方法,如INFORMATION_SCHEMA.COLUMNS, INFORMATION_SCHEMA.TABLE這種,初學metadata方法,這里不太理解, 并且對于mysql不能用with方法不知道怎么解決,如何用一個語句選出的結果在另一個語句中進行from操作?臨時表如何搭建?
CUSTOMER(cid,cname,ccity,cstate,cphone)RESTAURANT(rid,rname,rcity,rstate)MENUITEM(rid,itemname,price)ORDER(oid,cid,rid,ordertime,deliverytime,totalprice,deliveryfee)ORDERDETAIL(oid,rid,itemname,quantity)列出擁有最多attributes的table列出attribute類型為int的attribute名及其table名列出擁有相同attribute和相同數據類型的兩個表
問題解答
回答1:mysql不支持with,臨時表語法可以百度,”用一個語句選出的結果在另一個語句中進行from操作“你是說insert into select么 oracle也有的嘛 臨時數據可以直接用insert into tbl select * from dual插入臨時表 方法笨了點還是可以實現(xiàn)的“列出擁有最多attributes的table”和“列出attribute類型為int的attribute名及其table名”在INFORMATION_SCHEMA.COLUMNS中有table_schema,table_name,column_name,data_type,你按需要取值就可以了最后一個問題可以稍微處理一下數據篩選,比如select group_concat(table_name) from (select table_name,group_concat(table_columns) table_atrs from (select table_name,concat(column_name,data_type,ifnull(CHARACTER_MAXIMUM_LENGTH,’’)) table_columns from INFORMATION_SCHEMA.COLUMNS order by table_name,column_name) tbl group by table_name ) aaa group by table_atrs having count(1)>1;整理了一下,這個sql可以找出你要的結果,相同結構的表名以逗號連接展示出來(不包括索引結構)
相關文章:
1. docker網絡端口映射,沒有方便點的操作方法么?2. docker不顯示端口映射呢?3. javascript - nodejs調用qiniu的第三方資源抓取,返回401 bad token,為什么4. angular.js - angular內容過長展開收起效果5. nignx - docker內nginx 80端口被占用6. docker綁定了nginx端口 外部訪問不到7. thinkphp5.1學習時遇到session問題8. dockerfile - 我用docker build的時候出現(xiàn)下邊問題 麻煩幫我看一下9. java - 為什么此私有靜態(tài)變量能被訪問呢?10. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?
