• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

查询二张表并输出

php 搞代码 4年前 (2022-01-24) 9次浏览 已收录 0个评论

查询2张表并输出
整个情况是这样的:
A表结构
id name info
1 栏目一 (存储样式为a:{s:6:”picid”;s:2:”74″;s:9:”text”;s:1:”存储内容区”;})
2 栏目二 (存储样式为a:{s:6:”picid”;s:2:”75″;s:9:”text”;s:1:”存储内容区”;})
B表结构
id url
74 图片路径
首先通过查询获取到了A表info中picid的id号为74,75的数组
输出样式为:
Array
(
[0] => 74
[1] => 75
)
然后在查询B表id为74,75的数据
然后如何关联输出这2张表的内容呢?@本文9来源gao($daima.com搞@代@#码8网^搞代gaodaima码
输出结果如何为:
Array
(
[0] => Array
(
[id] => 1
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)

[1] => Array
(
[id] => 2
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
….

——解决方案——————–
取出 info 中的 text 的内容的表达式
substring_index(substring_index(substr(info, locate(‘”text”‘, info)), ‘”‘, 4), ‘”‘, -1) as info

两表的关联条件
B表.id = substring_index(substring_index(substr(info, locate(‘”picid”‘, info)), ‘”‘, 4), ‘”‘, -1)

表达式很长,你可以用存储过程来缩短他

原理很简单
a:{s:6:”picid”;s:2:”74″;s:9:”text”;s:1:”存储内容区”;}
substr(info, locate(‘”picid”‘, info)) 用于取得 “picid” 看是的一段
“picid”;s:2:”74″;s:9:”text”;s:1:”存储内容区”;}
内层的 substring_index 用于取得 ” 第4次出现以前的内容
“picid”;s:2:”74
外层的 substring_index 用于取得 ” 最后一次出现以后的内容
74


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:查询二张表并输出
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址