Листинг кода C# для BatchQueryFindAnEmp
В нижеследующем образце создается BatchQueryFindAnEmp.
private void BatchQueryFindAnEmp_Click(System.Object sender, System.EventArgs e)
{
server.sql_endpoint proxy = new server.sql_endpoint ();
proxy.Credentials = System.Net.CredentialCache.DefaultCredentials;
listBox1.Items.Add ("1) Executing batch. ");
listBox1.Items.Add ("");
NativeSOAPApp1.server.SqlParameter[] p = new NativeSOAPApp1.server.SqlParameter[1];
p[0] = new NativeSOAPApp1.server.SqlParameter ();
p[0].name = "x";
p[0].Value = textBox1.Text;
p[0].maxLength = 20;
p[0].sqlDbType = NativeSOAPApp1.server.SqlDbType.Int;
p[0].direction = NativeSOAPApp1.server.ParameterDirection.Input;
if (textBox1.Text == "NULL" || textBox1.Text == "null")
p[0].Value = null;
string s = "SELECT EmployeeID, FirstName, LastName " + "FROM Employee Where EmployeeID=@x " + "FOR XML AUTO;";
object[] results = proxy.sqlbatch (s, ref p);// proxy.sqlbatch(s);
for (int j = 0; j < results.Length; j++)
{
object e1;
server.SqlMessage errorMessage;
System.Xml.XmlElement xmlResult;
//System.Data.DataSet resultDS;
e1 = results[j];
//return value from SP is an int
if (e1.GetType ().IsPrimitive)
{
listBox1.Items.Add ("Return code = ");
listBox1.Items.Add (e1);
}
switch (e1.ToString ())
{
case "NativeSOAPApp1.server.SqlRowCount":
listBox1.Items.Add (e1.ToString ());
listBox1.Items.Add (((NativeSOAPApp1.server.SqlRowCount)results[j]).Count);
break;
case "System.Xml.XmlElement":
xmlResult = (System.Xml.XmlElement)results[j];
listBox1.Items.Add (xmlResult.OuterXml);
break;
case "NativeSOAPApp1.server.SqlMessage":
errorMessage = (server.SqlMessage)results[j];
listBox1.Items.Add (errorMessage.Message);
listBox1.Items.Add (errorMessage.Source);
break;
}
}
}
См. также
Справочник
Отправка SOAP-запросов с использованием клиента Visual Studio 2005 (C#)