热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SQLSever2008R2数据库管理

一、预备知识提要:1.创建数据库需要的权限至少要拥有:(1)createdatabase;(2)createanydatabase;(3)alteranydatabase2.数据库的上限在同一实例中,最多可以创建32767个数据库,超过则会失败!3.数据库文件和文件组每个SQLServer2008数据库至

  一、预备知识提要:

  1. 创建数据库需要的权限

  至少要拥有:

  (1)create database;

  (2)create any database;

  (3)alter any database

  2. 数据库的上限

  在同一实例中,最多可以创建32767个数据库,超过则会失败!

  3. 数据库文件和文件组

  每个SQL Server 2008数据库至少包括2个文件:

  (1)数据文件 : 包含的是 数据库的数据和对象。它分为:主要数据文件和次

  要数据文件,扩展名分别为 .mdf和.ndf

  (2)日志文件 : 包含的是 用于恢复数据库时所需要的信息。它分为:主要日志

  文件和次要日志文件,扩展名都为.ldf

  技巧:

  在默认情况下,数据库的数据文件和日志文件都保存在同一目录下,但这并

  不是最佳方案,为了提高存储速度,

  强烈建议:

  将数据文件和日志文件保存在不同的驱动器上!

  文件组

  为了方便对数据库文件进行管理,可以将数据库文件集中起来放在文件组中.

  每个数据库都有一个主要文件组.该组包括主要数据文件和未放入其他文件组的

  所有次要文件。当然用户也可自行定义不同的文件组。

  4. 数据库状态

  SQL Server 2008数据库永远处于特定的状态中,包括7种状态:

  (1)online : 可以对数据进行访问。(在线)

  (2)offline: 数据库无法使用。(离线)

  (3)restoring : 表示正在还原主文件组的一个或多个文件,或正在离线还原一个

  或多个辅助文件,此时数据库不可用。(还原)

  (4)recovering : 表示正在恢复数据库。该状态是个暂时性的状态,恢复成功

  后,数据库会自动回到在线状态。(恢复)

  (5)recovering pending : 此时数据库并未损坏,但很有可能缺少文件。此时

  数据库不可用,并等待用户执行操作来完成恢复工作。(恢复等待)

  (6)suspect : 表示数据库里的文件组(至少是主文件组)可疑或已经损坏,SQL

  Server 2008启动过程无法恢复数据库,此时数据不能使用。(可疑)

  (7)emergency : 一般用于故障排除。此时数据库处于单用户模式,可以修复

  或还原。数据库标记为只读,并禁用日志记录,只有具备sysadmin服务

  器角色的成员才能访问。(紧急)

  二、 举例说明

  例一: 创建一个数据库,所有的设置采用默认值.

  create database 测试数据库

  例二: 创建一个数据库,指定数据库的数据文件所在位置.

  create database 例二数据库

  on

  (

  name='例二数据库',

  filename='d:DBtest例二数据库.mdf'

  )

  例三:创建一个数据库,指定数据库的数据文件所在位置、初始容量、最大容量

  和文件增长的数量。

  create database 例三数据库

  on

  (

  name='例三数据库',

  filename='d:DBtest例三数据库.mdf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  )

  例四: 创建一个数据库,指定数据库的数据文件和日志文件所在位置.

  create database 例四数据库

  on

  (

  name='例四数据库数据文件',

  filename='D:DBtest例四数据库数据文件.mdf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  )

  log on

  (

  name='例四数据库日志文件’,

  filename='D:DBtest例四数据库日志文件.ldf'

  )

  例五:创建一个数据库,它总共包含五个数据文件和两个自定义的文件组。

  create database 例五数据库

  on

  (

  name='例五数据库数据文件1',

  filename='d:DBtest例五数据库数据文件1.mdf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  ),(

  name='例五数据库数据文件2',

  filename='d:DBtest例五数据库数据文件2.ndf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  ),

  filegroup 例五数据库数据文件组1

  (

  name='例五数据库数据文件组1的数据文件',

  filename='d:DBtest例五数据库数据文件组1的数据文件.ndf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  ),

  filegroup 例五数据库数据文件组2

  (

  name='例五数据库数据文件组2的数据文件1',

  filename='d:DBtest例五数据库数据文件组2的数据文件1.ndf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  ),(

  name='例五数据库数据文件组2的数据文件2',

  filename='d:DBtest例五数据库数据文件组2的数据文件2.ndf',

  size=5MB,

  maxsize=10MB,

  filegrowth=5%

  )

  log on

  (

  name='例五数据库日志',

  filename='d:DBtest例五数据库日志文件.ldf'

  )

  例六: 创建一个数据库,并指定排序规则。

  create database 例六数据库

  on

  (

  name='例六数据库',

  filename='d:DBtest例六数据库.mdf'

  )

  collate Chinese_PRC_CI_AS

  在使用collate指定排序规则之前,一定要先知道排序规则名。

  为何才能知道排序规则名呢?请用下面的SQL语句查询:

  select * from ::fn_helpcollations ()

  三、修改数据库设置

  1. 使用SQL Server Management Studio修改数据库设置

  1) 查看数据库的基本信息

  【数据库属性】---【 基本】选项页里,可以看到数据库的基本信息。

  2) 增加、删除与修改数据库文件

  【数据库属性】---【文件】选项页里。

  重点: 典型案例

  例七: 将名为"例二数据库"的数据库改名为"例七数据库"。

  方法一:

  alter database 例二数据库

  modify name = 例七数据库

  方法二:

  exec sp_renamedb '例二数据库','例七数据库'

  ------------------------------------------------------

  例八:为“例六数据库”增加一个数据文件。

  alter database 例六数据库

  add file (name=增加的数据文件,

  filename='d:DBtest例六数据库增加的数据文件.ndf')

  --------------------------------------------------------

  例九:为“例六数据库”增加一个日志文件。

  alter database 例六数据库

  add log file (name=例九增加的日志文件,

  filename='d:DBtest例九增加的日志文件.ldf',

  size=3MB,

  maxsize=50MB,

  filegrowth=10% )

  --------------------------------------------------------

  例十:将“例六数据库”中名为“增加的数据文件”的数据文件改名。

  alter database 例六数据库

  modify file(name=增加的数据文件,

  newname = 例十数据文件,

  filename = 'd:DBtest例十数据文件.ndf')

  例十一: 修改’例六数据库’的排序规则

  alter database 例六数据库

  collate Chinese_PRC_CI_AS_KS

  例十二: 在’例六数据库’里删除一个数据文件.

  alter database 例六数据库

  remove file 例十数据文件

  例十三: 在’例六数据库’里添加一个文件组

  alter database 例六数据库

  add filegroup 例十三文件组

  例十四: 在’例六数据库’里为一个文件组改名.

  alter database 例六数据库

  modify filegroup 例十三文件组

  name=例十四文件组

  例十五: 在’例六数据库’里添加一个数据文件(如:例十五数据文件)到一个文件组(如:例十四文件组),并将该文件组设置为默认文件组.因alter database一次只能修改数据库的一个属性,故下例中使用了2个alter database语句.

  alter database 例六数据库

  add file (name=例十五数据文件,

  filename=’d:DBtest例十五数据文件.ndf’)

  to filegroup 例十四文件组

  go

  alter database 例六数据库

  modify filegroup 例十四文件组 default

  例十六: 在“例六数据库”里删除“例十四文件组”.由于“例十四文件组”是默认文件组,其中又包含了一个文件(例十五数据文件).故,要从“例六数据库”中删除“例十四文件组”,必须先进行以下操作:

  (1)将其他文件组设置为默认文件组,如本例中将PRIMARY文件组设置为默认文件组。

  由于PRIMARY是保留字,故在使用它的时候,要用方括号括起来。

  alter database 例六数据库

  modify filegroup [PRIMARY] default

  (2)删除“例十四文件组”中包含的“例十五数据文件”。

  alter database 例六数据库

  remove file 例十五数据文件

  (3)删除“例十四文件组”。

  alter database 例六数据库

  remove filegroup 例十四文件组

  例十七:将“例六数据库”里的一个文件组设置为只读。

  (1)由于primary文件组是不能设置为只读的,故先添加一个文件组(如:例十七文件组)。

  alter database 例六数据库

  add filegroup 例十七文件组

  (2)由于空文件组(如:例十七文件组)是不能设置为只读的,所以要再添加一个文件(如:例十七数据文件)到该文件组中。

  alter database 例六数据库

  add file (name=例十七数据文件,

  filegroup=’d:Dbtest例十七数据文件.ndf’)

  to filegroup 例十七文件组

  (3)将文件组(例十七文件组)

  alter database 例六数据库

  modify filegroup 例十七文件组 read_only

  例十八:将“例六数据库”设置为只有一个用户可访问。

  alter database 例六数据库

  set single_user

  例十九:设置“例六数据库”可自动收缩。

  alter database 例六数据库

  set auto_shrink on


推荐阅读
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 本文详细介绍 Go+ 编程语言中的上下文处理机制,涵盖其基本概念、关键方法及应用场景。Go+ 是一门结合了 Go 的高效工程开发特性和 Python 数据科学功能的编程语言。 ... [详细]
  • Valve 发布 Steam Deck 的新版 Windows 驱动程序
    Valve 最新发布了针对 Steam Deck 掌机的 Windows 驱动程序,旨在提升其在 Windows 环境下的兼容性、安全性和性能表现。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
  • 资源推荐 | TensorFlow官方中文教程助力英语非母语者学习
    来源:机器之心。本文详细介绍了TensorFlow官方提供的中文版教程和指南,帮助开发者更好地理解和应用这一强大的开源机器学习平台。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 计算机网络复习:第五章 网络层控制平面
    本文探讨了网络层的控制平面,包括转发和路由选择的基本原理。转发在数据平面上实现,通过配置路由器中的转发表完成;而路由选择则在控制平面上进行,涉及路由器中路由表的配置与更新。此外,文章还介绍了ICMP协议、两种控制平面的实现方法、路由选择算法及其分类等内容。 ... [详细]
  • 本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ... [详细]
  • This guide provides a comprehensive step-by-step approach to successfully installing the MongoDB PHP driver on XAMPP for macOS, ensuring a smooth and efficient setup process. ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
author-avatar
挽木城祠_
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有