@vouchid varchar(1000)=''   //这是我从前台输入的参数
//我想声明一个游标 DECLARE cursor_for CURSOR FOR
 select * from t where id in ( @vouchid ) //但是这样写是不对的,因为@vouchid是字符类型的应该怎样写才对

解决方案 »

  1.   

    @vouchid='1,2,3,4'  //这种形式的
    id是整型变量
      

  2.   

    可以先把@vouchid 中的id列表通过一个自己写的自定义函数转换成一个含各个ID的表。
      

  3.   

    /*
    StringToTable
    */
    CREATE FUNCTION StringToTable(@StringX varchar(8000),@Split nvarchar(10))
    RETURNS @TableResult TABLE(TableID nvarchar(20))
    AS  
    BEGIN 
    DECLARE @Index int
    SET @Index=CHARINDEX(@Split,@StringX,1)
    WHILE (@Index>=1)
    BEGIN
    INSERT INTO @TableResult SELECT LEFT(@StringX,@Index-1)
    SELECT @StringX=RIGHT(@StringX,LEN(@StringX)-@Index),@Index=CHARINDEX(@Split,@StringX,1)
    END
    IF(@StringX<>'') INSERT INTO @TableResult SELECT @StringX
    RETURN 
    END
    这是我写一个有含id列表转成表格式,如'1,2,3,4,5,6'能转成
    id
    ---------------
    1
    2
    3
    4
    5
    6
    这样一个表格式。
      

  4.   

    因为你使用DECLARE cursor_for CURSOR FOR
    所以个人认为使用我的那自定义函数还是不错的。以前我也碰到这样的问题,就这样的解决。从性能考虑还是感觉不错的。