daniwell 2017-08-18 11:19 采纳率: 50%
浏览 1490
已采纳

数据库创建存储过程后,执行语句出错

数据库为sql 2008

创建存储过程语句
create proc myOrderInfo_1
(
@s_OrderId int ,
@s_totalPrice float,
@s_OrderDate date,
@s_payMode varchar(50)
)
as
begin
set nocount on;
DECLARE @MyParm NVARCHAR(MAX) ,
@sqlcommand NVARCHAR(MAX)

    SET @sqlcommand = 'SELECT [OrderId],
                              [TotalPrice],
                              [OrderDate],
                              [PayMode]
                        FROM [dbo].[OrderInfo] 
                        where 1=1 '
   IF(@s_OrderId IS NOT NULL)
        SET @sqlcommand = cast(@sqlcommand as varchar)+'AND OrderId=@s_OrderId'

    IF(@s_totalPrice IS NOT NULL)
        SET @sqlcommand = cast(@sqlcommand as varchar)+'AND TotalPrice=@s_totalPrice'

    IF(@s_OrderDate IS NOT NULL)
        SET @sqlcommand = cast(@sqlcommand as varchar)+'AND OrderDate>=@s_OrderDate'

   IF(@s_payMode IS NOT NULL)
        SET @sqlcommand = cast(@sqlcommand as varchar)+'AND PayMode>=@s_payMode'

    SET @MyParm= ' @s_OrderId1 int ,
                 @s_totalPrice1 float,
                 @s_OrderDate1 date,
                 @s_payMode1 varchar(50) '


    PRINT @sqlcommand
    EXEC sp_executesql @sqlcommand,@MyParm,
                         @s_OrderId      =    @s_OrderId,
                         @s_totalPrice   =    @s_totalPrice,
                         @s_OrderDate    =    @s_OrderDate,
                         @s_payMode      =    @s_payMode

end

错误:图片说明 想不通哪错了,。。。。求大神解答

  • 写回答

2条回答 默认 最新

  • weixin_39900427 2017-08-18 20:52
    关注

    你 在 AND 前面添加一个空格 就可以了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码