php查询mysql中的json编码后的字符串内容的方法
博客专区 > jroam 的博客 > 博客详情
php查询mysql中的json编码后的字符串内容的方法
jroam 发表于7个月前
php查询mysql中的json编码后的字符串内容的方法
  • 发表于 7个月前
  • 阅读 26
  • 收藏 0
  • 点赞 0
  • 评论 0

问题

  1. mysql里存的是json编码后的字符串,其中中文会被转为unicode码,所以直接查询是查询不到的。
  2. mysql里的查询如 like "%\u6211\u662f%" 也是不会有结果的,原因是反斜线被mysql转义了, 需要如下的格式才能查询: like "%\\\\u6211\\\\u662f%" (四个反斜杠) 注意:mysql5.7版以后增加了直接对json格式的支持.

解决方式:

  1. 写二个php函数对要查询的字符串进行unicode编码或解码(这里,我们利用了json_encode这个函数)

  对关键字进行unicode编码
  @param  string $keyword  要编码的字符串关键字
  @return string         str

 function unicode_encode($keyword=""){
   if($keyword=="") return "";
   $bb=json_encode(array($keyword));
   return preg_replace("/^\[\"|\"\]$/","",$bb);
}



 对关键字进行unicode解码
 @param  string $keyword   unicode编码后的字符串
 @return string           str

 function unicode_decode($keyword=""){
   if($keyword=="") return "";
   $keyword="[\"".$keyword."\"]";
   $aa=json_decode($keyword,true);
   return $aa[0];
}

  1. 对转化成unicode后的字符串,替换为4个反斜杠.
$keyword=preg_replace("/\\/","\\\\","\u5a74\u513f");
  1. 用最后得到的keyword去mysql数据库里like查询或其它查询就可以得到预期的结果了。
共有 人打赏支持
粉丝 0
博文 5
码字总数 1957
×
jroam
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: