3

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

3 回答 3

12

在 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();
于 2013-02-28T15:46:36.380 回答
0

一旦切换到 C#,您就可以像通常在应用程序中那样执行查询(使用 ADO.NET 的 SqlConnection 和 SqlDataReader,使用 LINQ to SQL 或使用您的自定义构建数据层)。

于 2012-10-18T09:45:03.177 回答
-2

要连接数据库,您必须在 web.config 文件的连接字符串中提及数据库用户名和密码。

于 2012-10-18T10:16:19.493 回答