sql >> Databasteknik >  >> RDS >> Mysql

mysql Varför variabeln inte ändras i if

Letar du efter det här?

SELECT rn, id, category_id, title
  FROM
(
  SELECT *, @a := IF(@c = category_id, @a + 1, 1) rn, @c := category_id
    FROM photos CROSS JOIN (SELECT @c := NULL, @a := 0) i
   ORDER BY category_id
) q
 WHERE rn <= 4;

Utdata:

| RN | ID | CATEGORY_ID |  TITLE |
|----|----|-------------|--------|
|  1 | 43 |           1 | Title1 |
|  1 | 28 |           2 | Title2 |
|  2 | 42 |           2 | Title3 |
|  1 | 11 |           3 | Title4 |
|  1 |  3 |           4 | Title5 |
|  2 | 29 |           4 | Title6 |
|  3 | 33 |           4 | Title7 |

Här är SQLFiddle demo

Här är en fix för din kod för att skapa rätt radnummer

SET @a:=0;
SET @cid:=0;   
SELECT @a, @cid, q.*, @cid:=q.category_id FROM (
    SELECT *
    FROM photos
    ORDER BY category_id
) AS q
WHERE @a := IF(@cid=q.category_id, @a+1, 1)

Här är SQLFiddle demo

Orden för körning av SQL-satsen spelar roll.




  1. Mysql räknar instanser av delsträng, sortera sedan efter

  2. Fick ett minus ett av ett lässamtal

  3. Hur kontrollerar jag att kolumnen är virtuell i Oracle?

  4. UTF8-kodningsproblem - med bra exempel