sql >> Databasteknik >  >> RDS >> Mysql

mySQL>> Lägga till HREF-länkar till en distinkt GROUP_CONCAT

Följer på denna fråga , och med den frågan som grund för följande exempel kan du göra detta med följande:

SELECT 
CONCAT(res_id,': ',res_name) 'Resources', 
GROUP_CONCAT(distinct t_name order by t_id separator ',') 'Topics', 
GROUP_CONCAT(distinct ch_name order by ch_id separator ',') 'Chapters'
FROM (SELECT res_id,
      res_name,
      t_id,
      t_name,
      ch_id, 
      CONCAT("<a href=\"page.asp?topic=",ch_name,"\" title=\"",ch_name,"\">",ch_name,"</a>") as ch_name 
             FROM resources r
             JOIN topics_to_resource ttr ON ttr.tr_resid = r.res_id
             JOIN topics t on t.t_id = ttr.tr_tid
             JOIN topics_to_chapter ttc on ttc.tch_tid = t.t_id
             JOIN chapters ch ON ch.ch_id = tch_chid) links
      GROUP BY res_id
      ORDER BY res_id, t_id, ch_id;

I princip har jag lagt in källdata i en separat (under)fråga, byggt länkarna och sedan utfört GROUP_CONCAT är utanför detta.

Detta ger:

<a href="page.asp?topic=CHAPTER #1" title="CHAPTER #1">CHAPTER #1</a>,
<a href="page.asp?topic=CHAPTER #2" title="CHAPTER #2">CHAPTER #2</a>,
<a href="page.asp?topic=CHAPTER #3" title="CHAPTER #3">CHAPTER #3</a>

Se denna fiol för mer information




  1. ActiveRecord::StatementInvalid:Mysql2::Fel:Kan inte ta bort eller uppdatera en överordnad rad - Rails 4.2.6

  2. Skapa tabellnamn som är reserverade ord/sökord i MS SQL Server

  3. cakephp:hur får man NOW() att fungera i söktillstånd?

  4. SQL-fråga för beräkning av kontosaldo