Server SQL2008对文件的基础操作—01

 

1、一个文件的基本框架为:文件名、文件地址、文件大小、文件最大的大小、文件的增量(Filegrowth)。

2、文件有mdf、ndf、ldf 三种文件的区别。

3、文件组可以进行文件的管理 FileGroup 默认的文件组是 Primary 日志文件无文件组的概念,存在Log文件中。

4、

alter database 数据库名 add  fileGroup 文件组名                       --添加文件组

 

 

(文件)

to filegroup 文件组名 --将文件添加到相关的文件组中去

 

 

实例:

alter database Stu_db2 add filegroup file_group         --向数据库中添加了新的文件组,file_group

go

alter database Stu_db2 add file
(
name=N'new_datafile',
filename='D:\SQl_Project\SQL_02\new_datafile.ndf',
size=3072kb,
maxsize=unlimited,
filegrowth=1024kb
)
to filegroup file_group                                                            --向文件组中添加文件new_datafile

 

5、修改文件组为默认的文件组;

alter database 数据库名 modify filegroup 文件组名 default

 

 

6、修改文件组的名字

alter database 数据库名 modify filegroup 文件组名 name =新的文件组名

 

 

7.1、设置文件组为只读

 

alter database 数据库名 modify filegroup 文件组名 Readonly

 

 

7.2:设置文件组为可读写;

 

alter database 数据库名 modify filegroup 文件组名 Readonly

 

 

8、删除文件组

 

alter database 数据库名 remove filegroup 文件组名 *注意,删除文件组要确保文件组中没有数据文件。

 

 

9、查看数据库的大小:

 

exec/execute sp_spaceused

 

 

10、查看数据中文件的详细信息:

 

exec sp_helpdb 数据库名

 

 

 sp_configure 使用sp_configure存储过程可设置实例范围内的配置选项

 

 

11、删除数据库;

 

drop database 数据库名

 

 

12、修改数据库的名字;

 

alter database 数据库名 modify name=新的数据库名

 

 

13、如果数据库的空间不足,则可以通过以下的方法进行设置;

13.1.1、添加新的次要文件或次要的日志文件

13.1.2、修改增量和文件大小:

 

 alter database 数据库名
modify file
(
name=Onedb, --要修改的文件名
size=20, --文件大小
filegrowth=10% --文件的增量
)

 


14、收缩数据库

14.1.1、直接修改增量和文件大小,参考以上,只是把文件大小改小了。

14.2.1、设置数据库为自动收缩;

 

alter database 数据库名 set auto_shrink on --不是最优的方法

 

 

14.3.1、

DBCC shrinkdatabase('要收缩的数据库名',可用空间的比例) 收缩数据库

 

 

**注意,如果收缩的是当前使用的数据库,则可以用0代替该数据库名。

14.4.1、

DBCC shrinkfile('要收缩的数据库文件名',收缩文件大小) 收缩数据库文件

 

 

15、数据库快照(注意,只有企业版才支持快照的功能,标准版不支持)

15.1.1、创建数据库快照;

 

create database 快照名称
On
(
name=数据库中的文件名,
filename='快照文件的存放地址'
),
( --如果数据库中有多个文件的话,
要一一的将每个文件进行指定
)
as snapshot of 数据库名

 

 

15.2.1、查询数据库快照:

 

select*from 数据库快照名

 

 

15.3.1、数据快照是只读的,所以不能为其添加文件和数据

15.3.1、用快照对数据库进行恢复;

 

restore database 数据库名 from database_snapshot='数据库快照名'

 

 

16、分离数据库:

 

exec sp_detach_db 数据库名

 

 

17、附加数据库;

 

create database 新的数据库名
on
( filename='文件地址' --可以选择的附加数据库中的相关文件,建议全部附加),
(filename=''for attach

 

 

18、如果附加的日志文件无法使用,则可以指定系统重新构建新的日志文件;

 

create database 数据库名 on
(filename='数据库文件所在的路径')
for attach_rebuild_log

 

 

19、移动数据库文件:

19.1.1、首先要讲数据库状态设为offline

19.2.1alter database 数据库名 modify file(name=文件名,filename='新路径')

19.3.1、再将数据库的状态设置为online 

 

 

20.1.1、完全备份数据库:

 backup database 要备份的数据库名

to disk='备份文件存放的位置' with name='备份集名称',

description='数据库描述【数据库完全备份/数据库差异备份】',

--init --指定重写所有备份集 noinit 不覆盖现有的备份

 
20.2.1、差异备份数据库;

 back database 要备份的数据库名

to disk ='备份文件存放的位置'

with differential [differential表示这是差异备份] ,

description='数据库差异备份',

init

 
21、还原数据库:

第一步:还原完全备份的数据:

restore database 数据库名 from disk='文件地址.bak' with file=1--备份设备中的第一个备份集,
norecovery , --不对数据库执行任何操作
nounload, --不对数据库做任何操作,不回滚相关的事物
replace, --覆盖现有的数据库

 



第二步:还原差异备份的数据:

restore database 数据库名 from disk='文件地址' with file=1--备份设备中的第一个备份集,
norecovery , --不对数据库执行任何操作
nounload, --不对数据库做任何操作,不回滚未提交的事物
replace, --覆盖现有的数据库

 

 

注意;如果还有差异备份的话,还要将差异备份中的数据进行还原,否则还原的过程会出错。


DDL:

1、在数据库中创建表;

 

create table 表明(列名 类型, ...)

 


2、在表中插入数据:

 

insert into 表名(列名1,列名2.、、、) values(对应列的值)

 

3、为表中更新数据:

updata 表名 set 列名 where 条件。 

 

 

4、删除表/表中的数据【列/行】

delete 表名/表中数据

 

 

5、在sever sql 中变量分为局部变量和全局变量 ,声明局部变量用declare,变量名称的前面要有@字符。

6、全局变量: 。

7.1.1、其中数据类型要注意:decimal 和numeric

 

语法: decimal(p,s) --其中p:代表数的总位数,s:代表小数点后的小数位数。
numeric的语法与decimal类似的。

 

 

 7.2.1、货币类型:

money/smallmoney

7.3.1、日期和时间数据类型

7.4.1、二进制数据类型;

binary[n] :如果没有指定n的值,则默认为1

7.5.1:其他数据类型:

timestamp:行版本,在创建表的时候无需给出列名,插入数据的时候也不用管。

                                                                

posted @ 2017-11-22 00:31  Turtle_Zhang  阅读(495)  评论(0编辑  收藏  举报