我正在使用 SQl CLR 来解析某些表列。我也想在 C# 用户定义函数中执行查询。有人可以举例说明在函数中执行选择和插入查询吗?
提前谢谢你。
SqlConnection objSqlConn;
string connString = string.Empty;
connString = "Data Source=(local);Initial Catalog=DB;User ID=uname;pwd=pass;Password=pass";
objSqlConn = new SqlConnection(connString);
objSqlConn.Open();
string query = "Select count(*) FROM [DB].[dbo].[TableName]";
SqlCommand cmdTotalCount = new SqlCommand(query, objSqlConn);
cmdTotalCount.CommandTimeout = 0;
string TotalCountValue = cmdTotalCount.ExecuteScalar().ToString();
return TotalCountValue;
最佳答案
在 CLR 中,您可以使用现有连接来运行查询。
简单,返回数据给客户端:
var cmd = new SqlCommand("select * from [table]");
SqlContext.Pipe.ExecuteAndSend(cmd);
通过 SqlDataReader 返回数据:
var con = new SqlConnection("context connection=true"); // using existing CLR context connection
var cmd = new SqlCommand("select * from table", con);
con.Open();
var rdr = cmd.ExecuteReader();
SqlContext.Pipe.Send(rdr);
rdr.Close();
con.Close();
运行其他命令:
var con = new SqlConnection("context connection=true"); // using existing CLR context connection
var cmd = new SqlCommand("insert into [table] values ('ahoj')", con);
con.Open();
var rsa = cmd.ExecuteNonQuery();
con.Close();
关于c# - 使用 CLR 在 C# 中执行 SQl 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12951661/