SQLServer基础入门教程课件.pptx
SQLServer复习数据库的创建数据库的文件在Microsoft SQL Server 2005系统中,一个数据库至少有一个数据文件和一个事务日志文件。当然,一个数据库也可以有多个数据文件和多个日志文件。数据文件用于存放数据库的数据和各种对象,而事务日志文件用于存放事务日志。一个数据库最多可以拥有32767个数据文件和32767个日志文件。(32K-1个,1K=1024)数据库的文件数据文件又可以分成主数据文件和次数据文件两种形式。主数据文件是数据库的起点,每一个数据库都有且仅有一个主数据文件。主数据文件名称的默认后缀是mdf。次数据文件是可选的,可以存储不在主数据文件中的全部数据和对象。数据库既可能没有次数据文件,也可能有多个次数据文件。次数据文件名称的默认后缀是ndf。数据库的文件Microsoft SQL Server系统使用数据库的事务日志来实现事务的功能。事务日志记录了对数据库的所有修改操作。日志记录了每一个事务的开始、对数据的改变和取消修改的足够信息。对于一些大型操作,例如创建索引,日志只是记录该操作的事实,而不是记录所发生的数据。事务日志还记录了数据页的分配和释放,以及每一个事务的提交和回滚。这样就允许SQL Server系统恢复事务或者取消事务。每一个数据库都至少有一个日志文件。日志文件名称的后缀默认是ldf。数据库的文件在操作系统上,数据库是作为数据文件和日志文件存在的,这些文件都明确地指明了文件的位置和名称。但是,在Microsoft SQL Server系统内部,例如在Transact-SQL语言中,如果使用物理文件执行操作,由于这些文件的名称比较长,使用起来非常不方便。为此,数据库又有了逻辑文件。每一个物理文件都对应一个逻辑文件。数据库的文件文件组就是文件的逻辑集合。为了方便数据的管理和分配,文件组可以把一些指定的文件组合在一起。例如,在某个数据库中,3个文件(data1.ndf,data2.ndf和data3.ndf)分别创建在3个不同的磁盘驱动器中,然后为它们指定一个文件组fgroup1。以后,所创建的表可以明确指定放在文件组fgroup1上数据库的文件使用文件和文件组时,应该考虑下列因素:(1)一个文件或者文件组只能用于一个数据库,不能用于多个数据库;(2)一个文件只能是某一个文件组的成员,不能是多个文件组的成员;(3)数据库的数据信息和日志信息不能放在同一个文件或文件组中,数据文件和日志文件总是分开的;(4)日志文件永远也不能是任何文件组的一部分。创建数据库的语句使用CREATE DATABASE语句定义数据库例:create database blog 使用默认的数据文件和日志文件。默认的存储位置:C:Program FilesMicrosoft SQL ServerMSSQL10.SQLEXPRESSMSSQLDATA创建数据库的语句指定文件和文件组的创建数据库的语句:示例查看数据库信息-查看数据库信息select*from sys.databasesexec sp_helpdb jsdb2-查看数据库文件use jsdb2select*from sys.database_files-查看数据库文件组use jsdb2select*from sys.filegroups-查看使用的数据空间exec sp_spaceused修改数据库-修改数据库名alter database jsdb2 modify name=jsdb-修改数据库增加文件alter database jsdb add file(name=jsdblog2_log,filename=c:jsdblog2_log.ldf,size=3,filegrowth=10%)-修改数据库文件的大小alter database jsdbmodify file(name=jsdb_log,size=4)删除数据库drop database jsdb数据库和文件一同被删除。Transact-SQL语言简介SQL语言SQL语言的历史是一种在关系数据库中定义、查询、操纵和控制数据的标准语言,其基本格式类似于英语。1974年 Boyce和Chamberlin提出 Sequel语言 1976年 IBM公司的San Jose修改 Sequel 2 1986年 SQL-86 1992年 SQL-92Transact-SQL语言的5种类型数据定义语言数据操纵语言数据控制语言事务管理语言附加的语言元素数据定义语言数据定义语言(DDL)是指用来定义和管理数据库以及数据库中各种对象的语句,这些语句包括CREATE、ALTER和DROP等。在SQL Server 2005中,数据库对象包括表、视图、触发器、存储过程、规则、默认、用户自定义的数据类型等。这些对象的创建、修改和删除等都可以通过使用CREATE,ALTER,DROP等语句来完成。数据操纵语言数据操纵语言(DML)是指用来查询、添加、修改和删除数据库中数据的语句,这些语句包括SELECT、INSERT、UPDATE和DELETE等。数据控制语言数据控制语言(DCL)是用来设置或更改数据库用户或角色权限的语句,包括GRANT,DENY,REVOKE等语句。在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行数据控制语言。事务管理语言使用事务管理语言(TML)语句来管理显示事务。BEGIN TRANSACTION语句用于明确地定义事务的开始;COMMIT TRANSACTION语句用于明确地提交完成的事务;事务中出现了错误时,可以使用ROLLBACK TRANSACTION语句明确地取消定义的事务。附加的语言元素附加的语言元素主要包括标识符、变量和常量、运算符、表达式、数据类型、函数、控制流语言、错误处理语言和注释等。标识符数据库对象的名称就是其标识符。按照标识符的使用方式,可以把这些标识符分为常规标识符和分割标识符两种类型。Transact-SQL语言的常规标识符的格式规则:规则一,第一个字符必须是下列字符之一:(1)Unicode标准定义的字母;(2)下划线()、符号()、数字符号(#)。规则二,后续字符可以包括:(1)Unicode标准中定义的字母;(2)基本拉丁字符或十进制数字;(3)下划线(_)、符号()、数字符号(#)、美元符号($)。规则三,标识符不能是Transact-SQL语言的保留字,包括大写和小写形式。规则四,不允许嵌入空格或其他特殊字符。变量数据库对象的名称就是其标识符。按照标识符的使用方式,可以把这些标识符分为常规标识符和分割标识符两种类型。Transact-SQL语言的常规标识符的格式规则:规则一,第一个字符必须是下列字符之一:(1)Unicode标准定义的字母;(2)下划线()、符号()、数字符号(#)。规则二,后续字符可以包括:(1)Unicode标准中定义的字母;(2)基本拉丁字符或十进制数字;(3)下划线(_)、符号()、数字符号(#)、美元符号($)。规则三,标识符不能是Transact-SQL语言的保留字,包括大写和小写形式。规则四,不允许嵌入空格或其他特殊字符。运算符运算符是一些符号,它们能够用来执行算术运算、字符串连接、赋值以及在字段、常量和变量之间进行比较。在SQL Server 2005中,运算符主要有以下六大类:算术运算符、赋值运算符、位运算符、比较运算符、逻辑运算符和字符串串联运算符。算术运算符算术运算符可以在两个表达式上执行数学运算,这两个表达式可以是数字数据类型分类的任何数据类型。算术运算符包括加(+)、减()、乘(*)、除(/)和取模(%)。赋值运算符Transact-SQL 中只有一个赋值运算符,即“=”。赋值运算符使我们能够将数据值指派给特定的对象。另外,还可以使用赋值运算符在列标题和为列定义值的表达式之间建立关系。位运算符位运算符使我们能够在整型数据或者二进制数据(image 数据类型除外)之间执行位操作。此外,在位运算符左右两侧的操作数不能同时是二进制数据。下表列出了所有的位运算符及其含义。运算符含义&按位 AND(两个操作数)|按位 OR(两个操作数)按位互斥 OR(两个操作数)比较运算符比较运算符亦称为关系运算符,用于比较两个表达式的大小或是否相同,其比较的结果是布尔值,即TRUE(表示表达式的结果为真)、FALSE(表示表达式的结果为假)以及UNKNOWN。除了 text,ntext 或 image 数据类型的表达式外,比较运算符可以用于所有的表达式。逻辑运算符逻辑运算符可以把多个逻辑表达式连接起来。逻辑运算符包括AND、OR和NOT等运算符。逻辑运算符和比较运算符一样,返回带有 TRUE 或 FALSE 值的布尔数据类型。三个运算符的优先级别为:NOT,AND,OR。字符串联接运算符字符串串联运算符允许通过加号(+)进行字符串串联,这个加号即被称为字符串串联运算符。例如对于语句SELECT abc+def,其结果为abcdef。运算符优先级在SQL Server 2005中,运算符的优先等级从高到低如下所示,如果优先等级相同,则按照从左到右的顺序进行运算。(1)括号:();(2)乘、除、求模运算符:*,/,%;(3)加减运算符:,;(4)比较运算符:=,=,=,!=,!,!5*0 and _row_num=5*1order by id desc排名函数RANK函数的使用方式是RANK()OVER(PARTITION BY i.LocationID order by i.Quantity)as RANK,其中,RANK()OVER是函数的关键字,PARTITION BY i.LocationID表示对结果集按照LocationlD列的数据分区,order by i.Quantity表示分区内的数据按照数量从低到高排序。安全函数安全函数字符串函数字符串函数字符串函数