c# - 使用 CLR 在 C# 中执行 SQl 查询

标签 c# sql sql-server clr

我正在使用 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/

相关文章:

c# - 在 TFS 服务器上运行的 C# Selenium 测试的持续 HTTP 请求超时

c# - 将 SQL 2008 DB R2 恢复到 SQL 2008(不是 r2)

sql-server - 在 Service Broker 中向服务添加契约(Contract)后

SQL Server 2005 在未知数量的列上进行透视

java - 需要方向 : . setObject 与 .setString 并将列信息从 GUI 保存到数据库

sql - 使用 SQL 插入基于 QUERY 的记录数

c# - P/Invoke问题(栈不平衡)

c# - ReactiveExtensions Observable FromAsync 调用两次函数

sql - 错误: column must appear in the GROUP BY clause or be used in an aggregate function

mysql - 使用 mysql 在一个查询中从多个表中删除行