Heim  >  Fragen und Antworten  >  Hauptteil

Übergibt Variablen in der SELECT-Anweisung in MySQL 8

Ich versuche es mit einer einfachen Select-Anweisung mit Variablen. Wenn ich die Anweisung wie concat_ws('%', @S, '%'); ändere, funktioniert es einwandfrei. zu einer Zeichenfolge. Es scheint, dass die SELECT-Anweisung die SET-Variable nicht auswählt. Ich danke Ihnen für Ihre Hilfe. Ich verwende die Mysql80-Workbench.

SET @S = "product";
SELECT distinct idproducts FROM mgjtest.vorutaflamedsamheit
WHERE productname like concat_ws('%', @S, '%');
````````````````````````````````````````````````````````````````

P粉764836448P粉764836448244 Tage vor485

Antworte allen(1)Ich werde antworten

  • P粉128563140

    P粉1285631402024-02-18 00:11:42

    只需使用 CONCAT 即可确保变量值两侧的通配符。否则,先使用 CONCAT_WS作为分隔符的参数在字符串末尾返回双通配符,相当于单通配符并产生不期望的结果。

    LIKE 'product%%'
    
    LIKE 'product%'
    

    但是,CONCAT 将按照您的预期返回通配符:

    LIKE '%product%'
    

    Antwort
    0
  • StornierenAntwort