MySQL returning an empty field: CONCAT(nonEmpty1,empty2,nonEmpty3) = NULL

前端 未结 6 1174
攒了一身酷
攒了一身酷 2021-02-19 10:27

I have PHP 5 code accessing a MyISAM table on MySQL 5 server. The query looks like this:

SELECT CONCAT(fName1,\' \',mName2,\' \',lName3) AS userName 
    FROM us         


        
相关标签:
6条回答
  • 2021-02-19 11:07

    This was the solution I came up with which included Keeper and Ersatz answer. System would not allow me to vote you guys up though :(

    CONCAT_WS(IFNULL(ts_usr_nameDetails.first_name,''),' ',IFNULL(ts_usr_lib_connectionNameDetails.first_name,'')) AS composerName

    This allowed for some amazing results

    0 讨论(0)
  • 2021-02-19 11:08

    From MYSQL docs

    CONCAT() returns NULL if any argument is NULL.

    you want to use CONCAT_WS()

    CONCAT_WS(separator,str1,str2,...)
    

    But best bet is to just pull it back and use php cause if you need a different format or just one of those fields later you'll have to make another db call

    0 讨论(0)
  • 2021-02-19 11:11

    In MySQL concatenating any string to a NULL value results in NULL. You have to check for NULL before concatenate using IFNULL:

    SELECT CONCAT(IFNULL(fName1,''),' ',IFNULL(mName2,''),' ',IFNULL(lName3,'')) AS userName 
    FROM users 
    WHERE level > 10
    
    0 讨论(0)
  • 2021-02-19 11:19

    This is an answer based on the solution above by @chocojosh and another question here: MySQL/SQL: Update with correlated subquery from the updated table itself

    I had a similar problem, but I was trying to concat a bunch of group_concats and some were NULL which caused the whole row to be NULL. The goal was to place data from other tables into a single field in the main table to allow fulltext searches.

    Here is the SQL that worked. Note the first parameter for concat_ws I made ' ', this allowed for spaces between the values for the fulltext field.

    Hope this helps someone.

    update
    products target
    INNER JOIN 
    (
        select p.id, 
        CONCAT_WS(
        ' ',
            (select GROUP_CONCAT(field SEPARATOR ' ') from table1 where productId = p.id),
            p.title,' ', 
            (select GROUP_CONCAT(field, ' ', descriptions SEPARATOR ' ') from table2 where productId = p.id),
            (select GROUP_CONCAT(field SEPARATOR ' ') from table3 where productId = p.id),
            (select GROUP_CONCAT(field, ' ', catno SEPARATOR ' ') from table4 where productId = p.id),
            (select GROUP_CONCAT(field SEPARATOR ' ') from table5 where productId = p.id),
            (select GROUP_CONCAT(field SEPARATOR ' ') from table6 where productId = p.id),
            (select GROUP_CONCAT(field SEPARATOR ' ') from table7 where productId = p.id)
        ) as ft
        from products p
    ) as source
    on target.id = source.id
    set target.fulltextsearch = source.ft
    
    0 讨论(0)
  • 2021-02-19 11:23

    From google: http://bugs.mysql.com/bug.php?id=480

    [23 May 2003 4:32] Alexander Keremidarski

    Thank you for taking the time to write to us, but this is not a bug. Please double-check the documentation available at http://www.mysql.com/documentation/ and the instructions on how to report a bug at http://bugs.mysql.com/how-to-report.php

    This is doccumented behaviour of CONCAT() function.

    From Manual chapter 6.3.2 String Functions

    CONCAT(str1,str2,...) Returns the string that results from concatenating the arguments. Returns NULL if any argument is NULL

    Use CONCAT_WS() instead or wrap NULLable paremeters with IFNULL() function.

    Documentation and usage for CONCAT_WS: http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_concat-ws

    0 讨论(0)
  • 2021-02-19 11:25

    you could also the COALESCE() function to return the first non-null value. Like so:

    SELECT CONCAT(fName1,COALESCE(CONCAT(' ',mName2,' '),' '),lName3) AS userName 
      FROM users 
      WHERE level > 10
    

    This would also only put one space if there was no middle name and a space before and after if there was a middle name.

    Reference for this function can be found at: http://dev.mysql.com/doc/refman/5.0/en/comparison-operators.html#function_coalesce

    0 讨论(0)
提交回复
热议问题