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 ...
随机推荐
- Codeforces Round #525 (Div. 2)
Codeforces Round #525 (Div. 2) 哎,忍不住想吐槽一下,又要准备训练,又要做些无聊的事,弄得我都想退出了. 好好的训练不好么???? 只能做出两道水题,其实C题,感觉做出来 ...
- Codeforce 886 Технокубок 2018 - Отборочный Раунд 3 C. Petya and Catacombs(结论题)
A very brave explorer Petya once decided to explore Paris catacombs. Since Petya is not really exper ...
- request.getSession()几种获取情况之间的差异
一.三种情况如下 HttpSession session = request.getSession(); HttpSession session = request.getSession(true); ...
- go websocket
websocket介绍 The WebSocket Protocol RFC6455,这个是WebSocket的RFC文档,所以内容非常全面(当然只涉及协议,不涉及具体实现),不过内容太多,如果是初 ...
- 关于交叉熵(cross entropy),你了解哪些
二分~多分~Softmax~理预 一.简介 在二分类问题中,你可以根据神经网络节点的输出,通过一个激活函数如Sigmoid,将其转换为属于某一类的概率,为了给出具体的分类结果,你可以取0.5作为阈值, ...
- logstash日志采集工具的安装部署
1.从官网下载安装包,并通过Xftp5上传到机器集群上 下载logstash-6.2.3.tar.gz版本,并通过Xftp5上传到hadoop机器集群的第一个节点node1上的/opt/uploads ...
- python科学计算
windows下python科学计算库的下载地址:http://www.lfd.uci.edu/~gohlke/pythonlibs/(由于C运行库的问题,scipy在linux下可以用pip安装,而 ...
- ****** 二 ******、软设笔记【数据结构】-KMP算法、树、二叉树
五.KMP算法: *KMP算法是一种改进的字符串匹配算法. *KMP算法的关键是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的.具体实现就是实现一个next()函 ...
- 基于DSP的IS95正向业务信道模块设计
**定时20ms循环处理话音数据包*** *伪指令不占空间不影响执行速度,只是定义和描述但对汇编链接有重要指示作用 ********************************* .title & ...
- luogu 1314 聪明的质检员
二分答案的边界问题还是要注意 double挨着,int+1-1, 此题用到long long,所以初始化ans要足够大,前缀和优化 依然根据check答案大小左右mid,虽然有s,但是有了+1-1加持 ...