常用的SQL数据库语句总结
1as 的用处
as可以对表和列取别名
在开发过程中经常遇到开始给某一个的字段去field1的名称,但后来有感觉field1字段指定不确切,于是又把此字段改成了field2,由于开始认 为field1是常量,于是到处使用字符串field1,而且程序中又含有大量对field1的处理, 此时就可以使用as
例如原来的
select field1 from tableA
,改为
select field2 as field1 from tableA
代码基本就可以不动了。
2自增长的字段的插入
开发中经常遇到某个字段类型为IDENTITY,也就是自增长类型,但由于特殊需要,又要插入数据
需要临时去掉,可以使用如下语句
set IDENTITY_INSERT tablename on
,在处理完成后在使用如下语句恢复
set IDENTITY_INSERT tablename off
3分组取每组的前N个数据
开发中还会遇到需要对某一组数据先分组,然后取每组的前n条记录的情况
不妨试试如下代码
4生成随机数
主意此方法只能写成存储过程,不能写成函数
5把满足一定条件的数据用逗号分隔
这可能也是一个很常用的语句了,经常出现在一对多的关系中对外展示,要求把子表中的数据取出来用逗号或者其他符号分隔开
6在数据库中处理异常
通过个参数附加output标志来输出参数,通过TRY,CATCH捕捉异常
7查询中的条件判断
经常遇到在某些条件下应该查询这个字段,在另外一些条件下需要其他字段的情况,可以通过unoin来完成,但也可以通过CASE WHEN 完成
8单引号的处理
在包含单引号时应该使用两个单引号转义
explain what does that mean? i do not agree ! just use N'男'
9使用游标
2015-11-18 go on tomorrow
'i use En because my input method has something wrong , i will try to restart my PC'
10合并更新和插入
在开发中大部分情况下,插入和更新传递的参数基本上是一样,那为什么不合并呢
- create proc [dbo].[Save_TableName]
- (
- @field1 varchar(50),
- @field2 varchar(200) ,
- @ID int,
- @insertOrUpdate --小于0插入 大于0更新
- )
- as
- begin
- if(@insertOrUpdate<0)
- begin
- INSERT INTO TableName (field1,field2,ID )
- values ( @field1 ,@field2,@ID);
- end
- else
- begin
- UPDATE TableName SET field1= @field1, field2 = @field2
- where ID =@ID;
- end
- end
11定义函数
在没有满足要求的情况时,可以定义函数,但是使用自己定义的函数时需要加上架构名称
- create FUNCTION [dbo].[CheckTime]
- (
- @startTime datetime,
- @endTime datetime--,
- )
- RETURNS int
- AS
- BEGIN
- DECLARE @result int
- SET @result=DATEDIFF(hour, @startTime, @endTime) --
- if(@result=0)--小时相同 比较分钟
- begin
- SET @result=DATEDIFF(minute, @startTime, @endTime)
- if(@result=0)--分钟相同比较秒
- begin
- SET @result=DATEDIFF(second, @startTime, @endTime)
- end
- end
- RETURN @result
- END
调用此函数
- dbo.CheckTime(@startTime1, @startTime2)--需要加上架构名称
12递归读取数据
在实际的应用中经常遇到树结构的表,但读取会比较麻烦,这里提够一个函数
- /*
- 函数 返回表,返回给定节点的所有子孙节点,而不仅仅是子节点
- */
- Create Function [dbo].[GetChildren](@NodeID Int)
- Returns @Tree Table (NodeID Int, NodeName Varchar(50), ParentID Int )
- As
- Begin
- Insert @Tree Select NodeID, NodeName, ParentID From Treetable Where ParentID = @NodeID
- While @@Rowcount > 0
- Insert @Tree Select A.NodeID, A.NodeName, A.ParentID
- From Treetable A
- Inner Join @Tree B
- On A.ParentID = B.NodeID And A.NodeID Not In (Select NodeID From @Tree)
- Return
- End
13通过默认值实现存储过程重载
存储过程可以使用默认值,估计都知道,但以此就可以实现类似函数重载的效果
例如,如下的存储过程由于使用了默认值,就可以不传递参数,传递一个参数,两个,三个,
- CREATE PROCEDURE dbo.my_proc
- @first int = NULL, -- NULL default value
- @second int = 2, -- Default value of 2
- @third int = 3 -- Default value of 3
- AS SELECT @first, @second, @third;
14在数据库中拼字符串,也可以用参数
在实际的开发中,某些情况下在数据库中拼字符串不可避免,但又担心有特殊字符,导致拼出来的SQL有问题,其实数据库中拼字符串也可以使用参数,这就要用到dbo.sp_executesql ,这样就可以避免SQL注入和特殊字符导致的错误
如
- DECLARE @IntVariable INT;--定义变量
- DECLARE @SQLString NVARCHAR(500);--存储拼出来的SQL
- DECLARE @ParmDefinition NVARCHAR(500);---存储拼出来的SQL中的参数
- /* Build the SQL string one time. */
- SET @SQLString =
- N'SELECT * FROM AdventureWorks.Sales.Store WHERE SalesPersonID = @SalesID';
- /* Specify the parameter format one time. */
- SET @ParmDefinition = N'@SalesID int';--赋值
- /* Execute the string with the first parameter value. */
- SET @IntVariable = 275;--赋值
- EXECUTE dbo.sp_executesql @SQLString, @ParmDefinition,
- @SalesID = @IntVariable;
- /* Execute the same string with the second parameter value. */
- SET @IntVariable = 276;
- EXECUTE dbo.sp_executesql @SQLString, @ParmDefinition,
- @SalesID = @IntVariable;
16触发器需要注意的问题
在使用触发器时有一个问题,或许很少有人注意到,一条更新语句一次更新了十条记录,会触发几次触发器?只有一次!!很奇怪,但却是事实,所以这需要注意,一不小心就会把好多数据漏了
常用的SQL数据库语句总结的更多相关文章
- 常用的sql数据库语句
1.说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)法一:select * into b from a where 1 <>1法二:select top 0 * i ...
- 讲解SQL数据库语句
前言 大家好,我是 Vic,今天给大家带来讲解SQL数据库语句的概述,希望你们喜欢 数据库语句 create database teach; use teach; create table `teac ...
- 常用的Oracle数据库语句 (待更新完毕)
一.常用的查询语句 1.1 常用查询 查表中有多少个字段 select count(*) from user_tab_columns where table_name=upper('表名') 或者 s ...
- SQL数据库语句练习题目
一. 设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...
- 渗透常用手工SQL注入语句合集
1.判断有无注入点; and 1=1 and 1=2 2.猜表一般的表的名称无非是admin adminuser user pass password 等..and 0<>(select ...
- 一些常用的SQL查询语句
学习网站:http://www.w3cschool.cc/sql/sql-tutorial.html 一:查询所有表的属性 SELECT 'ALTER TABLE '+ CASE WHEN O.sch ...
- 批量分离SQL数据库语句
--sp_helpdb--查看可用数据库 declare @name sysname, @sql nvarchar(4000) DECLARE roy CURSOR FOR --排除不分离的数据库名就 ...
- 简单常用的sql,统计语句,陆续整理添加吧
1. 分段统计分数 if object_id('[score]') is not null drop table [score] go create table [score]([学号] i ...
- SQL数据库语句
on xxx --主文件 ( name=‘xxxx’, fliename='里面写文件放的路径\xxxx.mdf', size=xxMB, filegrowth=xxMB, maxsize=xxMB ...
随机推荐
- 基础命名空间:序列化 System.Runtime.Serialization
对象通常都有状态(state),从一个对象中抽取这种状态,不论是将它存储于某地,还是通过网络传送,这种抽取动作称为“将一个对象序列化”,而反向处理过程,从一个被序列化的状态重建一个对象即为反序列化. ...
- GridView+ZedGraph【转】
edgraph图表控件的强大功能令人出乎意料,与OWC相比我想应该毫不逊色,近来需求要求作出相关数据统计,不想使用BI这类的强大东西,所以搜索到 了免费的开源的Zedgraph控件.使用起来也非常方便 ...
- 南阳oj-喷水装置(一)
喷水装置(一) 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 现有一块草坪,长为20米,宽为2米,要在横中心线上放置半径为Ri的喷水装置,每个喷水装置的效果都会让以 ...
- session问题和JSP
session问题和JSP 07. 五 / J2EE / 没有评论 一.Session开发中遇到的问题1.内存中的Session非常多,怎么办?2.用户在购物中.服务器停掉了该web应用(或者重新 ...
- android listview Caused by: java.lang.ArrayIndexOutOfBoundsException: length=3; index=3
android listview 适配器在多种类型viewType报错: Caused by: java.lang.ArrayIndexOutOfBoundsException: length=3; ...
- 做一个正气的杭电人--hdu2500
做一个正气的杭电人 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- javascript跨域获取json数据
项目在开发过程中,用到了天气预报的功能,所以需要调用天气预报的api,一开始以为直接用ajax调用url就可以获取天气数据,结果涉及到了跨域的问题,这里做一个记录. 说到跨域,就得知道同源策略. 同源 ...
- 简单的html5布局
<!DOCTYPE html><html><meta charset="utf-8"><head><style>html ...
- VCL线程的同步方法 Synchronize(用消息来同步)
看本文时,可以同时参考:Delphi中线程类 TThread实现多线程编程(事件.临界区.Synchronize.WaitFor……) 先说一下RTL和VCL RTL(Run-Time library ...
- javascript调试
今天,发现了一个之前从未注意的角落,相信能够大大提高自己写JS的速度.能够迅速发现错误. 例如,今天的加班中调试一个js错误发现的一个例子. 1.Google浏览器报的错 以上是google浏览器报的 ...