一、基础

1创建数据库

CREATE DATABASE database-name

2删除数据库

drop database dbname

3备份sql server

--- 创建 备份数据的 device

USE master

EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'

--- 開始 备份

BACKUP DATABASE pubs TO testBack

4创建新表

create table tabname(col1 type1 [not
null] [primary key],col2
type2 [not null],..)

依据已有的表创建新表: 

A:create table tab_new like tab_old
(使用旧表创建新表)

B:create table tab_new as select col1,col2… from tab_old
definition only

5删除新表

drop table tabname

6添加一个列

Alter table tabname add column col
type

注:列添加后将不能删除。DB2中列加上后数据类型也不能改变。唯一能改变的是添加varchar类型的长度。

7加入、删除主键

加入主键:Alter table tabname add primary key(col)

删除主键: Alter table tabname drop primary key(col) 

8创建、删除索引

创建索引:create [unique] index idxname on tabname(col….) 

删除索引:drop index idxname

注:索引是不可更改的,想更改必须删除又一次建。

9、创建、删除视图

创建视图:create view viewname as select statement 

删除视图:drop view viewname

10几个简单的主要的sql语句

选择:select * from table1 where 范围

插入:insert into table1(field1,field2) values(value1,value2)

删除:delete from table1 where 范围

更新:update table1 set field1=value1 where 范围

查找:select * from table1 where field1 like ’%value1%’ ---like的语法非常精妙,查资料!

排序:select * from table1 order by field1,field2 [desc]

总数:select count as totalcount from table1

求和:select sum(field1) as sumvalue from table1

平均:select avg(field1) as avgvalue from table1

最大:select max(field1) as maxvalue from table1

最小:select min(field1) as minvalue from table1

11几个高级查询运算词

A: UNION 运算符 

UNION 运算符通过组合其它两个结果表(比如 TABLE1 和 TABLE2)并消去表中不论什么反复行而派生出一个结果表。

当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除反复行。两种情况下,派生表的每一行不是来自
TABLE1 就是来自 TABLE2。 

B: EXCEPT 运算符 

EXCEPT 运算符通过包含全部在 TABLE1 中但不在 TABLE2 中的行并消除全部反复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时
(EXCEPT ALL)。不消除反复行。

C: INTERSECT 运算符

INTERSECT 运算符通过仅仅包含 TABLE1 和 TABLE2 中都有的行并消除全部反复行而派生出一个结果表。

当ALL 随 INTERSECT 一起使用时
(INTERSECT ALL)。不消除反复行。

注:使用运算词的几个查询结果行必须是一致的。

12使用外连接 

A、left (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

B:right (outer) join: 

右外连接(右连接):结果集既包含连接表的匹配连接行,也包含右连接表的全部行。 

C:full/cross (outer) join: 

全外连接:不仅包含符号连接表的匹配行。还包含两个连接表中的全部记录。

12分组:Group by

一张表,一旦分组 完毕后。查询后仅仅能得到组相关的信息。

    组相关的信息:(统计信息) count,sum,max,min,avg 
分组的标准)

    在SQLServer中分组时:不能以text,ntext,image类型的字段作为分组根据

   在selecte统计函数中的字段,不能和普通的字段放在一起;

13数据库操作

分离数据库: sp_detach_db; 附加数据库:sp_attach_db 后接表明,附加须要完整的路径名

14改动数据库的名称

sp_renamedb 'old_name', 'new_name'

二、提升

1复制表

仅仅复制结构,原表名:a, 新表名:b, (Access可用)

法一:select * into b from a where 1<>1(仅用于SQlServer)

法二:select top 0 * into b from a

2拷贝表

拷贝数据。源表名:a。 目标表名:b。 (Access可用)

insert into b(a,
b, c) select d,e,f from b;

3跨数据库之间表的拷贝

详细数据使用绝对路径 (Access可用)

insert into b(a,
b, c) select d,e,f from b in ‘详细数据库’ where 条件

样例:..from b in '"&Server.MapPath(".")&"\data.mdb"
&"' where..

4子查询

(表名1:a ,表名2:b)

select a,b,c from a where a IN (select d from b
) 或者: select a,b,c from a where a IN (1,2,3)

5显示文章、提交人和最后回复时间

select a.title,a.username,b.adddate from table a,(select max(adddate)
adddate from table wheretable.title=a.title)
b

6外连接查询

(表名1:a, 表名2:b)

select a.a,
a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c

7在线视图查询

(表名1:a )

select * from (SELECT a,b,c FROM a)
T where t.a > 1;

8between的使用方法

between限制查询数据范围时包含了边界值,not between不包含

select * from table1 where time between time1 and time2

select a,b,c, from table1 where a not between 数值1 and 数值2

9in 的用法

select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’)

10两张关联表。删除主表中已经在副表中没有的信息 

delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1
)

11四表联查问题

select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .....

