我在 SQL 中创建了一个函数,现在我需要在我的 C# 应用程序中使用该函数。
我尝试使用这样的东西,但似乎我做错了,因为我得到:
Must declare the scalar value '@2064734117'
...当我2064734117
作为第一个参数和1
第二个参数给出时。这是我正在谈论的代码:
SqlConnection con = new SqlConnection(clsDb.connectionString);
string query = string.Format("select Function1(@{0},@{1}) ",
int.Parse(e.CurrentRow.Cells["CodeMeli"].Value.ToString()),1);
con.Open();
SqlCommand cmd = new SqlCommand(query,con);
SqlDataAdapter READER = new SqlDataAdapter();
READER.SelectCommand = cmd;
DataTable table = new DataTable();
READER.Fill(table);
radGridView1.DataSource = table;
con.Close();
我的函数接受两个整数参数并返回一个表。我在 Visual Studio 中检查了它,它工作正常,但我无法让它在我的应用程序中工作。
这是我的函数声明:
ALTER FUNCTION dbo.Function1
(
/*
@parameter1 int = 5,
@parameter2 datatype
*/
@ID int,
@clsTypeID int
)
RETURNS TABLE/* @table_variable TABLE (column1 datatype, column2 datatype) */
AS
/*BEGIN */
/* INSERT INTO @table_variable
SELECT ... FROM ... */
RETURN SELECT * FROM tblCLASS2
WHERE STNID = @ID AND CLASSTYPEID = @clsTypeID
/*END */
/*GO*/