2017-12-27 197 views
0
...... 
..... 

return myDb.myTable.rollgroup.findAll({ 

       attributes : ['ID','GROUPNAME'], 
       where : { 
        id : { 
         $notIn: ? //// how to use subQuery here 
        } 
       } 


       }).then((getResult) => { 

        return getResult; 

       }) 
....... 
....... 

我的原始查詢像這樣:如何正確使用子查詢的續集?

從MYGROUP毫克其中mg.ID不

回答

0
(?從employeegrouprelation EGR其中egr.PID =選擇egr.GROUPID)選擇mg.ID,mg.GROUPNAME

您可以使用sequelize.literal的包裹子查詢:

... 

    id:{ 
     $notIn: sequelize.literal('(select egr.GROUPID from employeegrouprelation egr where egr.PID = ?)') 
     } 

    ... 
+0

它的工作,但正確的方式? – mani

+0

另一種方法是先運行子查詢以返回一個groupid的數組,然後使用第一個結果將其他查詢鏈接到它上面。所以像'return model.findAll({attributes:['groupid'],其中:{groupid:}})。then((result)=> {next查詢使用$ notIn中的結果})''。無論你喜歡什麼。 – Faz

0

另一種方式來做到這一點

myDb.myTable.employeegrouprelation.findAll({ 
     attributes: [egr.GROUPID], 
     where: { 
      egr.PID: ???? 
     } 
    }).then((ids) => { 
     var id = [0] 
     ids.map((id) => { 
     id.push(id.GROUPID) 
     }) 
     return myDb.myTable.rollgroup.findAll({ 
      attributes : ['ID','GROUPNAME'], 
      where : { 
       id : { 
       $notIn: id 
       } 
      } 


     }).then((getResult) => { 

      return getResult; 

     }) 
    })