c#如何获取sql语句中@后面的参数名,

例如:sql="select*fromstuwhereusername=@unameandpassword=@pwd";cmd.CommandText=sql;但我想用方... 例如:
sql = "select * from stu where username=@uname and password=@pwd";
cmd.CommandText = sql;
但我想用方法获取sql字符串中@后面的名字,动态获取,而且不固定参数,有的语句为多个参数,因为cmd.parameters.add("@uname","abc")这种方法面局限性了,前面的参数得手动填写,我就是想用循环,自动遍历这些名字,然后传到cmd.parameters.addadd()方法中去。求高手解答。。。
纠正一下,打错一个方法:cmd.parameters.add()多写了个add...
展开
 我来答
sniper2003
2012-05-11 · TA获得超过1882个赞
知道小有建树答主
回答量:775
采纳率:100%
帮助的人:663万
展开全部
sql语句的执行是在数据库端判定的,所以.net没有提供获取的方法。

首先,依照你的需求,计算你取到了@后面的名字,你也不会知道@后面参数的名字是什么类型的,一样会有问题。还有特殊类型中还需要指定长度参数,例如varchar,nvarchar等;

因为sql语句是一个字符串,所以获取的唯一方法就是使用正则。
var pattern = @"@(\S+)";
然后用Match.Result("$1") 循环获取每一个捕获组的数就行了
zly0304302
2012-05-11 · TA获得超过2462个赞
知道小有建树答主
回答量:744
采纳率:0%
帮助的人:605万
展开全部
你可以使用sqlparameters这个类型的数组,
每次循环动态添加,最后清除参数.
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友38b75e5
2012-05-10 · TA获得超过103个赞
知道小有建树答主
回答量:281
采纳率:0%
帮助的人:202万
展开全部
split(sql,'@'.tocharry()) 然后再针对数组中每个元素进行字符串处理,转换为字节的写法忘记了,大体是这样。
追问
难道C#语言中没有自带的方法吗?微软怎么会忽略这么重要的功能。。唉,失望啊。实在没有输入法只有用切割的方法了。。
追答
暂时么有
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
liuxingyusky
推荐于2018-05-09 · TA获得超过241个赞
知道小有建树答主
回答量:281
采纳率:75%
帮助的人:97.7万
展开全部
提供一个完整的例子:
CREATE procedure [dbo].[user_logon]
@userid char(2),
@username nvarchar(50) output

as
declare @s varchar(1000)
begin
select @username=username,@s=userbm from shopuser where userid=@userid
if @username=null
begin
set @username='不存在该用户'
end
else
begin
set @s = 'select bmid +'''+' '+'''+bmmc from xsbm where bmid in ('+@s+')'
exec(@s)
end
end
GO

C#:
SqlCommand cmd = new SqlCommand("user_logon", conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add( new SqlParameter("@shopuserid",SqlDbType.Char,2){Value=tbxUserID.Text.Trim()});
cmd.Parameters.Add( new SqlParameter("@shopusername",SqlDbType.NVarChar, 50){Direction=ParameterDirection.Output} );
SqlDataReader dr = cmd.ExecuteReader();

label5.Text = Convert.ToString(cmd.Parameters["@shopusername"].Value);//显示username

while (dr.Read())
{
cbxKuzi.Items.Add(dr.GetString(0)); //填充登录部门
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式