`
accpxudajian
  • 浏览: 458795 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

SqlServer数据库所有知识总汇

阅读更多
--if exists(select * from sys.databases where name='test')
-- drop database test
--go
--
--create database test
--on primary
--(
--name='test_dat',
--filename='D:\DB\test_dat.mdf',
--size=5MB,
--maxsize=20MB,
--filegrowth=1MB
--),
--(
--name='test_dat2',
--filename='D:\DB\test_dat2.ndf',
--size=5MB,
--maxsize=20MB,
--filegrowth=1MB
--)
--log on
--(
--name='test_log',
--filename='D:\DB\test_log.ldf',
--size=5MB,
--maxsize=20MB,
--filegrowth=1MB
--)
--go
--use test
--go
--
--create table school
--(
--id int primary key identity(1,1),
--sname varchar(20) not null
--)
--go
--insert into school values('农安十中')
--insert into school values('试验中学')
--go

select * from school
--create table classes 
--( 
--id int identity(1,1), 
--tname varchar(20) not null,
--sid int 
--) 
--create table users
--(
--id int primary key identity(1,1),
--uname varchar(20),
--upass varchar(20)
--)
select * from school
select * from classes
select * from users
--常见系统存储过程
exec sp_databases---显示服务器上所有的数据库
exec sp_helpdb zf----显示某一个或者所有的数据库的信息
exec sp_renamedb 'zf', 'zf2' ---修改数据库的名称
exec sp_tables ---显示所有的表
exec sp_columns users ---显示某一个表的所有列的信息
exec sp_help users ----显示某个表的所有信息
exec sp_helpconstraint users   ----查看某一个表的约束
exec sp_helpindex users ---查看某一个表的索引
exec sp_stored_procedures users  ---查看某一个表的存储过程
exec sp_helptext my_view_users ---查看未加密的存储过程,触发器或者试图的实际文本
exec sp_rename 'users.uname','username' ----给表或者表的字段重命名:sp_rename '表名[.字段名]','newname'
---doc存储过程
exec xp_cmdshell 'mkdir D:\aa',no_output
exec xp_cmdshell 'rd D:\aa' 
EXEC xp_cmdshell 'dir *.exe'
---启用xp_cmdshell
-- To allow advanced options to be changed.
EXEC sp_configure 'show advanced options', 1
GO
-- To update the currently configured value for advanced options.
RECONFIGURE
GO
-- To enable the feature.
EXEC sp_configure 'xp_cmdshell', 1
GO
-- To update the currently configured value for this feature.
RECONFIGURE
GO



---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
--主键??
--1保证你每行数据都是唯一值的那个列,这个列不能为空,也不能重复出现相同的值,你可以理解成人的身份证号码,网卡的地址号码,以及公司的税务号码,他们都是唯一而且必须有的。
--2主键的值不可重复,也不可为空(NULL)。
--3主键可以由一个字段,也可以由多个字段组成,分别成为单字段主键或多字段主键。
--4作用:加快数据库的操作速度
--5一个表里可以设两个(或者多个)主键 但是SQL只允许一个主键
--外键?
--1外键表示了两个关系之间的联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。
--   例如:班级表(Class as B) [cid ,cname] 学生表(Student as A) [sid ,name ,cid]  那么就是班级是主表,学生是子表。
--2外建也是一种约束的
--3 外键必须是另一个表的主键

--试图
--1视图是从一个特定的角度来查看数据库中的数据,
--2一个视图是由SELECT查询语句组成的虚拟表。视图包含一系列的列和行。但是,视图不存储真实数据。 只是在引用时动态生成
--3视图是由一张或多张表中的数据组成的
--4单个表的试图的可以执行操作而且直接影响到对应的表,多个表的试图不能进行操作,只可以查看
--5视图是存储在数据库中的查询的SQL 语句,属于定制数据的机制,它主要出于两种原因:安全原因, 视图可以隐藏一些数据,将重要的数据列过滤掉;另一原因是可使复杂的查询易于理解和使用。
--优点:
--1视图集中即是使用户只关心它感兴趣的某些特定数据和他们所负责的特定任务
--2视图本身就是一个复杂查询的结果集,这样在每一次执行相同的查询时,不必重新写这些复杂的查询语句,只要一条简单的查询视图语句即可
--3视图能够实现让不同的用户以不同的方式看到不同或相同的数据集。因此,当有许多不同水平的用户共用同一数据库时,这显得极为重要。
--4视图可以作为一种安全机制。通过视图用户只能查看和修改他们所能看到的数据
--left join :左连接,返回左表中所有的记录以及右表中连接字段相等的记录。 
--right join :右连接,返回右表中所有的记录以及左表中连接字段相等的记录。 
--inner join: 内连接,又叫等值连接,只返回两个表中连接字段相等的行。 
--full join:外连接,返回两个表中的行:left join + right join 
--cross join:结果是笛卡尔积,就是第一个表的行数乘以第二个表的行数。 
create view my_view_users 
as 
select * from users

--存储过程
--是SQL语句和控制流语句的预编译集合。
--存储过程已经经过编译,只需执行它就可以。
--用户通过名字指定存储过程并给出参数
--存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。
--存储过程是由流控制和SQL语句书写的过程,这个过程经编译和优化后存储在数据库服务器中,应用程序使用时只要调用即可。
--优点:
--通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。
--存储过程可以简化运行提高效率
--存储过程因为SQL语句已经预编绎过了,因此运行的速度比较快。 
--存储过程可以接受参数、输出参数、返回单个或多个结果集以及返回值。可以向程序返回错误原因。 
--示例:
--存储过程实现登录
--create proc user_login
[email=--@uname]--@uname[/email] varchar(20),
[email=--@upass]--@upass[/email] varchar(20),
[email=--@flag]--@flag[/email] varchar(20) output
--as
--begin
--if exists(select * from users where [email=uname=@uname]uname=@uname[/email])
--begin
-- if exists(select * from users where [email=uname=@uname]uname=@uname[/email] and [email=upass=@upass]upass=@upass[/email])
--  set @flag='登录成功'
-- else
-- set @flag='密码错误'
--end
--else 
-- set @flag ='不存在该用户'
--end
--
--drop proc user_login
--
--
--declare @flag varchar(20)
--exec user_login 'admin','123',@flag output
--select @flag as 登录结果

--事务
--事务是一种机制.是一个操作序列,它包含一组数据库操作命令,并且所有的命令作为一个整体一起向系统提交或撤消,即这一组数据库命令要么都执行,要么都不执行. 
--事务运行的三种模式: 
--A:自动提交事务 
--每条单独的语句都是一个事务。每个语句后都隐含一个COMMIT。 
--B:显式事务 
--以BEGIN TRANSACTION显式开始,以COMMIT或ROLLBACK显式结束。 
--C:隐性事务 
--在前一个事务完成时,新事务隐式启动,但每个事务仍以COMMIT或ROLLBACK显式结束。
--第二点:你要了解事务的4个属性,即ACID 
--原子性:事务是一个完整的操作 要么全做要么全不做
--一致性:当事务完成时,数据是必须处于一致状态 
--隔离性:对数据进修改的所有并发事务是彼此隔离的. 
--持久性:事务完成后,它对于系统的影响是永久的. 
-- 
----事务的try-catch
--begin tran 
--
--begin try 
-- insert into classes(tname,sid) values('dd',546)--sid约束小于100,引发错误
-- commit tran 
--end try 
--
--begin catch 
-- print 'error'
-- rollback tran
--end catch 

--函数 function??
--函数是由一个或多个 Transact-SQL 语句组成的子程序,可用于封装代码以便重新使用。
--可使用 CREATE FUNCTION 语句创建、使用 ALTER FUNCTION 语句修改、以及使用 DROP FUNCTION 语句除去用户定义函数
--共七类: 
--1.数学函数:abs()、sign()、pi()、power()等。 
--2.统计函数:avg()、sum()、max()、min()等。 
--3.字符串函数:char()、space()、nchar()、len()等。 
--4.日期函数:getdate()、day()、month()、year()等。 
--5.系统函数:db_id()、file_id()、user_id()、user()等。 
--6.其他函数:textptr()、textvalid()、patindex()、cursor_status()等。 
--7.用户自定义函数: 
----一个自定义function示例
--create function split(@str varchar(500),@pos int) 
--returns varchar(500) 
--as 
--begin 
--if @str='' or @pos<1 or @pos>500 
--return '' 
--declare @i int 
--declare @j int 
--declare @s int 
--declare @ret varchar(500) 
--set @s=1 
--set @j=0 
--set @ret='' 
--while @s<=len(@str) 
-- begin 
-- set @j=@j+1 
-- set @i=charindex('|',@str,@s) 
-- if @i<1 
-- begin 
-- set @ret=substring(@str,@s,len(@str)-@s+1) 
-- break 
-- end 
-- else 
-- begin 
-- set @ret=substring(@str,@s,@i-@s) 
-- end 
-- if @j=@pos break 
-- set @s=@i+1 
-- end 
-- if @j<@pos 
-- return '' 
-- return @ret 
--end 
--
--select dbo.split('AAA|BBBB|CCCC' ,1) 

--触发器(trigger)
--是在对表进行插入,更新或者删除时自动执行的存储过程。
--是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由个事件来触发
--触发器经常用于加强数据的完整性约束和业务规则等。
--触发器可通过数据库中的相关表实现级联更改
--触发器可以强制比用 CHECK 约束定义的约束更为复杂的约束
----触发器和inserted数据集
CREATE TRIGGER TR_USERS_UPDATE ON dbo.students
FOR UPDATE 
AS 
declare @USER_IF int
select @USER_IF=sage from inserted --* 
if @user_if>1 
insert into students values('更新',@USER_IF) 
go 
drop trigger TR_USERS_UPDATE
---测试
update students set sage=340 where id =1--更新同时添加一条新记录
select * from students
--范式(Normal Formate)
--第一范式:每列都是不可再分的最小数据单元,要求不能再分
--第二范式:每列都和主键相关,即除了主键以外的其他列,都依赖于该主键,要求一个表只描述一件事
--第三范式:数据表中的每列都和主键直接相关,而不是间接关联,要求不是传递依赖关系。


---------------------基本用法
--默认约束
alter table users
add constraint DF_uname default('dajian') for uname
--唯一约束
alter table users
add constraint UQ_uname unique(uname)
--check约束
alter table users
add constraint CK_upass check(upass != 'admin')
----创建windows登录用户
use master
exec sp_grantlogin '域名/帐户名'
----创建SQL登录用户
exec sp_addlogin 'admin','131258'
exec sp_addlogin 'admin2','131258'
--创建数据库用户
--1进入到要分配权限的数据库
--2为当前数据库添加数据库用户
use test
go
exec sp_grantdbaccess 'admin','admin2'
go
---给数据库用户分配权限(CRUD)
use test
go
--为用户分配school表的删除以外的权限
grant select ,insert ,update on school to admin2
--分配创建表的权限
grant create table to admin2
--声明局部变量 赋值后用于查询
declare @name varchar(20)
set @name ='dajian'
select * from users where [email=uname=@name]uname=@name[/email]
---声明全局变量(@@ 表示)
系统常用全局变量:
@@error 最后一个T-SQL的错误号
delete from notables ---notalbes表示不存在的数据表
select @@error ---208
print '当前错误号为:'+convert(varchar(5),@@error)----当前错误号为:208
一般用来累计错误,与事务并用如:
begin tran
...
update bank set balance =balance-1000
set @errorCount = @errorCount [email=+@@error]+@@error[/email]
if(@errorCount>0)
rollback tran
else
commit tran

@@identity 最后一个插入的标识列
insert into users values('ada','afad')
select @@identity---6
@@language 当前使用的语言
select @@language --简体中文
@@servername 本地服务器的名称
select @@servername  --WWW-90DB9457179
@@servicename  本地SQL服务的名称
select @@servicename----MSSQLSERVER
@@rowcount 受上一个SQL语句影响的行数
select * from users
select @@rowcount---4
@@max_connections 同时创建最大连接数目
select @@max_connections-----32767
@@trancount 当前打开事务的总数
begin tran
select @@trancount---1
rollback tran
select @@trancount---0
@@version 当前SQL Server的版本信息
select @@version  ---Microsoft SQL Server 2005 - 9.00.1399.06 (Intel X86)   Oct 14 2005 00:33:37   Copyright (c) 1988-2005 Microsoft Corporation  Developer Edition on Windows NT 5.1 (Build 2600: Service Pack 3) 
set 和select赋值的区别
1 select可以多个同时赋值,set必须一个一个赋值
例如:
select @a=1,@b=2,@c=3
set @a=1
set @b=2
set @c=3
2 当查询结果不为一时,只能用select赋值,且去最后一条记录
declare @name varchar(20)
set @name = (select uname from users where id =2) --有且只能有一条记录
select @name = (select uname from users where id !=2) --多条记录时,取最后一条记录
--
--create table students
--(
--id int primary key identity(1,1),
--sname varchar(20),
--sage int 
--)
--insert into students values('111',3)
--insert into students values('222',23)
--insert into students values('333',33)
--insert into students values('444',43)
--insert into students values('555',55)
--insert into students values('6666',63)

--while循环
declare @age int
set  nocount on
print '加分前的年龄是:'
select * from students
while(1=1)
begin
select @age=min(sage) from students 
if(@age<40)
  begin
   update students set sage=sage+2
  end
else
  begin
   break
  end
end
print '加分后的年龄是:'
select * from students
--case用法
select sname as 学生姓名,年龄段=case
when sage <50 then '少年'
when sage >50 and sage<80 then '中年'
else '老年'
end
from students
update students set sage =sage-2 
--索引
--索引提供指针指向表中的指定列,然后根据指定的排序顺序排列这些指针。
--数据库找到指定的索引,然后跟随指针到达包含值的行
--索引是表中列的逻辑指针清单。
--一个表只允许由一个聚集索引,可以有多个非聚集索引;
--创建users表的uname的索引,用于查询
if exists(select name from sys.indexes where name='myindex_users')
drop index users.myindex_users
go
create nonclustered index myindex_users
on users(uname)
with fillfactor= 30
go
---按照自定义的索引查询表
select * from users with (index = myindex_users) 
----但是一般不用人工指定索引,SQL会根据所创建的索引,自动优化查询
----索引可以加快查询速度,但索引自身也需要维护,并占用一定的资源,所以不需要为每一个列创建索引,
----为某一个列创建索引的标准:1频繁搜索2用于排序(没必要为小表创建索引)
--索引其实可以理解成一本字典的目录,通过目录我们很快的能找到我们要找的那一页,如果没有目录,我们就要一篇一篇的翻,很明显,使用索引的表要比没有使用索引的标的查询速度快几十倍
--什么是索引?SQL Server 2000里有什么类型的索引? 
--索引用来快速访问数据库表格或者视图里的数据。在SQL Server里,它们有两种形式:聚集索引和非聚集索引。
--1聚集索引在索引的叶级保存数据。这意味着不论聚集索引里有表格的哪个(或哪些)字段,这些字段都会按顺序被保存在表格。由于存在这种排序,所以每个表格只会有一个聚集索引。
--2非聚集索引在索引的叶级有一个行标识符。这个行标识符是一个指向磁盘上数据的指针。它允许每个表格有多个非聚集索引。 


 

 

 

 

分享到:
评论

相关推荐

    SQL SERVER数据库基本知识点DOC 文档

    在SQL Server数据库中,掌握基本知识点对于任何数据库管理员或开发者来说都是至关重要的。以下是对标题和描述中提及的各个主题的详细阐述: 1. **数据库设计**:数据库设计是整个系统的基础,它涉及到数据的组织、...

    《SQLServer数据库技术项目化教程》483页完整版教学课件汇总全书电子教案.pptx

    《SQLServer数据库技术项目化教程》是一份详尽的教学课件,总计483页,旨在教授学生关于SQL Server 2016数据库系统的基本知识和实用技能。本教程覆盖了数据库系统的概念、SQL Server 2016的使用以及一系列相关管理...

    SQL Server 索引基础知识

    ### SQL Server 索引基础知识知识点汇总 #### 一、记录数据的基本格式 - **数据页作为基础单位**:在 SQL Server 中,数据页是最基本的存储单位,无论是缓存中的数据还是磁盘上的物理存储,都以数据页的形式存在。...

    SQLServer数据库设计和高级查询4_2

    根据给定的信息,“SQLServer数据库设计和高级查询4_2”,我们可以推断出这份材料主要聚焦于SQL Server数据库的设计原则以及高级查询技术。虽然提供的部分内容并未包含具体的知识点,但基于标题、描述和标签,我们...

    《SQL SERVER 数据库应用》实验指导书-2015版.doc

    《SQL Server 数据库应用》实验指导书-2015版...总的来说,这个实验课程旨在通过实践操作,使学生熟悉SQL Server数据库管理系统,掌握数据库设计、操作和管理的核心技能,为将来在IT领域中的数据库应用打下坚实基础。

    SQLServer数据库设计和高级查询11

    在深入探讨《SQL Server数据库设计和高级查询》这一主题时,我们不仅触及了数据库的核心构建原理,还深入了解了如何利用SQL Server进行复杂的数据管理和高效的数据检索。以下是对标题、描述和部分潜在内容所涵盖的...

    SQLServer数据库设计和高级查询14

    在深入探讨《SQLServer数据库设计和高级查询14》这一主题前,我们首先需要理解SQL Server作为微软开发的关系型数据库管理系统,在数据管理、存储及处理方面的重要地位。它不仅提供了强大的数据存储功能,还支持复杂...

    SQLServer数据库设计和高级查询5

    根据给定的信息“SQLServer数据库设计和高级查询5”,我们可以推断出这是一份关于SQL Server数据库管理和查询技术的专业资料。尽管提供的具体内容部分主要包含了网站链接和版权申明,并未直接涉及具体的技术细节,但...

    在Sql Server 数据库中利用存储过程实现动态交叉表

    本文将探讨如何在SQL Server数据库中利用存储过程实现动态交叉表。 首先,我们需要理解交叉表的基本概念。在数据分析和报表生成中,交叉表是一种以行列交叉形式展示数据统计结果的表格,通常用于展示分类数据的汇总...

    《SQLServer数据库技术》授课计划定义.pdf

    从提供的文件信息来看,文档的标题是《SQLServer数据库技术》授课计划定义,而描述和标签部分没有提供额外信息。文件内容包含了关于SQL Server数据库技术的一系列知识点,可能是一份课程内容大纲或提纲,但是由于...

    SQLServer数据库设计和高级查询6_2

    在深入探讨《SQLServer数据库设计和高级查询6_2》这一主题时,我们不仅需要关注其表面的命名,更应挖掘其背后所蕴含的丰富知识体系。标题与描述的重复实际上是在强调本书聚焦的核心——SQLServer数据库的设计与高级...

    SQLServer数据库复杂查询示例

    在SQLServer数据库中,复杂查询通常涉及到多个表的联接(JOIN)、子查询、聚合函数(GROUP BY)、分组层次(ROLLUP/CUBE/GROUPING SETS)以及窗口函数(Window Functions)。这些技术使得我们可以从庞大的数据集中...

    ACCP5。0 SQL Server数据库设计和高级查询(SQL Advance)

    以下是关于"ACCP5.0 SQL Server数据库设计和高级查询"的一些核心知识点: 1. **SQL Server基础**:首先,了解SQL Server的基本概念,如数据库、表、索引、视图等,以及如何通过SQL Server Management Studio(SSMS...

    《SQLserver数据库》课程设计范例.pdf

    本资源摘要信息基于《SQL Server数据库》课程设计范例.pdf,旨在提供一个小型书店管理系统的设计方案,涵盖数据库设计、软件设计、数据库应用等方面的知识点。 数据库设计 数据库设计是指根据业务需求,设计和实现...

    SQL Server数据库应用与开发教程完整版课件

    SQL Server数据库应用与开发教程

    SQLServer数据库设计和高级查询13

    根据给定的文件标题、描述、标签以及部分内容来看,虽然部分内容并未给出具体的知识点,但从标题“SQLServer数据库设计和高级查询13”可以推测出本篇内容将围绕SQL Server数据库的设计原则与高级查询技巧展开。...

    SQLServer基础知识.pdf

    SQL Server基础知识 本资源摘要信息涵盖了SQL Server基础知识的重要概念和技术要点,旨在帮助读者快速掌握SQL Server的基本原理和应用。 SQL Server简介 SQL Server是Microsoft公司开发的一款关系数据库管理系统...

Global site tag (gtag.js) - Google Analytics