Sql server 语句大全
创建数据库
  创建之前判断该数据库是否存在
  if exists (select * from sysdatabases where name='databaseName')
  drop database databaseName
  go
  Create DATABASE databasename
删除数据库
  drop database dbname
备份sql server
  --- 创建备份数据的 device
  USE master
  EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
  --- 开始备份
  BACKUP DATABASE pubs TO testBack
创建新表
  create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
  根据已有的表创建新表:
  Ago
  use 原数据库名
  go
  select * into 目的数据库名.dbo.目的表名 from 原表名select中distinct(使用旧表创建新表)
  Bcreate table tab_new as select col1,col2 from tab_old definition only
创建序列
  create sequence SIMON_SEQUENCE
  minvalue 1 -- 最小值
  maxvalue 999999999999999999999999999 -- 最大值
  start with 1 -- 开始值
  increment by 1 -- 每次加几
  cache 20;
删除新表
  drop table tabname
增加一个列
  Alter table tabname add colname coltype
删除一个列
  Alter table tabname drop column colname
添加主键
  Alter table tabname add primary key(col)
  说明:删除主键:Alter table tabname drop primary key(col)
创建索引
  create [unique] index idxname on tabname(col…。)
  删除索引:drop index idxname on tabname
  注:索引是不可更改的,想更改必须删除重新建。
创建视图
  create view viewname as select statement
  删除视图:drop view viewname
简单基本的sql语句
  (1) 数据记录筛选:
  sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]"
  sql="select * from 数据表 where 字段名 like '%字段值%' order by 字段名 [desc]"
  sql="select top 10 * from 数据表 where 字段名=字段值 order by 字段名 [desc]"
  sql="select top 10 * from 数据表 order by 字段名 [desc]"
  sql="select * from 数据表 where 字段名 in ('1','2','3')"
  sql="select * from 数据表 where 字段名 between 1 and 2"
  (2) 更新数据记录:
  sql="update 数据表 set 字段名=字段值 where 条件表达式"
  sql="update 数据表 set 字段1=1,字段2=2 …… 字段n=n where 条件表达式"
  (3) 删除数据记录:
  sql="delete from 数据表 where 条件表达式"
  sql="delete from 数据表" (将数据表所有记录删除)
  (4) 添加数据记录:
  sql="insert into 数据表 (字段1,字段2,字段3 ) values (1,2,3 )"
  sql="insert into 目标数据表 select * from 源数据表" (把源数据表的记录添加到目标数据表)
  (5) 数据记录统计函数:
  AVG(字段名) 得出一个表格栏平均值
  COUNT(*;字段名) 对数据行数的统计或对某一栏有值的数据行数统计
  MAX(字段名) 取得一个表格栏最大的值
  MIN(字段名) 取得一个表格栏最小的值
  SUM(字段名) 把数据栏的值相加
  引用以上函数的方法:
  sql="select sum(字段名) as 别名 from 数据表 where 条件表达式"
  set ute(sql)
  用 rs("别名") 获取统计的值,其它函数运用同上。
  查询去除重复值:select distinct * from table1
  (5) 数据表的建立和删除:
  CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )
  (6) 单列求和:
  SELECT SUM(字段名) FROM 数据表
几个高级查询运算词
  AUNION 运算符
  UNION 运算符通过组合其他两个结果表(例如TABLE1 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL UNION 一起使用时(即UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自TABLE1 就是来自TABLE2
  B EXCEPT 运算符
  EXCEPT 运算符通过包括所有在TABLE1 中但不在TABLE2 中的行并消除所有重复行而派生出一个结果表。当ALL EXCEPT 一起使用时(EXCEPT ALL),不消除重复行。
  CINTERSECT 运算符
  INTERSECT 运算符通过只包括TABLE1 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当ALL INTERSECT 一起使用时(INTERSECT ALL),不消除重复行。
  注:使用运算词的几个查询结果行必须是一致的。
使用外连接
  Aleft outer join
  左外连接(左连接):结果集既包括连接表的匹配行,也包括左连接表的所有行。
  SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
  Bright outer join:
  右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
  Cfull outer join
  全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
编辑本段判断对象是否存在
判断数据库是否存在
  if exists (select* from sysdatabases where name= '数据库名')
  dropdatabase[数据库名]
判断表是否存在
  if not exists (select * from sysobjects where [name] = '表名' and xtype='U')
  begin
  --这里创建表
  end
判断存储过程是否存在
  if exists (select* from sysobjects whereid = object_id(N'[存储过程名]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。