Sqlserver

一、Sqlserver简介

SQL Server一开始并不是微软自己研发的产品,而是当时为了要和IBM竞争时,与Sybase合作所产生的,其最早的发展者是Sybase[1],同时微软也和Sybase合作过SQL Server 4.2版本的研发,微软亦将SQL Server 4.2移植到Windows NT(当时为3.1版),在与Sybase终止合作关系后,自力开发出SQL Server 6.0版,往后的SQL Server即均由微软自行研发。

在与微软终止合作关系后,Sybase在Windows NT上的数据库产品原本称为Sybase SQL Server,后来改为现在的Sybase Adaptive Server Enterprise

Sqlserver 6.0之前版本都是与sybase联合研发,在SQL Server for Windows NT之后从sybase手中买断sqlserver著作权开始自主研发。Sqlserver 2017开始支持linux系统。

二、Sqlserver架构

Sqlserver架构与mysql、oracle不同(在SQL 2000数据库用户名称架构是绑定的,一个完整的表的名称包括了服务器名.数据库名.用户名.对象名,2005时为服务器名.数据库名.架构名.对象名,2008版本之后取消了用户和其创建对象的关联),在一个sqlserver实例下可以创建多个数据库实例,每个数据库实例中可以创建多个模式,模式下才有表和视图

sql server na sqlserver哪个公司_SQL

 

Sql Server只保存视图的元数据,用户描述这个对象,以及它所包含的列,安全,依赖等。当你查询视图时,无论是获取数据还是更新数据,Sql server都用视图的定义来访问基础表;视图在我们日常操作也扮演着许多重要的角色,比如可以利用视图访问经过筛选和处理的数据,而不是直接访问基础表,以及在一定程度上也保护了基础表。

视图的作用:

1、视图隐藏了底层的表结构,简化了数据访问操作,客户端不在需要知道底层的结构及其之前的关系。

2、视图提供了一个统一访问数据的接口。(即可以允许用户通过视图访问数据的安全机制,而不授予用户直接访问底层表的权限)

3、加强了安全性,时用户只能看到视图所显示的数据

4、视图还可以被嵌套,一个视图中可以嵌套另一个视图

 

三、使用

连接工具:Navicat、Microsoft SQL Server Management Studio,推荐使用后者,毕竟这是微软专门配套的工具。通过Microsoft SQL Server Management Studio导出表结构、数据都是很容易实现的。右键点击库名选择任务-->生成脚本-->点击下一步选择需要导出的表或者视图(选择导出结构还是数据)-->一直下一步就可以了。最后脚本会导出到指定的文件夹下。

1、Join

对于普通的增删改查与其他数据库没有多大区别,而且在sqlserver中可以跨模式、跨库进行关联查询。

跨模式:

sql server na sqlserver哪个公司_SQL_02

sql server na sqlserver哪个公司_数据库_03

 

跨库:

sql server na sqlserver哪个公司_Server_04

 

sql server na sqlserver哪个公司_Server_05

 

同一库下跨模式需要带上模式名,跨库关联需要带上库名、模式名。

另外我们可能会遇到数据是汉字乱码的情况,这时需要我们修改sqlserver编码,

对某个库设置编码sql:

sql server na sqlserver哪个公司_Server_06

 

将数据先设置为单用户模式,修改字符编码后在设置为多用户模式。若不先设置为单用户模式数据库被占用无法修改编码。

2、查看执行计划

对图中这条sql查看执行计划(点击上方工具栏显示估计的执行计划,也可以使用快捷见Ctrl+L)如下图:

 

sql server na sqlserver哪个公司_Server_07

 

从图中可以得出以下几点信息:

(1)、各阶段执行开销

(2)、各阶段执行什么样的操作

(3)、各阶段数据量(通过线条粗细来表示的)

通过这些信息对一些慢查询做针对性的优化非常有帮助。

3、元数据查询

在日常开发中,我们可能对数据的关注的会比较多,但是对于元数据多一些了解对于开发是很有帮助的。这里简单介绍一下sqlserver的元数据管理。

(1)、获取库下所有用户表(u:用户表,s:系统表)



select Name from sysobjects where xtype='u' and status>=0;



 (2)、获取某一个表的所有字段



select name from syscolumns where id=object_id('表名')



(3)、查询用户创建的所有数据库



select d.*,s.name from master..sysdatabases D join master..syslogins s on d.sid=s.sid;



 (4)、查询某一个表的字段和数据类型



select * from information_schema.columns where table_name = 'student_type';



除此之外,还有两个语句可以获取比较详细的信息:

1)、sp_help tableName

 

2)、sp_columns tableName

推荐使用sp_help tableName,获取的信息比较全面。

有时我们还需要获取表、字段相关的注释信息,可使用如下sql:

表注释:



SELECT

a.NAME,

b.VALUE

FROM

sys.TABLES a

JOIN sys.extended_properties b ON a.object_id = b.major_id

JOIN sys.SCHEMAS c ON c.schema_id = a.schema_id

WHERE

b.minor_id = '0'

AND c.NAME = 'dbo'

AND a.NAME = 'student_type';



  

字段注释:



SELECT

b.NAME,

a.VALUE

FROM

sys.extended_properties a

JOIN sys.COLUMNS b ON a.minor_id = b.column_id

WHERE

a.major_id = OBJECT_ID ( 'dbo.student_type' )

AND b.object_id = a.major_id;



  

了解相关元数据信息有时会为我们带来很多便利。同时也能更有效的利用数据库帮助我们处理相关业务。

四、数据库对比

这里主要对三大数据库作比较:mysql、mssql、oracle

 

mysql

mssql

oracle

 

 

 

优点

存储、响应快,支持多种语言,用户安全性高,是较为单纯的数据存储

提供一整套的数据解决方案,良好的读写性能。容易维护监控支持扩展sql语法。存储过程支持图形化编辑界面记录

支持用户选择不同解决方案,安全性高,性能高效稳定,风险低,扩展、伸缩行好

 

缺点

不支持热备,没有存储过程记录

安全性地,多用户时性能低,伸缩扩展行不是很好

价格贵,成本高。管理维护比较麻烦,操作复杂,技术要求高