【问题标题】:How to write union query in doctrine?如何在学说中编写联合查询?
【发布时间】:2013-10-07 10:09:20
【问题描述】:

我想在学说中使用联合,我搜索了很多但没有成功,这是我在sql中的联合查询,如何在学说中转换这个查询?

select * from (select orderid,tutorialId,points,allow_multiple,question,answer1,image1,correct1,answer2,image2,correct2,answer3,image3,correct3,answer4,image4,correct4,answer5,image5,correct5,'1' as istest,'' as content,'' as media,'' as media_type_id from tutorial_test

union

select orderid,tutorialId,'0' as istest,content,media,media_type_id,'' as points,'' as allow_multiple,'' as question,'' as answer1,'' as image1,'' as correct1,'' as answer2,'' as image2,'' as correct2,'' as answer3,'' as image3,'' as correct3,'' as answer4,'' as image4,'' as correct4,'' as answer5,'' as image5,'' as correct5  from tutorial_elements) a where a. tutorialId = 1 order by orderid asc

这是我的教义查询

    $query  = "SELECT * FROM(SELECT
                    tt.tutorialid
                FROM
                    TutorialTest tt
                UNION 
                SELECT te.tutorialid) tte
                WHERE tte.tutorialid = 1    

    ";
    $qb     = $this->Doctrine->createQuery($query);
    $tutorial_test  = $qb->getResult();

我研究了很多,但没有取得任何成功,如果有人可以提供帮助,在此先感谢数百万。

【问题讨论】:

    标签: mysql orm doctrine-orm doctrine doctrine-query


    【解决方案1】:

    我找到了解决办法

    我们可以将这个查询与 RSM 一起使用,如下所示

    “usman 基本上就是表名和类”

        $rsm = new ResultSetMapping();
        $rsm->addEntityResult('Usmans', 'u');
        $rsm->addFieldResult('u', 'orderid', 'orderid');
        $rsm->addFieldResult('u', 'tutorialId', 'tutorialid');
        $rsm->addFieldResult('u', 'points', 'points');
    
        $query = $this->Doctrine->createNativeQuery('SELECT * FROM usman', $rsm); 
        $tutorial_tests = $query->getResult();
    

    我们可以在没有 ORM 的情况下使用

    $testQuery = "
        select * from (
                select orderid, 
                    tutorialId, 
                    points, 
                    allow_multiple, 
                    question, 
                    answer1, 
                    image1, 
                    correct1, 
                    answer2, 
                    image2, 
                    correct2, 
                    answer3, 
                    image3, 
                    correct3, 
                    answer4, 
                    image4, 
                    correct4, 
                    answer5, 
                    image5, 
                    correct5, 
                    '1' as istest, 
                    '' as content, 
                    '' as media, 
                    '' as media_type_id 
                from tutorial_test
    
                union
    
                select orderid, 
                    tutorialId, 
                    '0' as istest, 
                    content, 
                    media, 
                    media_type_id, 
                    '' as points, 
                    '' as allow_multiple, 
                    '' as question, 
                    '' as answer1, 
                    '' as image1,
                    '' as correct1,
                    '' as answer2,
                    '' as image2,
                    '' as correct2,
                    '' as answer3,
                    '' as image3,
                    '' as correct3,
                    '' as answer4,
                    '' as image4,
                    '' as correct4,
                    '' as answer5,
                    '' as image5,
                    '' as correct5  
                from tutorial_elements
            ) a 
            where a. tutorialId = $tutorial_id 
            order by orderid asc
    ";
    
    $resultSets = $this->Doctrine->getConnection()->fetchAll($testQuery);
    

    【讨论】:

      【解决方案2】:

      对于联合查询有一些规则

      (1) 所有 SELECT 语句具有相同的数据类型和相同的列数

      在您的选择查询中具有不同的数据类型,没有列不匹配。

      所以你找到了问题。

      解决办法

      select orderid, tutorialId, points, allow_multiple, question, answer1, image1, correct1, answer2, image2, correct2, answer3, image3, correct3, answer4, image4, correct4, answer5, image5, correct5,'1' as istest,'' as content,'' as media,'' as media_type_id 
      from tutorial_test 
      
      union
      
      select orderid, tutorialId,'0' as istest, content, media, media_type_id,'' as points,'' as allow_multiple,'' as question,'' as answer1,'' as image1,'' as correct1,'' as answer2,'' as image2,'' as correct2,'' as answer3,'' as image3,'' as correct3,'' as answer4,'' as image4,'' as correct4,'' as answer5,'' as image5,'' as correct5, '1' as istest,'' as content,'' as media,'' as media_type_id  
      from tutorial_elements 
      where a. tutorialId = 1 
      order by orderid asc
      

      【讨论】:

      • 基本上我的 sql 查询非常好,它给了我 sql 的结果,我的问题是我怎样才能用学说语法编写这个查询。
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-01-18
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多