婷婷久久综合九色综合,欧美成色婷婷在线观看视频,偷窥视频一区,欧美日本一道道一区二区

<tt id="bu9ss"></tt>
  • <span id="bu9ss"></span>
  • <pre id="bu9ss"><tt id="bu9ss"></tt></pre>
    <label id="bu9ss"></label>

    當(dāng)前位置:首頁 >  站長 >  數(shù)據(jù)庫 >  正文

    postgresql 查詢字符串中是否包含某字符的操作

     2021-05-26 16:51  來源: 腳本之家   我來投稿 撤稿糾錯

      阿里云優(yōu)惠券 先領(lǐng)券再下單

    這篇文章主要介紹了postgresql 查詢字符串中是否包含某字符的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧。

    先看表結(jié)構(gòu)和數(shù)據(jù):

    需求:

    查詢出manager_id中包含某些字符的數(shù)據(jù),此處查詢manager_id包含6651545956882725395,5722501350582149881的數(shù)據(jù),

    SQL語句如下:

    SELECT t.* from bas_cm_customer t where position('6651545956882725395' in t.manager_id) > 0 OR position ('5722501350582149881' in t.manager_id) > 0;
    SELECT t.* from bas_cm_customer t where position('6651545956882725395' in t.manager_id) > 0 OR position('5722501350582149881' in t.manager_id) > 0 ;
    SELECT t.* from bas_cm_customer t where strpos(t.manager_id,'6651545956882725395') > 0 or strpos(t.manager_id,'5722501350582149881') > 0;
    SELECT t.* from bas_cm_customer t where '6651545956882725395' ~ t.manager_id or '5722501350582149881' ~ t.manager_id;
    SELECT t.* FROM bas_cm_customer t WHERE (string_to_array('6651545956882725395,5722501350582149881', ',') && string_to_array(t.manager_id, ','))

    此處不比較這幾種寫法的性能問題,前四種寫法,如果后端語言是Java的話,使用的ibatis或者mybatis,那示例如下:

    Java部分:

    if (StringUtils.isNotEmpty(managerId)){
     String[] managerIds = managerId.split(",");
     queryParam.put("managerIds", managerIds);
    }

    ibatis和mybatis差不多,要改下標(biāo)簽:

    <isNotEmpty prepend="and" property="managerIds">
     <iterate property="managerIds" conjunction="OR">
      position(#managerIds[]# in bc.manager_id) > 0
     </iterate>
    </isNotEmpty>

     

    這里演示了 position函數(shù)的用法,strpos和~寫法與position寫法大致相同,就不貼出代碼了。

    相較于前四種寫法,第五種寫法,Java只要傳來字符串即可,Java層不需要做處理,直接把字符串傳來即可。

    補(bǔ)充:pgsql 判斷逗號分割字符串是否包含的方式

    我就廢話不多說啦,大家還是直接看代碼吧~

    SELECT ARRAY[1] <@ string_to_array('1,2,3,4,5,6', ',')::int[];
    SELECT position(1::VARCHAR in '1,2,3,4,5,6');
    SELECT strpos(1::VARCHAR,'1,2,3,4,5,6');
    SELECT '1,2,3,4,5,6' ~ 1::VARCHAR;

    文章來源:腳本之家

    來源地址:https://www.jb51.net/article/204846.htm

    申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

    相關(guān)文章

    熱門排行

    信息推薦