Microsoft SQL - 数据库管理系统
数据库管理系统(Server Management Studio)
SQL Server Management Studio是一个数据库管理系统软件,数据库可以看成是一个个存储数据的文件,而Management Studio就是用来管理各个数据库的软件,我们并不需要直接访问数据库,所有操作都是通过此软件(DBMS)来完成。它可以替我们访问数据库。
系统数据库(system DB)
master数据库
该数据库保存了一系列的系统表,用于管理整个数据库系统。当你在数据库管理软件中创建一个新的数据库时,系统将向master数据库中的sysdatabase表中插入一条新的纪录,且所有的系统存储
过程和自定义的存储过程,无论它们位于哪个数据库,实际上它们都存储在master数据库中,所有描述服务器的信息也都存储于此。
model数据库
为用户创建的数据库提供数据库模版。
msdb数据库
是sql代理执行任务的地方,比如计划夜间对数据库进行备份操作,那么在这个数据库中会生成一条记录。
tempdb数据库
在执行大量复杂的sql语句时,SQL Server可能会在这个数据库中创建一些临时的中间表用于计算,这个数据库本身也是临时的,在你每次启动数据库管理软件时,该数据库都会完全重新创建。
事务日志
你对数据库所做的任何修改更新操作实际上最早做出响应的是事务日志文件,所有操作都被记录在事务日志里,然后系统发出一个检查点,检查所有操作是否合法,完全合法后才会将数据录入数据库
中。数据到达磁盘上的最初地方是事务日志文件,被检查合法后才会传送到实际的数据库文件中。性能良好的数据库既需要数据库文件,也需要事务日志文件。
数据库文件(data file)
数据库主文件(.mdf)
每个数据库都有一个且只能有一个主文件(Primary) 后缀是.mdf,该文件存储了数据库中的所有事物和表,这个文件是磁盘路径上存在的一个实体。 比如你创建了一个数据库mydb1的数据库,那么其物理路径可能如下:
重新装系统后,你可以将这个文件附加到数据库管理软件中,但mdf需要权限,右击mdf文件取得完全控制才能附加成功。
数据库日志文件(.ldf)
日志文件用于收集操作数据库的信息记录,便于查看操作数据库的信息,该文件可有可无,但最好创建它。
数据库辅助文件(.ndf)
辅助文件用于备份+还原数据库,该文件可有可无。 辅助文件可加入到主文件组中,你也可以创建辅助文件组,将辅助文件加入到辅助文件组中。尽管只能有一个主文件组 但可以有255个辅助文件。
表(table)
数据库由许多事物构成,而表是其最重要的一环。数据都存储在表结构中。
列(字段)(Column)
表由列和行构成,可以是一列或以上。每个列都应指定它可以存储的数据类型,如数字、日期、字符串、金额……
行(记录)(Row)
每个行都存储一组列所指定的数据类型。比如一个员工信息表,每个行可以代表每个员工的具体信息,即一行代表的就是其中一个员工的信息。通常意义上来说人们说的一条记录就是指的一行。
主键(Primary Key)
每一行的某个列应定义为主键,主键可以用来标识该行具有唯一性。比如员工ID、学员编号等等,使用主键的最佳实践应为:不更新主键列中的值、不重用主键列中的值。
外键(Foreign key)
外键可以将多张表建立联系,节省数据量,可以节约数据占用数据库的空间。
索引(Index)
索引存储了键值,根据键值可查找需要的数据。索引分为聚集索引和非聚集索引。
聚集索引
每个表只能有一个聚集索引,相当于百科全书中的页码。
非聚集索引
每个表可以有n个非聚集索引,类似关键字的索引。
约束(Constraint)
限定表中列的数据,提供约束。
视图(view)
视图本身不存储数据,它获取一张或n张表的数据,将它们结合起来显示。通过视图可以决定哪些表的内容可以开放给用户查看,哪些则不。视图可以执行insert、delete、update操作,所有这些操
作都会影响到视图所引用的原表,即原表也会发生数据变化。
触发器(Trigger)
当表发生特定的事件时(如:插入、删除、修改)自动执行的一段逻辑代码,类似于事件处理器。
操作表
你可以使用图形界面创建、操作表,也可以使用TransSQL语句达到同样的目的。
null值
在使用图形界面操作表时,如果你要插入一个null值可以使用ctrl+0,这有别于系统默认的null,ctrl+0插入的null被认为是一个有效的数据,而系统默认的null则被认为是不存在的数据。而空字符、空格不是null。
数据量限制
每个表最多定义250个字段。每个记录的最大长度限制为1962个字节(文本与图像数据除外)。
数据库常见术语
列:一个字段
行:一条记录
属性:列可以看成是行的属性,即字段是记录的属性。
域:列的取值范围
关联:一张表对应多张表,即多张表建立了一对多的关系,表的关联一共有四种方式:一对多、多对一、一对一、多对多,这个关系以每张表都有一个相同的字段值(关键字)为连接建立起关系。
关键字:某个列的独立的值,它能代表每条记录的唯一性。
外部关键字:某列不是当前表的关键字,但它是另一张表的关键字。
数据冗余:表中的重复数据。
数据库选项
限制访问可选择多用户、单用户和管理员、特定成员。
数据库分离、附加与删除
分离
右键数据库可以将其与Magement管理器分离,分离后可以拷贝数据库文件到其它计算机。
附加
通过右键数据库-附加,可以把数据库文件附加到另一台计算机的Magement管理器中。无法附加时考虑:
1.修改数据库文件mdf和ldf的访问权限,右击它们-安全。
2.windows身份登录Magement管理器再进行附加。
删除
删除即彻底删除磁盘上的数据库文件。
表的外键
找到外键表-右击设计-右击字段-关系-表与列规范-选择主表与从表即可。
将数据库导出为脚本
右击数据库-任务-生成脚本-选择对象后-设置脚本编写选项-高级-要编写脚本的数据的类型可选择架构、数据等,选数据则只生成insert语句
Microsoft SQL - SQL SERVER学习总目录
Microsoft SQL - 数据库管理系统的更多相关文章
- 第八课: - 从Microsoft SQL数据库读取
第 8 课 如何从Microsoft SQL数据库中提取数据 In [1]: # Import libraries import pandas as pd import sys from sqlalc ...
- Microsoft SQL - 学习总目录
Microsoft SQL - 数据库管理系统 Microsoft SQL - 数据类型 Microsoft SQL - 查询与更新 Microsoft SQL - 操作语句 Microsoft SQ ...
- Microsoft SQL Server(sql server 关系型数据库管理系统)
sql server一般指Microsoft SQL Server 关系型数据库管理系统 Microsoft SQL Server 是一个全面的数据库平台,使用集成的商业智能 (BI)工具提供了企业级 ...
- Jmeter—8 连接microsoft sql server数据库取数据
本文以Jmeter 连接microsoft sql server为例. 1 从微软官网下载Microsoft SQL Server JDBC Driver 地址:http://www.microsof ...
- Microsoft SQL Server,附加数据库 错误:Error 916解决方法
错误信息:错误提示:标题: Microsoft SQL Server Management Studio Express —————————— 无法为此请求检索数据. (Microsoft.SqlS ...
- sql System.Data.SqlClient.SqlError: 无法覆盖文件 'C:\Program Files\Microsoft SQL Server\MSSQL\data\itsm_Data.MDF'。数据库 'my1' 正在使用该文件的解决方案
对数据库备份进行还原时遇到“sql System.Data.SqlClient.SqlError: 无法覆盖文件 'C:\Program Files\Microsoft SQL Server\MSSQ ...
- 数据库备份和恢复秩序的关系(周围环境:Microsoft SQL Server 2008 R2)
让我们来看看在备份序列新手 --1.塔建环境(生成测试数据和备份文件) /* 測试环境: Microsoft SQL Server 2008 R2 (RTM) - 10.50.1600.1 (X64) ...
- Microsoft SQL Server 数据库 错误号大全
panchzh :Microsoft SQL Server 数据库 错误号大全0 操作成功完成. 1 功能错误. 2 系统找不到指定的文件. 3 系统找不到指定的路径. 4 系统无法打开文件. 5 拒 ...
- 使用Microsoft SQL Server Migration Assistant for Oracle迁移数据库
前言:使用Microsoft SQL Server Migration Assistant for Oracle迁移Oracle数据库到SqlServer数据库. 准备:Oracle11g.SqlSe ...
随机推荐
- Tomcat源码组织结构
Tomcat 源码组织结构 目录结构 这里所介绍的目录结构,是使用CATALINA-BASE变量定义的路径,如果没有通过配置多个CATALINA-BASE目录来使用多实例,则CATALINA-BASE ...
- (贪心) nyoj1036-非洲小孩
题目描述: 家住非洲的小孩,都很黑.为什么呢?第一,他们地处热带,太阳辐射严重.第二,他们不经常洗澡.(常年缺水,怎么洗澡.)现在,在一个非洲部落里,他们只有一个地方洗澡,并且,洗澡时间很短,瞬间有木 ...
- 42套JavaScript深度解析教学视频!合集
本文首发于:风云社区SCOEE(社区旨在普惠软件.图片.音乐.视频.素材.文档等互联网资源.为大众提供多样化的服务,以及主要涵盖学术科学.电脑技术.文化人文.体育健身等领域的知识和信息,获得用户的支持 ...
- mybatis多数据源报错
2018-12-06 16:58:35,709 [ main ] - [ INFO ] [ org.springframework.core.KotlinDetector : 57 ] - Kotli ...
- 10 个 Linux 中方便的 Bash 别名
10 个方便的 Bash 别名 1. 你有几次遇到需要解压 .tar 文件但无法记住所需的确切参数?别名可以帮助你!只需将以下内容添加到 .bash_profile 中,然后使用 untar File ...
- [JUC-1]并发包实现及线程状态
一.Java 并发包实现 二.Java 线程状态转换图
- 【转载】C# 字符串截取
https://blog.csdn.net/maba007/article/details/78424760
- DingDing的CorpSecretID和SSOSecret不是一个东西
今天客户更新系统后,提供了一对corpid和secret,结果同步钉钉考勤机数据时,一直提示corpid和secret不正确,最后询问钉钉官方人员发现,客户提供的是SSOSecret,应该使用Copr ...
- 29. SpringBoot Redis 非注解
1. 引入依赖 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spr ...
- JavaSE回顾及巩固的自学之路(一)——————前言
长长的呼出一口气,终于到了末端了,JavaSE,Java入门的基础,历经一个多月,终于细细的学了一遍,大部分的时间都是熬夜到半夜两点钟.本来是一个月的课程,足足让我给学了将近两个月,为什么呢?第一,还 ...