12日程安排提前五分钟提醒 

SQL: select * from 日程安排 where datediff('minute',f開始时间,getdate())>5

13数据库分页

select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc)
a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段

详细实现:

关于数据库分页:

  declare @start int,@end int 

  @sql  nvarchar(600)

  set @sql=’select top’+str(@end-@start+1)+’+from T where rid not in(select top’+str(@str-1)+’Rid from Twhere Rid>-1)’

  exec sp_executesql @sql

--注意:在top后不能直接跟一个变量,所以在实际应用中仅仅有这种进行特殊的处理。Rid为一个标识列,假设top后还有具---体的字段。这样做是很有优点的。

由于这样能够避免
top的字段假设是逻辑索引的,查询的结果后实际表中的不一致(逻--辑索引中的数据有可能和数据表中的不一致,而查询时假设处在索引则首先查询索引)

14前10条记录

select top 10 * form
table1 where 范围

15选择在每一组b值同样的数据中相应的a最大的记录的全部信息

(类似这种使用方法能够用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.)

select a,b,c from tablename
ta where a=(select max(a) from tablename
tb where tb.b=ta.b)

16包含全部在
TableA 中但不在 TableB和TableC 中的行并消除全部反复行而派生出一个结果表

(select a from tableA
) except (select a from tableB) except (select a from tableC)

17说明:随机取出10条数据

select top 10 * from tablename order by newid()

18说明:随机选择记录

select newid()

19说明:删除反复记录

1),delete from tablename where id not in (select max(id) from tablename group by col1,col2,...)

2),select distinct * into temp from tablename

  delete from tablename

  insert into tablename select * from temp

评价: 这样的操作牵连大量的数据的移动,这样的做法不适合大容量但数据操作

3),比如:在一个外部表中导入数据,因为某些原因第一次仅仅导入了一部分,但非常难推断详细位置,这样仅仅有在下一次所有导入,这样也就产生好多反复的字段。如何删除反复字段

alter table tablename

--加入一个自增列

add 
column_b int identity(1,1)

delete from tablename where column_b not in(

select max(column_b)  from tablename group by column1,column2,...)

alter table tablename drop column column_b

20列出数据库里全部的表名

select name from sysobjects where type='U' // U代表用户

21列出表里的全部的列名

select name from syscolumns where id=object_id('TableName')

22列示type、vender、pcs字段

以type字段排列,case能够方便地实现多重选择,类似select 中的case。

select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type

显示结果:

type vender pcs

电脑 A 1

电脑 A 1

光盘 B 2

光盘 A 2

手机 B 3

手机 C 3

23初始化表table1

TRUNCATE TABLE table1

24选择从10到15的记录

select top 5 * from (select top 15 * from table order by id asc)
table_别名 order by id desc

三、技巧

11=11=的使用

在SQL语句组合时用的较多,“where 1=1
是表示选择所有    “where 1=2”所有不选。

如:

if @strWhere !='' 

begin

set @strSQL = 'select
count(*) as Total from [' + @tblName + ']
where ' + @strWhere 

end

else 

begin

set @strSQL = 'select
count(*) as Total from [' + @tblName + ']' 

end 

我们能够直接写成

错误。未找到文件夹项。

set @strSQL = 'select
count(*) as Total from [' + @tblName + ']
where 1=1 安定 '+ @strWhere

2收缩数据库

--重建索引

DBCC REINDEX

DBCC INDEXDEFRAG

--收缩数据和日志

DBCC SHRINKDB

DBCC SHRINKFILE

3压缩数据库

dbcc shrinkdatabase(dbname)

4转移数据库给新用户以已存在用户权限

exec sp_change_users_login 'update_one','newname','oldname'

go

5检查备份集

RESTORE VERIFYONLY from disk='E:\dvbbs.bak'

6修复数据库

ALTER DATABASE [dvbbs] SET SINGLE_USER

GO

DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK

GO

ALTER DATABASE [dvbbs] SET MULTI_USER

GO

7日志清除

SET NOCOUNT ON

DECLARE @LogicalFileName sysname,

@MaxMinutes INT,

@NewSize INT



USE tablename -- 要操作的数据库名

SELECT  @LogicalFileName = 'tablename_log', -- 日志文件名称

@MaxMinutes = 10, -- Limit
on time allowed to wrap log.

@NewSize = 1  -- 你想设定的日志文件的大小(M)



Setup / initialize

DECLARE @OriginalSize int

SELECT @OriginalSize = size 

FROM sysfiles

WHERE name = @LogicalFileName

SELECT 'Original
Size of ' + db_name() + ' LOG
is ' + 

CONVERT(VARCHAR(30),@OriginalSize) + ' 8K
pages or ' + 

CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB'

FROM sysfiles

WHERE name = @LogicalFileName

CREATE TABLE DummyTrans

(DummyColumn char (8000) not null)



DECLARE @Counter    INT,

