开发者

mysql select to return blanks for all but first row of repeating column

Is it possible to create a mysql select (directly or using a stored procedure) that will return blanks for repeating columns. Fo开发者_如何学运维r example, a select that would normally return these 7 records with 2 columns:

Bob   123
Bob   557
Bob   888
Joe   887
Joe   223
Tom   899
Tom   999

I would prefer to see this directly from the sql select:

Bob   123
      557
      888
Joe   887
      223
Tom   899
      999

I realize I can just post process the records in my program, but I'd like to replace the duplicates with blanks within the sql call.


Following should work but it doesn't return the results in the order you've used in your example.

SELECT  IF(n.ID = nm.ID, n.Name, NULL)
        , n.ID
FROM    Names n
        INNER JOIN (
          SELECT  Name
                  , ID = MIN(ID)
          FROM    Names        
          GROUP BY
                  Name
        ) nm ON nm.Name = n.Name
ORDER BY
        n.Name
        , n.ID


Yes, it's possible, but it would be very expensive (subqueries!) and not at all efficient. Whatever language you use or however you transfer this data directly, it's not worth it to have SQL spare these few bytes.


It seems like it would be a huge waste of resources to not do it through your application, but one way that you could do this is to use PL/SQL in a stored procedure or something similar to populate a some temporary table. With this you could declare a variable for if the name equals the last name that was iterated over. So if the name is a new name add it to the temporary table otherwise do not.

Again though this is a huge waste of resources


For MySQL (I guess it should be similar for other DBs), to avoid repeating a column value on every row, you can make good use of variables. No subqueries necessary: light and quick.

//Init a variable
SET @previous:="";

//Remember previous row value
SELECT IF(Name=@previous, "", @previous:=Name) AS GroupedName, Value
FROM tableName ORDER BY 1;


For future readers, here is a select query that will return blanks for repeating column values.

SELECT IF(name=@previous, "", @previous:=name) as name_, value
FROM (SELECT @previous:= '') AS temp, tableName
ORDER BY name
0

上一篇:

下一篇:

精彩评论

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

最新问答

问答排行榜