假設我有波紋管查詢:Mysql如何獲取子查詢的列名?
SELECT
c.id AS 'course_id',u.id as 'user_id',c.round,u.first_name as name,u.last_name as family_name,u.`father_name`,u.`tazkera_id` as tazkira,c.`no` as class_ID,tc.province,tc.village,tl.id as training_provider_id,
CASE c.`shift`
WHEN 1 THEN 'Morning'
WHEN 2 THEN 'Afternoon'
END as shift,
c.`start_date`as start_date,
sa.participant_id,
DATE_FORMAT(ca.`date`,'%Y-%m-%d') as attendence,
CASE sa.`precence`
WHEN 0 THEN 'A'
WHEN 1 THEN 'P'
END as attendence_status
FROM `users` AS u
LEFT JOIN `provinces` as pu On pu.`province_code` = u.`province_code`
LEFT JOIN `districts` as du on du.`district_code` = u.`district_code`
LEFT JOIN `course_user` as cu ON cu.`user_id` = u.id AND cu.`relation_type` = 1
LEFT JOIN `courses` AS c On c.id = cu.`course_id`
LEFT JOIN `training_centers` as tc On tc.id = c.`training_center_id`
LEFT JOIN `training_providers` AS tl ON tl.id = tc.`training_provider_id`
/*** Training location **/
LEFT JOIN `provinces` as pt On pt.`province_code` = tc.`province`
LEFT JOIN `districts` as dt on dt.`district_code` = tc.`district`
LEFT JOIN `course_attendances` as ca ON ca.`course_id` = c.`id`
LEFT JOIN `student_attendances` as sa ON sa.`course_attendance_id` = ca.`id`
WHERE c.id IS NOT NULL AND sa.`participant_id` = u.id
GROUP BY sa.`participant_id`,ca.date order by u.id,ca.date
我想利用上述查詢的列名與MySQL。 當然用PHP我們可以做到這一點,但我的問題是,如何做到這一點與MySQL查詢?可能嗎 ?
您正在給您選擇的大部分內容提供別名,因此您不知道結果集中列的名稱? –
@TimBiegeleisen我有很多這樣的其他查詢,我使用它作爲drodown中的表名,別名'src',當用戶選擇它時,我應該運行它的相關查詢,並獲取所有列名以在另一個下拉列表中顯示它用戶列表。 – jones
只需對您的查詢進行一些說明:對別名使用雙引號;單引號用於字符串文字。你加入了很多你不用在結果中的表格('省份','區域',兩個表格甚至兩次,以及表格'training_providers',你只需使用'id',你可以用'training_centers.raining_provider_id已經)。爲什麼?你也試圖外連接所有的表。這是故意的嗎?它似乎沒有道理,它甚至不起作用,因爲你在where子句中解除了外部連接的記錄。 '在哪裏c.id不是NULL'?一個表的ID如何可以爲空? –