@StartTime DATETIME,

@TruncLog   VARCHAR(255)

SELECT @StartTime = GETDATE(),

@TruncLog = 'BACKUP
LOG ' + db_name() + ' WITH
TRUNCATE_ONLY'



DBCC SHRINKFILE
(@LogicalFileName, @NewSize)

EXEC (@TruncLog)

-- Wrap
the log if necessary.

WHILE @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time
has not expired

AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  

AND (@OriginalSize * 8 /1024) > @NewSize  

BEGIN -- Outer
loop.

SELECT @Counter = 0

WHILE  
((@Counter < @OriginalSize / 16) AND (@Counter < 50000))

BEGIN -- update

INSERT DummyTrans VALUES ('Fill
Log') DELETE DummyTrans

SELECT @Counter = @Counter + 1

END

EXEC (@TruncLog)  

END

SELECT 'Final
Size of ' + db_name() + ' LOG
is ' +

CONVERT(VARCHAR(30),size) + ' 8K
pages or ' + 

CONVERT(VARCHAR(30),(size*8/1024)) + 'MB'

FROM sysfiles 

WHERE name = @LogicalFileName

DROP TABLE DummyTrans

SET NOCOUNT OFF

8更改某个表

exec sp_changeobjectowner 'tablename','dbo'

9存储更改所有表

CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch

@OldOwner as NVARCHAR(128),

@NewOwner as NVARCHAR(128)

AS



DECLARE @Name    as NVARCHAR(128)

DECLARE @Owner   as NVARCHAR(128)

DECLARE @OwnerName   as NVARCHAR(128)



DECLARE curObject CURSOR FOR 

select 'Name'    = name,

   'Owner'    = user_name(uid)

from sysobjects

where user_name(uid)=@OldOwner

order by name



OPEN  
curObject

FETCH NEXT FROM curObject INTO @Name, @Owner

WHILE(@@FETCH_STATUS=0)

BEGIN     

if @Owner=@OldOwner 

begin

   set @OwnerName = @OldOwner + '.' + rtrim(@Name)

   exec sp_changeobjectowner @OwnerName, @NewOwner

end

-- select
@name,@NewOwner,@OldOwner



FETCH NEXT FROM curObject INTO @Name, @Owner

END



close curObject

deallocate curObject

GO

10SQL
SERVER中直接循环写入数据

declare @i int

set @i=1

while @i<30

begin

    insert into test
(userid) values(@i)

    set @i=@i+1

end

案例:

有例如以下表,要求就裱中全部沒有及格的成績,在每次增長0.1的基礎上,使他們剛好及格:

    Name     score

    Zhangshan   80

    Lishi       59

    Wangwu      50

    Songquan    69

while((select min(score) from tb_table)<60)

begin

update tb_table set score =score*1.01 

where score<60

if 
(select min(score) from tb_table)>60

  break

else

    continue

end

最新文章

  1. spring中InitializingBean接口使用理解
  2. 基于服务(Web Service)的文件管理Winform客户端实现(二)
  3. Windows下mysql忘记root密码的解决方法
  4. js原生捕鱼达人(一)
  5. Cstyle的UEFI导读之SEC第一篇 Reset Vector
  6. 外部样式OL LI的定义 影响到了富文本框内的UL LI的定义,使用内部样式对其还原
  7. SQL检测开始日期 结束日期 是否存在交叉
  8. 关于JS中获取浏览器高度和宽度值的多种方法(多浏览器)
  9. 原始的Ajax方法 (异步的 JavaScript 和 XML -- (Extensible Markup Language 可扩展标记语言))
  10. 如何解决远程连接mysql出现Can’t connect to MySQL server on (111 “Connection refused”)的问题
  11. 004 使用SpringMVC开发restful API二--编写用户详情
  12. 实验隐藏参数&quot;_allow_resetlogs_corruption&quot;的使用
  13. .NET Framework 版本和依赖关系[微软官方文档]
  14. 【翻译自mos文章】在10g中,当发生ORA-00020时,sqlplus登陆会报“connected to an idle instance”
  15. 大数据入门到精通2--spark rdd 获得数据的三种方法
  16. Oracle_PL/SQL(9) 例外处理
  17. [BZOJ2124]等差子序列/[CF452F]Permutation
  18. 操作系统定期定时执行python脚本
  19. 关于2013年1月21日的DNS故障分析文章
  20. 在eclipse中使用Maven建web工程的两种方式

热门文章

  1. Spring容器的理解
  2. Python之写入文件(1)
  3. Python的第二堂课(2)
  4. (转)git clone: error: RPC failed; result=18, HTTP code = 200 解决办法
  5. ORACLE常用修改字段脚本
  6. MFC中Picture控件显示图像
  7. vc调试大全
  8. windows liver writer下载地址
  9. charles-修改发送的接口数据测试页面样式
  10. GT使用说明