1 普通sql语句可以用exec执行,如:

SELECT * FROM video

EXEC ('SELECT * FROM video')

EXEC sp_executesql N'SELECT * FROM video' --字符串前一定要加N

2 字段名,表名,数据库名之类作为变量时,必须用动态sql

DECLARE @fname NVARCHAR()
SET @fname = 'Name'
SELECT @fname FROM Video
--以上结果为Name,并非所要

可以使用这样动态拼接:

EXEC(' select ' + @fname + ' from video')--注意加号前后的单引号都加上空格
--当然将字符串形式改成变量也可以
DECLARE @sql NVARCHAR(MAX)
DECLARE @fname NVARCHAR()
SET @fname = '[SeoFilename]'
set @sql = 'SELECT ' + @fname + ' FROM Video AS v'
EXEC (@sql)--一定要记得这个小括号 ,这里的@sql是varchar类型可以

注意:也可以使用 exec sp_executesql 形式

EXEC sp_executesql @sql -- 注意:@sql必须是ntext,nchar,nvarchar类型,不可以是varchar类型         

3 输入或者输出参数

动态查询语句变量:必须为ntext,nchar,nvarchar类型

设置动态语句中的查询字符串,必须为ntext,nchar,nvarchar类型

declare @input_id int--定义需传入动态语句的参数的值,参数1
declare @input_name varchar()--定义需传入动态语句的参数的值,参数2
DECLARE @QueryString NVARCHAR(MAX)--动态语句变量
DECLARE @paramstring NVARCHAR()--设置动态语句中的动态字符串参数
-- --
set @QueryString='select * from Video where id=@id and SeoFilename=@name' --id与name为字段名,@id与@name为要传入的参数
set @paramstring='@id int,@name varchar(20)' --设置动态语句中参数的定义的字符串,多个参数用"
-- set @input_id = --设置需传入动态语句的参数的值为1
set @input_name='新增视频一' --设置需传入动态语句的参数的值为"张三"
exec sp_executesql @querystring,@paramstring,@id=@input_id,@name=@input_name --请注意参数的顺序

4 输出参数

DECLARE @num INT,@sql NVARCHAR(MAX)
SET @sql = 'select count(1) from Video'
EXEC(@sql)

如何将总数的结果返回给一个变量呢?

DECLARE @QueryString NVARCHAR(MAX)
DECLARE @ParamString NVARCHAR()
DECLARE @output_result INT --查询结果返回给它 SET @QueryString = ' select @totalcount = count(1) from video '--定义@totalcount为输出结果参数
SET @ParamString = ' @totalcount int output ' EXEC sp_executesql @QueryString,@ParamString,@totalcount = @output_result OUTPUT
SELECT @output_result AS '返回总数'

另外,动态语句查询的结果集要输出的话,可以使用临时表的方法

先判断临时表是否存在

   IF object_id('[tempdb].[dbo].#tmp') IS NOT NULL --判断临时表#tmp是否存在,存在则删除
drop table #tmp

  IF object_id('[tempdb].[dbo].#tmp') IS NOT NULL --判断临时表#tmp是否存在,存在则删除
  drop table #tmp

  SELECT * INTO #tmp FROM Video AS v

  SELECT * FROM #tmp AS t


sqlserver数据库中用到的Identity列

当表中被删除了某些数据,自增长的编号就不再是一个连线的数据

可以使用 SET IDENTITY_INSERT Video ON
允许将显式值插入到表的标示列中,当设置为on,这时可能在insert 操作时候手动指定插入到标示列中的序号,,同时必须在完成操作后,将IDENTITY_INSERT 还原成off
否则,下次插入的时候必须指定编号,不然就无法完成Insert操作

当表中的记录被全部删除,但此时标示列的值很大很大,如果不重置,会无休止的增长,这个时候可以用:DBCC CHECKIDENT(Video, [RESEED|NORESEED], [1]) 进行重置

--重置表中标识列中种子值
DBCC CHECKIDENT(Video, [RESEED|NORESEED], []) --获取当前表中标示列的种子值
DBCC CHECKIDENT(Video,NORESEED)

