public class User { public string FirstName { get; set; } public string LastName { get; set; } } public class Address { public string City { get; set; } public string Country { get; set; } } /* * There are 2 c# objects i have shown * There is a stored procedure in my application which * returns data for both objects simultaneously * eg * select FirstName,LasteName from Users where something="xyz" * select City,Country from Locations where something="xyz" * * both queries are run by single procedure * Now how can i fill both objects with from that stored procedure in asp.net using c# */
解决方法
使用ADO.NET,在使用参数执行SP的sqlCommand对象上打开sqlDataReader.使用sqlDataReader.NextResult方法获取第二个结果集.
基本上:
sqlConnection cn = new sqlConnection("<ConnectionString>"); cn.open(); sqlCommand Cmd = new sqlCommand("<StoredProcedureName>",cn); Cmd.CommandType = System.Data.CommandType.StoredProcedure; sqlDataReader dr = Cmd.ExecuteReader(CommandBehavior.CloseConnection); while ( dr.Read() ) { // populate your first object } dr.NextResult(); while ( dr.Read() ) { // populate your second object } dr.Close();