Maison > base de données > tutoriel mysql > le corps du texte

Pièges rencontrés dans les valeurs d'épissage oracle/mysql et comment utiliser les doubles barres verticales ||

PHPz
Libérer: 2023-05-28 20:13:28
avant
1979 Les gens l'ont consulté

    pièges Oracle MySQL rencontrés lors de l'épissage des valeurs​​Doubles barres verticales || concat

    ||

    "||" est une valeur d'épissage dans Oracle, mais cela signifie "ou" dans MySQL.

    where name like '%' || 'Tony' || '%'
    Copier après la connexion

    Il est donc recommandé d'utiliser concat()

    concat()

    mais concat() présente également des pièges. Dans

    mysql, vous pouvez utiliser directement concat pour fusionner 3 valeurs. Dans

    concat( '%' , 'Tonny' , '%' )
    Copier après la connexion

    oracle, cette utilisation est erronée. Étant donné que le concat d'Oracle ne peut épisser que 2 valeurs, il doit être comme ceci :

    concat( '%' , concat('Tonny' , '%') )
    Copier après la connexion

    Épissage de champ dans Oracle CONCAT et ||

    Dans Oracle, il existe deux méthodes d'épissage de chaîne, à savoir la fonction CONCAT() et "|| "Épissage

    1. Fonction d'épissage CONCAT()

    Inconvénients : ne prend en charge que l'épissage de deux chaînes. S'il y en a plus de deux, une erreur sera signalée (l'erreur signalée semble être un crochet droit manquant)

    //表中的两个字段拼接
    select concat(t1.column_1,t1.column_2) from table t1;//任意一个字段与任意字符串拼接 (time是取的别名,记住:Oracle 取别名不要用as )
    select concat('时间是: ',t1.column_2) time from table t1;
    select concat(t1.column_1,' 单位:元') time from table t1;//超过两个字段,会报错(下面这样写会报错)
    select concat(t1.column_1,t1.column_2,t1.column_3) from table t1;
    Copier après la connexion

    Lors de l'utilisation de CONCAT() Lorsque la fonction effectue un épissage de chaîne, si le champ épissé (chaîne) contient des caractères chinois, cela peut provoquer des caractères tronqués. La solution est d'ajouter to_char() au champ épissé (chaîne). ):

    //如果遇到乱码,加上to_char()
    select concat(to_char(t1.column_1),to_char(t1.column_2)) time from table t1;
    Copier après la connexion

    2. Utilisez " ||" Épissage de chaînes

    En utilisant l'épissage "||", il n'y a aucune restriction

    //表中两个字符串拼接,取别名为time
    select t1.column_1 || t1.column_2 time from table t1;//表中三个字符串拼接,取别名为time
    //这里可以使用括号将几个要拼接的字段括起来,可读性会好点,好像加不加括号都不影响
    select (t1.column_1 || t1.column_2 || t1.column_3) time from table t1;
    Copier après la connexion

    Les avantages de l'utilisation de l'épissage "||", lorsque vous effectuezdes requêtes floues, vous pouvez utiliser this

    //这样可以动态进行模糊查询,field是动态值
    select t1.* from table t1 where t1.name like '%' || field || '%';//如果对模糊查询更加细粒度,当然,也可以使用concat()进行模糊查询
    select t1.* from table t1 where t1.name like concat('%',field);
    select t1.* from table t1 where t1.name like concat(field,'%');
    Copier après la connexion

    Ajouter : Les pièges rencontrés par MySQL lors de l'utilisation de concat ou || pour épisser des chaînes

    Pour les besoins de l'entreprise, plusieurs champs ont été regroupés en un seul champ pour la requête, et ils étaient tous vides plus tard, après une recherche en ligne. J'ai trouvé :
    Utilisez || ou concat pour épisser une chaîne de caractères, si l'un d'eux est nul, il devient nul
    Peut être évité en utilisant concat_ws

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

    Étiquettes associées:
    source:yisu.com
    Déclaration de ce site Web
    Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
    Tutoriels populaires
    Plus>
    Derniers téléchargements
    Plus>
    effets Web
    Code source du site Web
    Matériel du site Web
    Modèle frontal
    À propos de nous Clause de non-responsabilité Sitemap
    Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!