动态sql语句基本语法的更多相关文章

  1. 动态sql语句基本语法--Exec与Exec sp_executesql 的区别

    http://www.cnblogs.com/goody9807/archive/2010/10/19/1855697.html 动态sql语句基本语法 1   :普通SQL语句可以用Exec执行   ...

  2. [SQL]动态sql语句基本语法

    动态sql语句基本语法 :普通SQL语句可以用Exec执行 eg: Select * from tableName Exec('select * from tableName') Exec sp_ex ...

  3. MyBatis学习总结_11_MyBatis动态Sql语句

    MyBatis中对数据库的操作,有时要带一些条件,因此动态SQL语句非常有必要,下面就主要来讲讲几个常用的动态SQL语句的语法 MyBatis中用于实现动态SQL的元素主要有: if choose(w ...

  4. MySQL基础----动态SQL语句

    尊重原创:http://blog.csdn.net/abc19900828/article/details/39501643   动态sql语句基本语法 1 :普通SQL语句可以用Exec执行 eg: ...

  5. MyBatis学习总结(11)——MyBatis动态Sql语句

    MyBatis中对数据库的操作,有时要带一些条件,因此动态SQL语句非常有必要,下面就主要来讲讲几个常用的动态SQL语句的语法 MyBatis中用于实现动态SQL的元素主要有: if choose(w ...

  6. mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...

  7. MyBatis学习(三)、动态SQL语句

    三.动态SQL语句 有些时候,sql语句where条件中,需要一些安全判断,例如按某一条件查询时如果传入的参数是空,此时查询出的结果很可能是空的,也许我们需要参数为空时,是查出全部的信息.使用Orac ...

  8. 三、动态SQL语句

    //备注:该博客引自:http://limingnihao.iteye.com/blog/106076 有些时候,sql语句where条件中,需要一些安全判断,例如按某一条件查询时如果传入的参数是空, ...

  9. 存储过程中执行动态Sql语句

    MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...

随机推荐

  1. 时间的函数,sleep,clock,gettickcount,QueryPerformanceCounter(转)

    介绍 我 们在衡量一个函数运行时间,或者判断一个算法的时间效率,或者在程序中我们需要一个定时器,定时执行一个特定的操作,比如在多媒体中,比如在游戏中等,都 会用到时间函数.还比如我们通过记录函数或者算 ...

  2. Linux在向磁盘新建文件的时候在系统层面的四步操作

    ----------- 1.存储文件属性.内核先找到一个空的i节点,并把文件属性信息记录其中.   2.存储数据.先计算要多少个磁盘块,在内核自由块列表找到合适数量的磁盘块,并把数据从内核的缓冲区依次 ...

  3. Codeforces Round #Pi (Div. 2) A. Lineland Mail 水题

    A. Lineland MailTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/567/probl ...

  4. Codeforces Bubble Cup 8 - Finals [Online Mirror] F. Bulbo DP

    F. Bulbo Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/575/problem/F Des ...

  5. Spring生态

    1.简洁有力,干掉了j2ee容器层特别是ejb,spring在rod Johnson十几年前一个人单挑j2ee体系开始,到十年前开始大行其道至今,基本上是java开发领域的事实标准.从此大部分开发者去 ...

  6. Android Mms 接收信息流程

    信息的接收工作是由底层来完成的,当有一个 新的信息时底层完成接收后会以Intent的方式来通知上层应用,信息的相关内容也包含在Intent当中,Android所支持的信息Intent都定 义在andr ...

  7. 使用Jquery+EasyUI进行框架项目开发案例解说之中的一个---员工管理源代码分享

    使用Jquery+EasyUI 进行框架项目开发案例解说之中的一个 员工管理源代码分享 在開始解说之前,我们先来看一下什么是Jquery EasyUI?jQuery EasyUI是一组基于jQuery ...

  8. php 下载远程图片 的几种方法(转)

    1.获取远程文件大小及信息的函数 function getFileSize($url){          $url = parse_url($url);          if($fp = @fso ...

  9. 使用 T4 文本模板生成设计时代码

      使用设计时 T4 文本模板,您可以在 Visual Studio 项目中生成程序代码和其他文件. 通常,您编写一些模板,以便它们根据来自模型的数据来改变所生成的代码. 模型是包含有关应用程序要求的 ...

  10. C++的64位整数

    在做ACM题时,经常都会遇到一些比较大的整数.而常用的内置整数类型常常显得太小了:其中long 和 int 范围是[-2^31,2^31),即-2147483648~2147483647.而unsig ...