案例分析:在我进行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.csdn.net/fuyifang
或者直接用手机扫描二维码查看更多博文: