SQL Incorrect syntax near 错误

本文分享了在使用SQL语句进行Top数据查询时遇到的参数使用问题,通过加入括号的方式成功解决问题。对于初学者来说,这是一次很好的实践和学习机会。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

案例分析:在我进行Top数据查询的时候用到如下SQL语句,

select top @TopCount * from  MD_DataCubeDataDetail2(nolock) 
 Where 1=1  and seqno>=@BeginSeqno and seqno<@EndSeqno and PlanCode=@PlanCode and ReadKey=@ReadKey

运行显示如下错误:

Incorrect syntax near ‘@TopCount’.

说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Data.SqlClient.SqlException: Incorrect syntax near ‘@TopCount’.
看来SQL语句有问题,我就一直在寻找,这些参数是有SqlParameter集合提供,如果我直接用数值代替这些参数,则程序能够正确运行,看来的确出自End和start的错误,经过不断的调试,和大胆的推测,最后在参数加入了括号,问题解决啦。SQL语句如下:

select top (@TopCount) * from  MD_DataCubeDataDetail2(nolock) 
 Where 1=1  and seqno>=@BeginSeqno and seqno<@EndSeqno and PlanCode=@PlanCode and ReadKey=@ReadKey

希望以上分享对初学朋友有些帮助,谢谢!
更多关注付义方技术博客:http://blog.youkuaiyun.com/fuyifang
或者直接用手机扫描二维码查看更多博文:
付义方优快云博客二维码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值