乱码乱a∨中文字幕,在线免费激情视频,亚洲欧美久久夜夜潮,国产在线网址

  1. <sub id="hjl7n"></sub>

    1. <sub id="hjl7n"></sub>

      <legend id="hjl7n"></legend>

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

      postgresql 查詢(xún)字符串中是否包含某字符的操作

       2021-05-26 16:51  來(lái)源: 腳本之家   我來(lái)投稿 撤稿糾錯(cuò)

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

      這篇文章主要介紹了postgresql 查詢(xún)字符串中是否包含某字符的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧。

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

      需求:

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

      SQL語(yǔ)句如下:

      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, ','))

      此處不比較這幾種寫(xiě)法的性能問(wèn)題,前四種寫(xiě)法,如果后端語(yǔ)言是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和~寫(xiě)法與position寫(xiě)法大致相同,就不貼出代碼了。

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

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

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

      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;

      文章來(lái)源:腳本之家

      來(lái)源地址:https://www.jb51.net/article/204846.htm

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

      相關(guān)文章

      熱門(mén)排行

      信息推薦