suchen

Heim  >  Fragen und Antworten  >  Hauptteil

字符串不重复拼接法?

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

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

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

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


高洛峰高洛峰3021 Tage vor805

Antworte allen(2)Ich werde antworten

  • 欧阳克

    欧阳克2016-11-10 15:25:57

    其实还是没太看懂题主到底是问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)。


    Antwort
    0
  • 三叔

    三叔2016-11-10 15:25:02

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

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


    Antwort
    0
  • StornierenAntwort