字符串不重复拼接法?
高洛峰
高洛峰 2016-11-10 15:24:25
0
2
761

比如有以下数据表结构
id  lei    shuxing  miaoshu
1   大象    眼睛       大大的
2   大象    眼睛       圆圆的
3   大象    鼻子       高高的
4   熊      鼻子       小小的
5   大象    腿         长长的
6   熊      腿         细细的
7   大象    嘴         小小的

第二列和第三列和第四列都可能有n多种情况,求一个能实现出以下要求组合的php方法,要求是每个描述是一个lei,涵盖shuxing中的3项(不够三项有几个算几个比如熊),以生成对某个动物的不同描述

举例说明:按以上数据的结果应该是

大象   眼睛大大的,鼻子高高的,腿长长的
大象   眼睛圆圆的,鼻子高高的,腿长长的
大象   眼睛大大的,鼻子高高的,嘴小小的
。。。
由于能组合出不少,就没法一一列出了,通过以上的例子希望朋友们能理解


高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

Antworte allen(2)
学霸

其实还是没太看懂题主到底是问php问题还是sql问题。不过感觉sql并不擅长解决这类问题,那我就假设是编程问题吧。

由于不懂php,所以仅提供解题思路:1、根据lei查询所有符合条件的数据,例如:

SELECT lei, shuxing, miaoshu FROM animal
WHERE lei IN ('大象', '熊');

2、在代码里先后对lei属性和shuxing属性做group by操作,如下:

{
    "大象": {
        "眼睛": ["大大的", "圆圆的"],
        "鼻子": ["高高的"],
        "腿": ["长长的"],
        "嘴": ["小小的"]
    },
    "熊": {
        ...
    }
}

3、对2中的数据进行笛卡尔积运算,done.

PS:其实是表结构设计得不好,应该拆分成animal表(animal_id, animal_name)和animal_prop表(animal_prop_id, animal_id, prop_name, prop_desc)。


三叔

可以采用分表,分成三张表。table1:用来记录lei的信息   table2:用来记录shuxing,table1的ID   table3:

用来记录miaoshu,table2的ID,用着三张表进行关联查询


Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage