开发者

Return value 1 on FIRST INSTANCE of unique

开发者 https://www.devze.com 2022-12-14 09:48 出处:网络
I have a table with Name and Area. I want to run a query that returns that table with the addition of a \'Special_COUNT\'

I have a table with Name and Area. I want to run a query that returns that table with the addition of a 'Special_COUNT' The count returns 1 on the firstmost Concat(Distinct(Name,Area); should return 0 otherwise For example:

Name          |          Area          |     Special_COUNT      |      

ABCD          |       开发者_高级运维   US            |          1             |
ABCD          |          US            |          0             |*Same Name/Region no value
ABCD          |          Asia          |          1             |*New Region
ABCDX         |          Asia          |          1             |*New Name

How can I get the above 'Special_COUNT' column into the results of my query?


MySQL doesn't have any ranking functionality - you'll want to read this article for setting up the variables for LEAD functionality in order to number the output correctly.

Use:

SELECT x.name,
       x.area,
       x.special_count
  FROM (SELECT t.name,
               t.area,
               CASE WHEN @name = t.name AND @area = t.area THEN 0 ELSE 1 END AS special_count,
               @name := t.name, 
               @area := t.area
          FROM TABLE t, 
               (SELECT @area := NULL, @name := NULL) r) x

Tested on 4.1 - results match, thanks for supplying test data.


Thanks!

Your code looks so simple, alas I am not able to work this into a larger query (apologies for not providing an example query so that you could show me how this would work, below I have done that for you in the hopes that you can explain by example)

So given this original query below how would I revise it to incorporate your data with the goal of obtaining a 'special_count' on allanimalnames.AnimalName per location.Area

I see the light at the end of the tunnel...

SELECT
CASE allanimalnames.animalID
    WHEN allanimalnames.animalID = 1 THEN "Dangerous!"
    WHEN allanimalnames.animalID <> 1 THEN "Cuddly"
END AS 'Animal Danger Levell,

allanimalsizes.SizeInFeet AS 'Length of the Animal',
allanimaltypes.AnimalTypeName AS 'Carnivor or Herbavore?',
location.Area AS 'Region this Animal is found in',
allanimalnames.AnimalName AS 'Name of this animal,
MAX(report.reportdate) AS 'Last Reported'
FROM
allanimalnames
INNER JOIN allanimaltypes ON allanimaltypes.atypeid = allanimalnames.atypeid
INNER JOIN allanimalsizes ON allanimalsizes.sizeid = allanimalnames.sizeid
INNER JOIN location ON location.locid = allanimalnames.locid
INNER JOIN report ON report.reportid = allanimalnames.reportid
WHERE
report.reportdate
BETWEEN '2008-01-01' AND '2009-01-01'
GROUP BY
allanimalsizes.SizeInFeet
allanimaltypes.AnimalTypeName
location.Area
allanimalnames.AnimalName
report.reportdate
0

精彩评论

暂无评论...
验证码 换一张
取 消