整个情况是这样的:
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张表的内容呢?
输出结果如何为:
Array
(
[0] => Array
(
[id] => 1
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
[1] => Array
(
[id] => 2
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
....
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张表的内容呢?
输出结果如何为:
Array
(
[0] => Array
(
[id] => 1
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
[1] => Array
(
[id] => 2
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
....
解决方案 »
- 响应版主号召,发点入门教学文章 - 简单说下redis主从复制过程以及我发现的一个导致我线上业务出bug的不起眼特性
- Email怎發信table格式
- PHP读文件问题
- 用PHP控制和延长session的有效时间的问题?谢谢
- smarty模板如何为变量附加值,如 smarttemplate中的$tpl->append('name','l4');
- 高手进(低手不要进)问:服务器端能不能获得我的ip地址及电脑名称\组\机器码\...详情见内...
- 看看吧,想改變這种現象!!<marquee>能移動內容,但它移動時有空白(要等全移完后才又重新移)能否不要這中間的空隙。
- 要求能够以Linux系统的密码来识别用户,欢迎高手支招!
- 怎么取得select下拉框的值?
- 微博短链接生成和淘宝客长链接生成
- 关于安装jpgraph的问题,望各位解答一下
- php+mysql写分页问题
这个又是怎么来的,栏目一不是只有74 吗?
a:{s:6:"picid";s:2:"74";s:9:"text";s:1:"存储内容区";} 这个序列化后的串吧,不过不对。
我没复制完全
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