当前位置: 首页 > article >正文

数据库的概念和操作

目录

1、数据库的概念和操作

1.1 物理数据库

1. SQL SERVER 2014的三种文件类型

2. 数据库文件组

1.2 逻辑数据库

2、数据库的操作

2.1 T-SQL的语法格式

2.2 创建数据库

2.3 修改数据库

2.4 删除数据库

3、数据库的附加和分离


1、数据库的概念和操作

1.1 物理数据库

数据库在磁盘上以文件为单位存储,SQL Server 2014将数据库映射为一组操作系统文件。

1. SQL SERVER 2014的三种文件类型

主数据文件(.mdf):每个数据库有且仅有一个主数据文件.。

辅助数据文件(次数据文件.ndf):0~N个,主数据文件容量不足,存到辅助数据文件。

事务日志文件(.ldf):>=1个,用于恢复数据库的日志信息。

2. 数据库文件组

文件的集合,简化数据的存放和管理。

主文件组(primary):主数据文件+未放入其他文件组辅助数据文件

用户定义文件组:可以收集辅助数据文件。

1.2 逻辑数据库

数据库存储数据容器

组成数据库逻辑成分,为数据库对象,SQL Server 2014包括表,视图,存储过程,触发器,函数等等。数据库+数据库对象的创建,修改,删除用的是DDL。

SQL Server 2014有两类数据库,系统数据库用户数据库

系统数据库

1. master 数据库

master 数据库是SQL Server 2014中最重要的数据库,是整个数据库服务器的核心存放基本信息,应定期备份

2. model 数据库

model 数据库是SQL Server 2014中创建数据库的模板

3. msdb 数据库

msdb 数据库提供运行SQL Server Agen任务的信息 SQL Server Agent是SQL Server中的一个Windows服务,用来运行制定的计划任务。

4. tempdb 数据库

tempdb 数据库是SQL Server 2014中的一个临时数据库存放临时变量和中间结果关闭SQL Server 2014,tempdb数据库内容会被清空

2、数据库的操作

2.1 T-SQL的语法格式

{ }:里面的内容必须写

[ ]:里面的内容可选

[,...n]:可写多个,用,分隔

A | B | C只能选一个

< >:是一个语法块

接下来的代码,

全大写的单词->关键字(关键字不区分大小写,我是为了是代码更清晰,才全大写)

小写的单词->用户自己定义

注意数据库中的字符串用单引号。'D:\data\student_data.mdf',路径用   \   。

代码是选中执行。

2.2 T-SQL创建数据库

CREATE DATABASE database_name
[ON [PRIMARY] 
<filespec>[,...n]]
[,FILEGROUP filegroup_name
<filespec>[,...n]]
[LOG ON
<filespec>[,...n]]

<filespec> ::={(
NAME = logic_file_name,  -- 逻辑名是数据库中文件名,没有后缀名。
FILENAME = '',  -- 文件的路径,有后缀名。
[,SIZE = size[KB|MB|GB|TB] -- 默认MB
[,MAXSIZE = {maxsize[KB|MB|GB|TB] | UNLIMITED}] -- 默认MB
[,FILEGROWTH = growth_increment[KB|MB|GB|TB|%]]) -- 默认MB
}

例:

-- 先在D盘创建data文件夹
create database student
on primary(
name = 'student_data',
filename = 'D:\data\student_data.mdf',
size = 5,
maxsize = 20,
filegrowth = 5%)
,filegroup fp1(
name = 'student_1',
filename = 'D:\data\student_1_data.ndf',
size = 2,
maxsize = 20,
filegrowth = 1
)
log on(
name = 'student_log',
filename = 'D:\data\student_log.ldf',
size = 3,
maxsize = 10,
filegrowth = 1)

2.3 T-SQL修改数据库

一次只能执行一个命令

ALTER DATABASE database_name
{ADD FILE<filespec>[,...n][TO FILEGROUP filegroup_name] -- 一般添加数据文件
|ADD LOG FILE<filespec>[,...n] -- 添加日志文件
|REMOVE FILE logic_file_name  -- 删除数据或日志文件
|MODIFY FILE<filespec>  -- 修改数据或日志文件
|ADD FILEGROUP filegroup_name -- 添加文件组
|REMOVE FILEGROUP filegroup_name -- 删除文件组
|MODIFY NAME = new_dbname -- 修改数据库名
}

也可以使用sp_renamedb old_name new_name,改数据库名 。

如:修改文件的大小

-- 如:修改文件的大小
alter database student
modify file(
name = 'student_1',
filename = 'D:\data\student_1_data.ndf',
size = 8
) 

2.4 T-SQL删除数据库

DROP DATABASE database_name[,...n]

3、数据库的附加和分离

用于数据库备份迁移操作。


http://www.kler.cn/a/458892.html

相关文章:

  • Pytorch | 利用DTA针对CIFAR10上的ResNet分类器进行对抗攻击
  • node.js之---单线程异步非阻塞 I/O
  • [pdf、epub]260道《软件方法》强化自测题业务建模需求分析共216页(202412更新)
  • 【Vim Masterclass 笔记04】S03L12:Vim 文本删除同步练习课 + S03L13:练习课点评
  • Matlab Hessian矩阵计算
  • 我们能否使用 ANSYS SPEOS 测量水质?
  • Mysql高级
  • 天通卫星技术,保障无信号区域的高效通信与监测
  • C++笔记4:C和C++混合编程,C不能识别C++的类内函数编译报错怎么办
  • 【优选算法】Sliding-Chakra:滑动窗口的算法流(下)
  • 【uni-app】微信小程序使用lime-painter生成海报
  • 区块链安全常见的攻击分析——私有数据泄露 (Private Data Exposure)【7】
  • Javascript数据结构——图Graph
  • C++ 设计模式:代理模式(Proxy Pattern)
  • 力扣第116题:填充每个节点的下一个右侧节点指针 - C语言解法
  • 代码随想录day21 | leetcode 77.组合 77.组合 加剪枝操作 216.组合总和III
  • [图形渲染]【Unity Shader】【游戏开发】 Shader数学基础17-法线变换基础与应用
  • Java:192 基于SSM框架的失物招领信息管理系统
  • debian12安装docker
  • Linux的进程替换以及基础IO
  • 初学stm32 --- 高级定时器PWM输入模式
  • Github 2024-12-26 Go开源项目日报 Top10
  • (二)当人工智能是一个函数时,怎么去训练它?
  • 【机器学习】机器学习的基本分类-半监督学习-Ladder Networks
  • 【day20】集合深入探讨
  • Optional类:避免NullPointerException