0

我已经阅读了几乎所有与我的查询相关的其他帖子,但找不到明确的答案 - 如果这已经得到回答,我深表歉意。

基本上我有一个产品表和一个图像表,一个产品可以有很多图像。据我了解,与运行多个查询相比,使用单个查询获取所有数据在性能方面会更好。

我目前正在使用一个左连接查询,它工作得很好,但对我来说似乎效率低下。

我的结果集有很多重复数据(我知道这就是我要的),并且是由于“产品”表包含 50 个(ish)列,而“图像”表只有 3 列,所以我的结果集看起来像这个:

P_ID    P_NAME    P_DESC   -->(rest of product data)    I_ID    I_PATH    I_THUMB
001     a.prod    'This is a product'                   001-01  /a1.jpg   /a1t.jpg
001     a.prod    'This is a product'                   001-02  /a2.jpg   /a2t.jpg
001     a.prod    'This is a product'                   001-03  /a3.jpg   /a3t.jpg
001     a.prod    'This is a product'                   001-04  /a4.jpg   /a4t.jpg

I_ID 是 images 表中的主键,是“products”表中的一列,表之间存在关系。

有些产品可以有 10 或 15 张图像,这些图像将复制“产品”信息 10 或 15 次,对我来说这似乎是错误的。在不必要的时候拥有如此多的重复数据。

我想我真正要问的是:这是最好的方法还是我应该有 2 个查询 1 来根据它的 ID 查找产品,然后另一个来查找与查询 1 中的产品相关的图像。

我期待一对多的关系会返回如下内容:

P_ID    P_NAME    P_DESC   -->(rest of product data)    I_ID    I_PATH    I_THUMB
001     a.prod    'This is a product'                   001-01  /a1.jpg   /a1t.jpg
NULL    NULL      NULL                                  001-02  /a2.jpg   /a2t.jpg
NULL    NULL      NULL                                  001-03  /a3.jpg   /a3t.jpg
NULL    NULL      NULL                                  001-04  /a4.jpg   /a4t.jpg

我还认为最好得到一个多维数组,它看起来像:

$resultset = array(
    'P_ID'=>'001', 
    'P_NAME'=>'a.prod',
    'P_DESC'=>'This is a product'
    (rest of product data) 
    'IMAGES'=>array(
        [0] => Array(
            'I_ID'=>'001-01',
            'I_PATH'=>'/a1.jpg', 
            'I_THUMB'=>'/a1t.jpg')
        [1] => Array(
             'I_ID'=>'001-02',
             'I_PATH'=>'/a2.jpg', 
             'I_THUMB'=>'/a2t.jpg')
        [2] => Array(
             'I_ID'=>'001-03',
             'I_PATH'=>'/a3.jpg', 
             'I_THUMB'=>'/a3t.jpg')
        [3] => Array(
             'I_ID'=>'001-04',
             'I_PATH'=>'/a4.jpg', 
             'I_THUMB'=>'/a4t.jpg')
    )
);

但是我一辈子都无法弄清楚如何像这样取回数据-请帮助

4

1 回答 1

0

听起来您应该使用 2 个单独的查询。一个返回产品信息,一个返回图像。否则,您的查询将始终重复它匹配的每个图像的产品表中的信息。只要该P_ID字段在每个表中都有索引,性能就不应该成为问题。

于 2014-05-28T12:51:37.047 回答