我正在开发 .cs 代码以从存储过程中获取数据并将其存储到列表中,但我无法将所有数据集都添加到列表中。
SP:
ALTER PROCEDURE [_testSchm].[_test_sp]
@paramINint int,
@paramINnvarchar nvarchar(max),
@paramOUTint int OUTPUT,
@paramOUTnvarchar nvarchar(max) OUTPUT
AS
set @paramOUTint = @paramINint * 33
set @paramOUTnvarchar = REVERSE(@paramINnvarchar)
select 666 as ResultSet1
select 999 as ResultSet1
return 401
我定义的类以填充 .cs 代码中的列表:
public class readerSQL
{
public int paramOUTint { get; set; } //esto es de prueba y si, se devuelve a cliente con el valor null porque el SP no lo rellena a su llamada
public string paramOUTnvarchar { get; set; }
public int ResultSet1 { get; set; }
public int ReturnValue { get; set; }
}
.cs 代码:
var paramINint = 3;
var paramINnvarchar = "carlos";
var paramOUTint = 0;
var paramOUTnvarchar = "";
object[] testJSONParameters = new object[] { paramINint, paramINnvarchar, paramOUTint, paramOUTnvarchar };
IDataReader petaReaderTest = PetaPocoHelper.ExecuteReader(
DataProvider.Instance().ConnectionString,
CommandType.StoredProcedure,
"_testSchm._test_sp",
testJSONParameters
);
var ReturnJSON = CBO.FillCollection<readerSQL>(petaReaderTest);
ReturnJSON 只返回这个:
<ArrayOfreaderSQL>
<readerSQL>
<ResultSet1>666</ResultSet1>
<ReturnValue>0</ReturnValue>
<paramOUTint>0</paramOUTint>
<paramOUTnvarchar i:nil="true"/>
</readerSQL>
</ArrayOfreaderSQL>
SQL 管理工作室返回的内容:
ColName : ResultSet1
Value : 666
---------------------
ColName : ResultSet1
Value : 999
----------------
ColName : @paramOUTint ||| @paramOUTnvarchar
Value : 99 ||| solrac
-----------------
ColName : Return Value
Value : 401
我想以 json 的形式返回(或类似的):
<ArrayOfreaderSQL>
<readerSQL>
<ResultSet1>666</ResultSet1>
<ReturnValue>0</ReturnValue>
<paramOUTint i:nil="true"/>
<paramOUTnvarchar i:nil="true"/>
</readerSQL>
<readerSQL>
<ResultSet1>999</ResultSet1>
<ReturnValue>0</ReturnValue>
<paramOUTint i:nil="true"/>
<paramOUTnvarchar i:nil="true"/>
</readerSQL>
<readerSQL>
<ResultSet1>0</ResultSet1>
<ReturnValue>0</ReturnValue>
<paramOUTint>99</paramOUTint>
<paramOUTnvarchar>solrac</paramOUTnvarchar>
</readerSQL>
<readerSQL>
<ResultSet1>0</ResultSet1>
<ReturnValue>401</ReturnValue>
<paramOUTint i:nil="true"/>
<paramOUTnvarchar i:nil="true"/>
</readerSQL>
</ArrayOfreaderSQL>