php 循环加,PHP对等循环,在线等,在加100分

这篇博客探讨了如何在PHP+MySQL环境中,当数据表结构不确定,可能存在尺码、颜色、图案等多个变量时,如何实现动态循环输出。作者提出通过创建临时表并结合笛卡尔积的方法来处理不同数量的数组,但遇到循环实现的困难。文章中提供了示例代码,并寻求解决方案。
摘要由CSDN通过智能技术生成

csdn 无法上传图片,数据表结构图片看百度知道吧

http://zhidao.baidu.com/question/1047510947746416459.html

这是我的数据表结构,PHP+MYSQL 。我想实现出循环这样的效果

尺码 颜色 图案

36 红色 印花

36 红色 平板

36 白色 印花

36 白色 平板

36 黑色 印花

36 白色 平板

37 红色 印花

37 红色 平板

依次类推, 但是尺码、颜色、图案 并不是固定的,有可能 只有两个 如

尺码 颜色

36 红色

36 白色

36 黑色

37 红色

37 白色

。。。。。。 等

也有可能有4个 如 尺码 、颜色、图案、其它

这样用表格的格式循环 要怎么循环啊。。。我现在用FOR可以循环出来,但是只能是固定的,不能自由选择。

回复讨论(解决方案)

你的尺码 、颜色、图案 的值都是在一个字段里的吗?用什么分隔的?数据类型是什么?

看看这个测试例,你应该会知道怎么做了create temporary table a (`尺码` varchar(10)) charset gbk;insert into a values (36),(37);create temporary table b (`颜色` varchar(10)) charset gbk;insert into b values ('红'),('白'),('蓝'),('黑');create temporary table c (`图案` varchar(10)) charset gbk;insert into c values ('印花'),('平板');select * from a,b,c; 尺码 颜色 图案 36 红 印花 37 红 印花 36 红 平板 37 红 平板 36 白 印花 37 白 印花 36 白 平板 37 白 平板 36 蓝 印花 37 蓝 印花 36 蓝 平板 37 蓝 平板 36 黑 印花 37 黑 印花 36 黑 平板 37 黑 平板

针对每个产品,首先把有的列出来。

例如尺码、颜色、图案 则会有3个数组, size,color,pattern。

例如尺码、颜色则只有两个数组。

然后循环。

你的尺码 、颜色、图案 的值都是在一个字段里的吗?用什么分隔的?数据类型是什么?

尺码 颜色 图案 分别在三条记录里。比如 尺码的所有值都在一个字段里 用 \n 分开的

针对每个产品,首先把有的列出来。

例如尺码、颜色、图案 则会有3个数组, size,color,pattern。

例如尺码、颜色则只有两个数组。

然后循环。

现在可以分为三个数组了,但是我就是不会循环啊

例$ar = array( array( "A", "B", "C"), array("1", "2", "3", "4"), array("X", "Y", "Z"),);print_rDescartes($ar));function Descartes($d) { $r = array_pop($d); while($d) { $t = array(); $s = array_pop($d); if(! is_array($s)) $s = array($s); foreach($s as $x) { foreach($r as $y) $t[] = array_merge(array($x), is_array($y) ? $y : array($y)); } $r = $t; } return $r;}

例$ar = array( array( "A", "B", "C"), array("1", "2", "3", "4"), array("X", "Y", "Z"),);print_rDescartes($ar));function Descartes($d) { $r = array_pop($d); while($d) { $t = array(); $s = array_pop($d); if(! is_array($s)) $s = array($s); foreach($s as $x) { foreach($r as $y) $t[] = array_merge(array($x), is_array($y) ? $y : array($y)); } $r = $t; } return $r;}

分都给您了。谢谢您帮了我

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值