0

有什么方法可以合并 2 选择,这两个选择都返回单独的数据列表

我想要做的就是连接到数据库一次

第一个查询:

string strQuery1=
    string.Format("SELECT distinct top 10   Title,  Id FROM Table1");
IQueryable<MyCompanyDto> list =
                    _entities.Database.SqlQuery<MyCompanyDto>(strQuery1).AsQueryable();

第二个查询:

string strQuery2=
        string.Format("SELECT   ProductName,  CountryID FROM Table2");
    IQueryable<MyProductDto> list =
                        _entities.Database.SqlQuery<MyProductDto>(strQuery2).AsQueryable();
4

1 回答 1

0

可以为两个查询连接一次,但您必须创建两个DbCommand

string strQuery1= string.Format("SELECT distinct top 10   Title,  Id FROM Table1");
string strQuery2= string.Format("SELECT   ProductName,  CountryID FROM Table2");

DataTable dataTable1 =  new DataTable();
DataTable dataTable2 =  new DataTable();

using (SqlConnection conn =  new SqlConnection(<connection_string>))
{
    conn.Open();

    using(DbCommand command = conn.CreateCommand())
    {
       command.Connection = conn;
       command.CommandText = strQuery1;

       using (var reader = dbCommand.ExecuteReader())
       { 
          dataTable1.Load(reader);
       }
    }
    using(DbCommand command = conn.CreateCommand())
    {
       command.Connection = conn;
       command.CommandText = strQuery2;

       using (var reader = dbCommand.ExecuteReader())
       { 
          dataTable2.Load(reader);
       }
    }
 }
于 2020-03-12T15:00:46.593 回答