sql >> Database teknologi >  >> RDS >> Mysql

SQL-syntaksfejl med understreng og charindex

Hvis du bruger SQL Server, har du en forkert udformet JOIN . Og meget dårlige bordaliasser. Måske gør dette, hvad du vil:

update fs
    set user_id = u.id,
        message = SUBSTRING(fs.message, 1, CHARINDEX('[', fs.message)-1)
    from edi_file_steps fs INNER JOIN
         GU_User u
         on u.login = SUBSTRING(fs.message, CHARINDEX('[', fs.message)+1, len(fs.message)- CHARINDEX('[',fs.message)-1 )
    where message LIKE '%Downloaded%' ;

EDIT:

I MySQL ville dette være:

update edi_file_steps fs INNER JOIN
       GU_User u
       on fs.message like concat('%[', u.login, ']%')
    set user_id = table_B.id,
        message = substring_index(fs.message, '[', 1)
    where message LIKE '%Downloaded%' ;



  1. Sådan får du MySQL-status i en forespørgsel

  2. returner mySQL originale rækkenummer

  3. Sådan opdaterer og sletter du listen. Se data i SQLite-database med kliklytter?

  4. hvad er brugen af ​​pool-indstillingen i database.yml