• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    动态SQL语句使用心得
    在我们的项目中经常需要用到分面功能,而我以前呢用的方法现在看起来都是那麽的笨拙,当时是这样做的,每当要进行数据分页时就专们针对那个表做分页,大家别笑,以前确实好笨。呵呵,虽然当时也有一个想法就是希望能够传入一张表进去进行操作,但那样的话编译是通不过的,因为FROM后面操作的是表变量,而不能是我们自定义的变量,所以当时没有深追究,现在为当时不深入学习而BS一下。

    动态SQL需要准备以下内容:

    1、@SQL 拼接后的SQL语句,可以是你任意需要的SQL语句如:SET @SQL='SELECT * FROM table WHERE ID=@id' 注意此处的@SQL必须且只能是NTEXT、NVARCHAR、NCHAR类型,如果是其它类型的话其它地方明明没有问题却会报 "过程需要类型为 'ntext/nchar/nvarchar' 的参数"这个错误。同时,如果这里需要传入表名称的话则应这样写:SET @SQL='SELECT * FROM '+@table+'WHERE ID=@id' ,因为上面传入的值是文本类型故会报错。

    2、@parameters 所拼接的SQL语句里面的参数,按上面的话这里应该是:SET @parameters='@id INT' 同时这个参数的类型也必须且只能是NTEXT、NVARCHAR、NCHAR类型
    3、调用:sp_executesql param1(,param2) 其中param1一般我们作为是@SQL,后面的参数则是我们在@sql中的参数了,但这里要注意的是传参的时候必须是对应的:

    复制代码 代码如下:

      DECLARE @InputId INT ;
      SET @InputId=1;
       param2为:@id=@InputId;


    以下是写的一个简单的通用分页,有需要可以自行修改:

    复制代码 代码如下:

    ALTER PROCEDURE sp_pager
    (
    @TableName nvarchar(50), -- 表名
    @ReturnFields nvarchar(200) = '*', -- 需要返回的列
    @PageSize int = 50, -- 每页记录数
    @PageIndex int = 1 -- 当前页码
    )
    AS
    DECLARE @SQL NVARCHAR(1000)
    DECLARE @paramters NVARCHAR(200)
    BEGIN
    SET NOCOUNT ON
    SET @SQL='SELECT '+@ReturnFields+' FROM '+@TableName+' WHERE ID>(SELECT TOP 1 ID FROM (SELECT TOP '+CAST(@PageSize*@PageIndex AS VARCHAR)+' ID FROM '+@TableName+ ' ORDER BY ID )AS A ORDER BY ID DESC)'
    PRINT @SQL
    EXECUTE sp_executesql @SQL,@paramters,@columns=@ReturnFields
    END
    您可能感兴趣的文章:
    • 基于Oracle的高性能动态SQL程序开发
    • 为什么ASP中执行动态SQL总报错误信息?提示语句语法错误
    • 批处理 动态sql
    • sqlserver 支持定位当前页,自定义排序的分页SQL(拒绝动态SQL)
    • 编程经验点滴 动态SQL的拼接技巧
    • oracle中动态SQL使用详细介绍
    • mysql存储过程 在动态SQL内获取返回值的方法详解
    • MySQL 存储过程中执行动态SQL语句的方法
    • mybatis的动态sql详解(精)
    上一篇:sqlserver 统计sql语句大全收藏
    下一篇:将表数据生成Insert脚本 比较好用的生成插入语句的SQL脚本
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    动态SQL语句使用心得 动态,SQL,语句,使用,心得,