查询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张表的内容呢?
输出结果如何为:
Array
(
[0] => Array
(
[id] => 1
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
[1] => Array
(
[id] => 2
[name] => 栏目一
[url] => 图片路径
[info] => info中text的内容
)
....
回复讨论(解决方案)
直接sql不好查,建议用程序来实现。
直接sql不好查,建议用程序来实现。
怎么弄呢
a:{s:6:"picid";s:2:"74";s:9:"text";s:1:"存储内容区";} 这个序列化后的串吧,不过不对。
首先通过查询获取到了A表info中picid的id号为74,75的数组
这个又是怎么来的,栏目一不是只有74 吗?
首先通过查询获取到了A表info中picid的id号为74,75的数组
这个又是怎么来的,栏目一不是只有74 吗?
少打个..略了刚刚
a:{s:6:"picid";s:2:"74";s:9:"text";s:1:"存储内容区";} 这个序列化后的串吧,不过不对。
我没复制完全
查询两次,你用的json连表查询不行的。
取出 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
上一篇: php中禁止危险php函数的例子
推荐阅读
-
查询sqlserver所有表并改变其架构
-
mysql实现查询数据并根据条件更新到另一张表的方法示例
-
创建一个存储过程,以部门号为参数,查询该部门的平均工资,并输出该部门中比平均工资高的员工号、员工名。并且调用该存储过程,要求根据输入部门编号,查询平均工资及输出比平均工资高的员工号、员工名
-
DM数据库表中的CLOB字段,使用ajax查询并显示结果时无法获取该字段值
-
mysql 查询 两个表中不同字段的 和,并通过两个表的时间来分组
-
Mysql 如何实现多张无关联表查询数据并分页
-
使用jdbc原生态手写statement连接数据库并查询某一张表
-
手把手教你使用C#连接并操作数据库SQLite,创建数据库,创建表,插入INSERT,查询SELECT,删除DELETE(持续更新)
-
查询sqlserver所有表并改变其架构
-
查询二张表并输出