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 ...
随机推荐
- noi.openjudge 1.13.44
http://noi.openjudge.cn/ch0113/44/ 总时间限制: 1000ms 内存限制: 65536kB 描述 将 p 进制 n 转换为 q 进制.p 和 q 的取值范围为[2 ...
- mysql 变量定义 sql查询
SET @idnoStr:='"idNo":"'; SELECT LOCATE(@idnoStr, param_array), LOCATE('",', par ...
- django 跨域解决方案
使用django-cors-headers模块 github:https://github.com/ottoyiu/django-cors-headers 官方文档中有详细说明 简要配置 1.安装 p ...
- db mysql / mysql cluster 5.7.19 / my.cnf / max_binlog_cache_size / binlog
s mysql修改binlog保存的天数 https://blog.csdn.net/Hu_wen/article/details/80582013 查看binlog过期时间,设置的时间为90天,这个 ...
- Hbase记录-Hbase配置项
hbase.tmp.dir:本地文件系统的临时目录,默认是java.io.tmpdir/hbase−java.io.tmpdir/hbase−{user.name}: hbase.rootdir:hb ...
- lnk快捷方式变记事本打开还原,桌面图标变lnk还原方法
今天天碰到一坑爹问题,打开一个.ini文件自动设置用记事本打开,所有快捷方式都变成记事本打开了,如下图,网上找了一些方法. windows中LNK文件打开方式恢复 相信有些用户曾试过错误地把LNK文件 ...
- JavaScript中调皮的undefined
JavaScript中调皮的undefined 在JavaScript中undefined只是一个标识符,不是关键字,这个很不靠谱的标识符还不能像其他符号一样随意使用,一方面是需要它的原始值保持不变, ...
- IPython--转
IPython使用学习笔记 学习<利用python进行数据分析>第三章 IPython:一种交互式计算和开发环境的笔记,共享给大家,同时为自己作为备忘用. 安装ipython用pip即可. ...
- 分布式中的 transaction log
分布式中的 transaction log 在分布式系统中,有很多台node组成一个cluster,对于client 的一个写操作请求而言,在什么样的情况下,cluster告诉client此次写操作请 ...
- vue2.0 子组件 父组件之间的传值
常用的子组件给父组件传值/调父组件方法 //子组件let val = "";//可以是任意类型this.$emit('fatherFun', val); //父组件<fath ...