Subsonic 与多个字段的内部联接

Subsonic 与多个字段的内部联接,subsonic,inner-join,Subsonic,Inner Join,精确到使用内部联接执行选择,该联接在表中的多个字段中具有关系 例如: DataSet dt = new Select().From(SubConta.Schema) .InnerJoin(PlanoContabilSubConta.EmpSubContaColumn, SubConta.CodEmpColumn) .InnerJoin(PlanoContabilSubConta.FilSubContaColumn, SubConta.CodFilColumn

精确到使用内部联接执行选择,该联接在表中的多个字段中具有关系

例如:

 DataSet dt = new Select().From(SubConta.Schema)
         .InnerJoin(PlanoContabilSubConta.EmpSubContaColumn, SubConta.CodEmpColumn)
         .InnerJoin(PlanoContabilSubConta.FilSubContaColumn, SubConta.CodFilColumn)
         .InnerJoin(PlanoContabilSubConta.SubContaColumn, SubConta.TradutorColumn)
         .Where(PlanoContabilSubConta.Columns.EmpContabil).IsEqualTo(cEmp)
         .And(PlanoContabilSubConta.Columns.FilContabil).IsEqualTo(cFil)
         .And(PlanoContabilSubConta.Columns.Conta).IsEqualTo(cTrad)
         .ExecuteDataSet();
但生成的sql是错误的:

exec sp_executesql N'/* GetDataSet() */ SELECT [dbo].[SubContas].[CodEmp], [dbo].[SubContas].[CodFil], [dbo].[SubContas].[Tradutor], [dbo].[SubContas].[Descricao], [dbo].[SubContas].[Inativa], [dbo].[SubContas].[DataImplantacao]

 FROM [dbo].[SubContas]
 INNER JOIN [dbo].[PlanoContabilSubContas] ON [dbo].[SubContas].[CodEmp] = [dbo].[PlanoContabilSubContas].[EmpSubConta]
 INNER JOIN [dbo].[PlanoContabilSubContas] ON [dbo].[SubContas].[CodFil] = [dbo].[PlanoContabilSubContas].[FilSubConta]
 INNER JOIN [dbo].[PlanoContabilSubContas] ON [dbo].[SubContas].[Tradutor] = [dbo].[PlanoContabilSubContas].[SubConta]
 WHERE EmpContabil = @EmpContabil0
 AND FilContabil = @FilContabil1
 AND Conta = @Conta2
',N'@EmpContabil0 varchar(1),@FilContabil1 varchar(1),@Conta2 varchar(1)',@EmpContabil0='1',@FilContabil1='1',@Conta2='1'
应该如何生成此sql

exec sp_executesql N'/* GetDataSet() */ SELECT [dbo].[SubContas].[CodEmp], [dbo].[SubContas].[CodFil], [dbo].[SubContas].[Tradutor], [dbo].[SubContas].[Descricao], [dbo].[SubContas].[Inativa], [dbo].[SubContas].[DataImplantacao]

     FROM [dbo].[SubContas]
     INNER JOIN [dbo].[PlanoContabilSubContas] ON [dbo].[SubContas].[CodEmp] = [dbo].[PlanoContabilSubContas].[EmpSubConta] AND
     [dbo].[SubContas].[CodFil] = [dbo].[PlanoContabilSubContas].[FilSubConta] AND
     [dbo].[SubContas].[Tradutor] = [dbo].[PlanoContabilSubContas].[SubConta]
     WHERE EmpContabil = @EmpContabil0
     AND FilContabil = @FilContabil1
     AND Conta = @Conta2
    ',N'@EmpContabil0 varchar(1),@FilContabil1 varchar(1),@Conta2 varchar(1)',@EmpContabil0='1',@FilContabil1='1',@Conta2='1'

看起来您无法在亚音速2中连接多个列,您可以创建一个SQL视图,该视图可以按照您的需要进行连接,然后让亚音速为该视图生成一个模型