SQL Server 数据库镜像:高可用性和灾难恢复的更佳解决方案 (sql server 数据库镜像)

随着企业业务数据的不断增多,数据安全和数据可靠性问题日益受到企业的重视。为了保证数据的高可用性和灾难恢复能力,很多企业都采用了数据库镜像技术。SQL Server 数据库镜像是一种高可靠性和灾难恢复的解决方案,它在数据库服务器之间复制数据库,并且在主数据库服务器出现故障的情况下实现快速自动切换到备用数据库服务器。本文将介绍 SQL Server 数据库镜像技术的优势和应用,以及数据库镜像技术的部署和管理。

一、SQL Server 数据库镜像技术的优势和应用

SQL Server 数据库镜像技术的主要优势是高可用性和灾难恢复能力。数据库镜像技术可以在主数据库服务器和备用数据库服务器之间保证数据的一致性,并且能够快速自动切换到备用服务器,从而避免数据库宕机导致的业务停摆。此外,数据库镜像技术还可以应用于多种场景,包括:数据中心的主备切换、地理位置分布式和异构数据库之间的数据迁移等。

二、SQL Server 数据库镜像技术的部署和管理

SQL Server 数据库镜像技术的部署和管理需要分为主服务器和备用服务器两个部分分别进行配置。下面我们将介绍数据库镜像技术的部署和管理。

2.1 配置主服务器

1. 首先在主服务器上创建一个数据库。

2. 进入主数据库的属性页面,在“选项”页面中,将“数据库镜像”设置为“全。”。

3. 创建一个用于镜像的登录账号,并授予其“连接”和“更高权限”等权限。

4. 在终端设置主数据库的镜像端点。端点使用 Windows 防火墙(Windows Firewall)的端口 5022 来进行通信。

5. 开启主服务器的数据库镜像,确保主数据库可以与备用数据库通信。

2.2 配置备用服务器

1. 在备用服务器上创建一个和主服务器上的数据库名称相同的数据库。

2. 在备用服务器上创建一个用于镜像的登录账号,并赋予与主服务器上的账号相同的权限。

3. 在备用服务器上开启数据库镜像并将其与主服务器上的数据库的镜像状态设置为“镜像”。

上述步骤完成后,主服务器和备用服务器之间就可以进行数据库复制和数据同步了。但在部署过程中要注意,主服务器和备用服务器的硬件配置必须相同,操作系统必须匹配,SQL Server 版本也必须相同,否则会导致数据库无法正常使用。

2.3 SQL Server 数据库镜像技术的管理

SQL Server 数据库镜像技术的管理包括以下方面:

1. 检测镜像状态:使用 SQL Server Management Studio 检测服务器之间的镜像状态并及时发现问题。

2. 测试镜像是否正常工作:在生产环境之前,必须在测试环境中对镜像技术进行测试,确保其可以高效可靠地工作。

3. 进行数据备份:在主服务器和备用服务器上进行数据备份,以保证在数据丢失或者硬件故障时可以进行数据恢复。

4. 监控并修复故障:监控数据库运行时的故障情况并及时修复它们,以避免业务受到影响。

通过以上的部署和管理措施,SQL Server 数据库镜像技术可以高效可靠地保证数据库的可用性和灾难恢复能力。企业在部署 SQL Server 数据库镜像技术时,务必注意数据库镜像的版本和数据同步模式。同时,确保管理员具备完整的数据库技术知识和能力,能够有效地管理和维护数据库的正常运行。

相关问题拓展阅读:

与SQL SERVER 安全控制相关的几点说明

与SQL SERVER安全控制相关的几点说明

(一)几个基本术语

身份验证(Authentication)是指通过提交服务器评估的凭据以登录到主体请求访问的 SQL Server 的过程。身份验证可以确定接受身份验证的用户或进程的标识。

用户、账户、账号、登录名、用户名

用户是指能够在SQL Server安全机制下,访问数据库对象中的数据的操作员或客户。用户若要访问数据库对象,必须获得数据库管理员(DBA)分配的账号和密码。从SQL Server管理系统的角度来看,用户就是一组匹配的账户和密码。

账户和账号是一个概念的不同搏乱说法,在服务器中的账户又叫登录名(Login Name),因此访问服务器也称为登录服务器。服务器的登录名可以映射到数据库中成为用户基乱档名(User Name)。一个登录名可以映射多个数据库用户,而一个用户只能映射一个登录名。

连接或登录SQL Server服务器时是用的登录名而非用户名登录的,程序里面的连接字符串中的用户名也是指登录名。

通常用户名与登录名相同(不是强制相同,但为了一目了然通常都在创建用户名时使用与登录名相同的名字)。

提示:登录名(Login Name)和用户名(User Name)是两个不同的概念:

登录名:服务器方的一个实体,登录名只能进入SQL Server服务器,但是不能让用户访问服务器中的数据库资源。

用户名:一个或多个登录对象在数据库中的映射,可以对用户对象进行授权,以便为登录对象提供对数据库的访问权限。

登录名作用于它所在的服务器。每个登录名的定义存放在master系统数据库的syslogins表中。

用户名作用于它所在的数据库。用户定义信息存放在每个数据库的sysusers表中。用登录名登录到SQL Server后,在访问操作各个数据库时,SQL Server会自动查询此数据库中是否存在与此登录名关联的用户名,若存在就使用此用户的权限访问此数据库,若不存在就是用guest用户访问此数据库(guest是一个特殊的用户名,后面会讲到)。

SQL身份验证:适合于非windows平台的用户或Internet用户,需要提供账户和密码。

Windows身份验证:适合于windows平台用户,利用Windows账户和windows集成验证,不需要提供密码。

用户想要操作数据库的某个对象(如某张表)需要过三关:

之一关:我们需要登录到SQL Server系统,即需要登录账户;

第二关:我们需要访问某个数据库,即陪档需要该数据库的用户账户;

第三关:我们需要访问数据库中的某个对象(如某张表),需要有该对象的权限。

主体(principal)是可被授予对安全资源的访问权限的实体(例如登录名、用户、进程、组或角色)。主体可以是主体的(比如数据库角色或Windows组)或不可分割的主体(比如本地登录或域登录)。每个主体都具有一个 ID (identification)和一个安全 ID (SID)。

⊙ Windows级别的主体:Windows组、Windows域登录名、Windows本地登录名。

⊙ SQL Server级的主体:服务器角色、SQLServer登录名。

⊙数据库级的主体:数据库角色、数据库用户、应用程序角色。

上下文切换 (context switch),更改检查执行语句或执行操作的权限时所依据的标识。

服务器(server)

1)指安装了SQL SERVER的计算机。2)指SQL Server实例——计算机上运行的 SQLServer的副本。3)指为用户提供服务的计算机软件或组件。

需要根据上下文理解。

注册服务器

注册服务器使您可以存储服务器连接信息(服务器的类型、服务器的名称、登录到服务器时使用的身份验证的类型等),以供将来连接时使用——下次连接该服务器时,不需要重新输入登录信息。

SQLServer 2023在SQL Server企业管理器中注册服务器,才能使用 SQL Server企业管理器来管理这些服务器。从SQLServer 2023始,在 SQL ServerManagement Studio 中注册服务器,才能使用 SQL Server Management Studio 来管理这些服务器。

在 Microsoft SQL Server中,可以注册以下类型的服务器:SQLServer数据库引擎、Analysis Services、Reporting Services、IntegrationServices和 SQL Server Compact 3.5SP1。

(二)SQL Server实例(SQL Server instance)

SQLServer实例(SQL Server instance),简称实例 (instance),是计算机上运行的SQLServer 的副本。同一台计算机上可以安装运行的多个 SQLServer副本。每个SQL Server实例都包含数据库引擎、Analysis Services和 ReportingServices的 SQL Server,每个SQL Server数据库实例各有一套不为其他实例共享的系统及用户数据库。

数据库引擎是用于存储、处理和保护数据的核心服务。利用数据库引擎可控制访问权限并快速处理事务。

实例又分为“默认实例”(default instance)和“命名实例”(namedinstance),如果在一台计算机上安装之一个SQLSERVER,命名设置保持默认的话,那这个实例就是默认实例。默认实例与安装计算机具有相同名称。命名实例指安装SQL Server时给定了名称,可以安装多个命名实例,给定名称是为了与同一台计算机上的其他命名实例和默认实例区分开。

SQLServer应用程序可以通过仅指定服务器名称而连接到 SQLServer的默认实例。SQL Server应用程序在连接到服务器上的某个命名实例时必须既指定服务器名称又指定实例名称,计算机名称\实例名称。

一台计算机上最多只有一个默认实例,也可以没有默认实例,默认实例名与计算机名相同。如果要访问本机上的默认SQL服务器实例,使用计算机名、(local)、localhost、127.0.0.1、.、本机IP地址,都可以达到相同的目的。但如果要访问非本机的SQL服务器,那就必须使用计算机名称\实例名称。

默认实例和命名实例的区别:

1、服务中服务名称的区别:

(1)默认实例:MSSQLSERVER。

(2)有名命名实例:实列名为benet,在服务中的名称是MSSQL$BENET。

注:如果你有多个实例的时候会在服务中出现多个服务名称。

2、连接到查询分析器或探查器的时候区别:

(1)默认实例可以使用:“.”(点)、“(local)”、“计算机名称”。

(2)实例名称:计算机名pcname,实例名benet,连接时使用的名称是pcname\benet。

(三)安全对象和权限

安全对象(Securable),可以通过权限得到保护的实体。是SQLServer数据库引擎授权系统控制对其进行访问的资源。如表、视图、触发器等。

SQLServer中将安全对象分为三个层次,分别为:

⊙服务器层级,包含的安全对象:端点、登录、服务器角色、数据库。

⊙数据库层级,包含的安全对象:用户、数据库角色、应用程序角色、程序集、消息类型、路由、服务、远程服务绑定、全文目录、证书、非对称密钥、对称密钥、约定、架构。

⊙构架(SCHEMA)层级,包含的安全对象:类型、XML架构、对象(函数、过程、同义词、表、视图)

这三个层级是从上到下包含的,级别从高到低。

说明:端点(endpoint)为服务器级安全对象。Microsoft SQL Server 2023 中的连接管理基于“端点”。一个端点就是一个SQL Server对象,它能够使 SQL Server在网络中通信。对于数据库镜像,服务器实例需要有自己专用的“数据库镜像端点”。此端点用途特殊,专门用于接收来自其他服务器实例的数据库镜像连接。

权限 (permission),与对象关联的规则,用来规定哪些用户可以获得该对象的访问权限以及方式如何。对安全对象的访问通过授予或拒绝权限进行控制。

权限可以明确用户能够使用哪些数据库对象,并对它们进行何种操作。用户在数据库内的权限取决于用户账号的权限和该用户所属的角色的权限。

提示:在设置权限时,尤其要注意权限在安全对象上的继承关系。对于高级别安全对象上设置的权限,会被自动继承到低级别安全对象上。

理解权限的继承和权限的覆盖会在设置权限时减少很多问题,更佳方法是统筹规划,上机验证。

(四)架构(schema)

架构是指包含表、视图、过程等的容器。它位于数据库内部,而数据库位于服务器内部。这些实体就像嵌套框放置在一起。服务器是最外面的框,而架构是最里面的框。架构包含表、视图、过程、函数、同义词、类型、队列、XML架构等安全对象。

注意:

在 SQL Server 2023和早期版本中,数据库可以包含一个名为“架构”的实体, SQL Server 2023包含 CREATE SCHEMA语句,但此实体实际上是所有者(创建对象时的用户)。在 SQL Server 2023 开始,架构既是一个容器,又是一个命名空间。任何用户都可以拥有架构,并且架构所有权可以转移。从 SQL Server 2023开始,每个用户都拥有一个默认架构。可以使用 CREATE USER或 ALTER USER的 DEFAULT_SCHEMA选项设置和更改默认架构。如果未定义 DEFAULT_SCHEMA,则数据库用户将使用 dbo作为默认架构。

在SQL Server 2023中,DataBaseName.dbo.TableName解释为:数据库名.所有者.表名。

从 SQL Server 2023开始,DataBaseName.dbo.TableName解释为:数据库名.架构名.表名。

在SQL Server 2023中,数据库对象全称是server_name…object_name

从SQL Server 2023始,数据库对象全称是server_name…object_name

在SQL SERVER2023或以前版本中创建一个对象,对象必须要有一个所有者(owner)。对象是如何属于某个所有者的呢?这依赖于创建对象时的用户。您不能取消对象所有者(object owner)的特权(privileges)。对象所有者可以执行任何与对象有关的操作(例如 INSERT、UPDATE、DELETE、SELECT或 EXECUTE),也可以管理对象的权限。

从2023/2023后,一个我们必须重新认识的情况是对象不再有所有者(owner)。架构包含对象,架构有所有者。

在2023前(如SQL Server 2023中),没有架构的概念,只有用户的概念,那时候DBO是默认用户。到了2023,有了架构概念,但是为了向后兼容,保留了DBO,并且把DBO作为默认架构,在不指定架构的情况下,默认为dbo,“默认架构”的概念,用于解析未使用其完全限定名称引用的对象的名称。在 SQL Server 2023 中,每个用户都有一个默认架构,用于指定服务器在解析对象的名称时将要搜索的之一个架构。可以使用 CREATE USER和 ALTER USER的 DEFAULT_SCHEMA选项设置和更改默认架构。如果未定义 DEFAULT_SCHEMA,则数据库用户将把 DBO作为其默认架构。

(五)dbo

dbo既是默认架构,也是默认用户。在SQL Server 2023中,dbo作为默认用户。在SQL Server2023中,dbo既作为默认用户,也作为默认架构(如图)。

dbo作为默认用户,dbo (DataBase Owner,数据库的所有者,拥有数据库中的所有对象),每个数据库都有dbo, sysadmin服务器角色的成员自动映射成dbo,无法删除 dbo用户,且此用户始终出现在每个数据库中。通常,登录名sa映射为库中的用户dbo。另外,固定服务器角色 sysadmin的任何成员都映射到每个数据库内称为 dbo的一个特殊用户上。由固定服务器角色sysadmin的任何成员创建的任何对象都自动属于 dbo。由固定服务器角色 sysadmin的任何成员或 dbo用户创建的任何对象都自动属于dbo,由任何其他用户(包括 db_owner固定数据库角色成员)创建的对象,属于创建该对象的用户,而不是 dbo,用创建该对象的用户名限定。例如:

如果用户 Andrew是固定服务器角色sysadmin的成员,并创建表 T1,则表 T1属于 dbo,并以 dbo.T1而不是 Andrew.T1进行限定。相反,如果 Andrew不是固定服务器角色sysadmin的成员,而只是固定数据库角色 db_owner的成员,并创建表 T1,则 T1属于 Andrew,并限定为Andrew.T1。该表属于 Andrew,因为该成员没有将表限定为dbo.T1。

dbo作为默认架构,在不指定架构的情况下,默认为dbo,“默认架构”的概念,用于解析未使用其完全限定名称引用的对象的名称。在 SQL Server 2023 中,每个用户都有一个默认架构,用于指定服务器在解析对象的名称时将要搜索的之一个架构。可以使用 CREATE USER和 ALTER USER的 DEFAULT_SCHEMA选项设置和更改默认架构。如果未定义 DEFAULT_SCHEMA,则数据库用户将把 DBO作为其默认架构。

(六)Guest用户

guest用户不需要映射到登录名。这种用户账号是供数据库中没有明确授予权限给已映射至认证用户使用的。guest供那些已经成功登录到SQL SERVER实例,但是却没有通过用户访问数据库的权限的登录者使用的。

SQLSERVER 2023中guest用户可以删除;而2023/2023中是不能删除的,却可以取消CONNECT权限,而且为安全起见,所有用户定义的数据库中缺省情况下guest用户的权限都是被取消了的,可在除master和tempdb之外的任何数据库中禁用Guest用户。

在SQL SERVER 2023中,新建的数据库中没有Guest用户,但可以添加它,也可删除它,添加与删除方法与普通数据库相同。

在SQL Server 2023或以上版本中GUEST已经默认存在于每个数据库中,但默认情况下,会在新数据库中禁用GUEST用户(在“对象资源管理器→安全性→登录”节点中图标上有禁用标识),我们可以通过以下语句启用GUEST用户:GRANT CONNECT TO GUEST 。当你决定不再想让该数据库被非数据库授权的用户以GUEST身份进行访问时,可以再次将GUEST帐号禁用。值得一提的是,GUEST用户在数据库中不能被删除,我们只能通过以下语句禁用GUEST用户:REVOKE CONNECT FROMGUEST 。

在SQL SERVER 2023中,要允许guest用户帐户访问数据库,可以像添加其它数据库用户那样添加它,如:

USE

GO

EXECsp_grantdbaccess ‘guest’

GO

在SQL SERVER 2023中,允许guest用户帐户

USE

GO

GRANT CONNECT TO GUEST

GO

需要提醒的是,对于是否添加Guest用户要谨慎权衡利弊。

–SQLServer 2023删除guest用户账号

USE

GO

EXECsp_revokedbaccess ‘guest’

GO

— SQLServer 2023禁用guest用户账号

USE

GO

REVOKECONNECT FROM GUEST

GO

(七)sa登录名

SQLServer的 sa登录名是服务器级的主体。默认情况下,该登录名是在安装实例时创建的。在 SQL Server 2023和 SQL Server2023中,sa的默认数据库为 master。这是对早期版本的 SQLServer的行为的更改。

sa(system administrator系统管理员)是为向后兼容而提供的特殊登录。sysadmin是一种角色。该角色能够执行SQLServer上的任何操作。本质上,任何具有这种角色成员身份的人都是那个服务器上的sa。这种服务器角色的创建为微软提供了某一天去除sa登录的能力——实际上,联机丛书把sa称作本质上为遗留物的东西。

与以前版本不同,SQL Server 2023,即使是用混合模式安装,sa也默认禁用。

注意,sa是一个默认的SQL Server登录名,拥有操作SQL Server系统的所有权限,该登录名不能被删除。当采用混合模式安装Microsoft SQL Server系统之后,应该为sa指定一个密码,应为 sa登录分配一个强密码(strongpassword)。

sa登录名会映射到 sysadmin固定服务器角色,它对整个服务器有不能撤销的管理凭据。如果攻击者以系统管理员的身份获取了访问权限,则可能造成的危害是无法预计的。

(八)其它几个默认配置的的登录(Logins)和用户(Users)

默认配置的的登录和用户除了dbo用户、Guest用户、sa登录,还有如下几个:

Administrators组是一个特殊的登录。administrator用户默认administrators组的成员。

Administrators组实际名称为BUILTIN\Administrators。早期版本,这个组的所有成员均为 sysadmin 角色的成员(这意味着Administrators组中的成员具有更高权限),但可以从该角色中移除这些成员。与以前版本不同,SQL Server 2023默认情况下,本地 Windows组 BUILTIN\Administrators不再包含在新的 SQL Server 2023安装上的 SQL Server的 sysadmin固定服务器角色中。

提示:每个版本的 SQL Server都具有不同的安全功能,默认配置也不尽相同,后出的版本更有利于安全,但安全性和使用方便这两种需求可能有矛盾的一面,更佳方法是上机了解验证。

NETWORKSERVICE和SYSTEM登录账户

NETWORKSERVICE和SYSTEM登录账户,实际名称为NT AUTHORITY\NETWORK SERVICE和NT AUTHORITY\SYSTEM,是否存在这些,依赖于服务器的配置。如果配置了报表服务器,将出现NETWORK SERVICE登录账户。

INFORMATION_SCHEMA和sys用户

INFORMATION_SCHEMA和sys又是SQL Server 预定义的架构(内置架构)名称,它们与INFORMATION_SCHEMA和sys用户具有相同的名称。不能删除,主要用于向后兼容性。可以使用INFORMATION_SCHEMA用户和sys用户访问INFORMATION_SCHEMA和sys架构的系统视图,获取有关数据库元数据信息。

(九)SQL Server中的角色

角色 (role),是SQL Server用来管理服务器和数据库权限的,是安全帐户的,在管理权限时可以视为一个单元——作为分配权限的单位。

SQLServer中的角色分为服务器级别和数据库级别角色。

◇服务器级别角色

服务器级别角色用于帮助管理服务器上的权限。服务器角色的权限作用域为服务器范围。可以将登录名(Login Name)添加到服务器角色。

符合权限要求的用户,可以将服务器级主体(SQL Server登录名、Windows帐户和 Windows组)添加到服务器级角色。固定服务器角色的每个成员都可以将其他登录名添加到该同一角色。

固定服务器角色简介:

1)sysadmin:系统管理员,角色成员可对SQLServer服务器进行所有的管理工作,为更高管理角色。这个角色一般适合于数据库管理员(DBA)。

2)securityadmin:安全管理员,角色成员可以管理登录名及其属性。可以授予、拒绝、撤销服务器级和数据库级的权限。另外还可以重置SQL Server登录名的密码。

3)serveradmin:服务器管理员,角色成员具有对服务器进行设置及关闭服务器的权限。

4)setupadmin:设置管理员,角色成员可以添加和删除链接服务器,并执行某些系统存储过程。

5)processadmin:进程管理员,角色成员可以终止SQLServer实例中运行的进程。

6)diskadmin:用于管理磁盘文件。

7)dbcreator:数据库创建者,角色成员可以创建、更改、删除或还原任何数据库。

8)bulkadmin:可执行BULK INSERT语句,但是这些成员对要插入数据的表必须有INSERT权限。BULK INSERT语句的功能是以用户指定的格式复制一个数据文件至数据库表或视图。

9)在sql server 2023 sp2(补丁)及以后版本,服务器角色中还可以看到一个public角色。每个 SQL Server登录名均属于 public服务器角色。 如果未向某个服务器主体授予或拒绝对某个安全对象的特定权限,该用户将继承授予该对象的 public角色的权限。public服务器角色默认拥有 VIEW ANY DATABASE(查看任何数据库)权限。

从 SQL Server 2023开始,您可以创建用户定义的服务器角色,并将服务器级权限添加到用户定义的服务器角色。

每个版本的 SQL Server都具有不同的安全功能,版本越高,功能越强。

可以利用系统函数IS_SRVROLEMEMBER指示当前用户的 SQLServer登录名是否是固定服务器角色的成员。

可以利用系统存储过程sp_helpsrvrolemember返回有关 SQL Server 固定服务器角色成员的信息。

–查询 sysadmin固定服务器角色的成员。

execsp_helpsrvrolemember ‘sysadmin’

◇数据库级别的角色

数据库级别角色用于帮助管理数据库中的权限。数据库级角色的权限作用域为数据库范围。可以将用户名(User Name)添加到数据库角色。

SQLServer中有两种类型的数据库级角色:数据库中预定义的“固定数据库角色”和您可以创建的“灵活数据库角色”(自定义数据库角色)。

固定数据库角色是在数据库级别定义的,并且存在于每个数据库中。 db_owner和db_securityadmin数据库角色的成员可以管理固定数据库角色成员身份。但是,只有db_owner数据库角色的成员能够向db_owner固定数据库角色中添加成员。 msdb数据库中还有一些特殊用途的固定数据库角色。

符合权限要求的用户,可以向数据库级角色中添加数据库帐户和其他 SQL Server角色。固定数据库角色的每个成员都可向同一个角色添加其他登录名。

固定数据库角色简介:

1)db_owner:数据库所有者,这个数据库角色的成员可执行数据库的所有管理操作。

2)db_accessadmin:数据库访问权限管理者,角色成员具有添加、删除数据库使用者、数据库角色和组的权限。

3)db_securityadmin:数据库安全管理员,角色成员可管理数据库中的权限,如设置数据库表的增加、删除、修改和查询等存取权限。

4)db_ddladmin:数据库DDL管理员,角色成员可增加、修改或删除数据库中的对象。

5)db_backupoperator:数据库备份操作员,角色成员具有执行数据库备份的权限。

6)db_datareader:数据库数据读取者,角色成员可以从所有用户表中读取数据。

7)db_datawriter:数据库数据写入者,角色成员具有对所有用户表进行增加、删除、修改的权限。

8)db_denydatareader:数据库拒绝数据读取者,角色成员不能读取数据库中任何表的内容。

9)db_denydatawriter:数据库拒绝数据写入者,角色成员不能对任何表进行增加、删修、修改操作。

10)public:是一个特殊的数据库角色,每个数据库用户都是public角色的成员,因此不能将用户、组或角色指派为public角色的成员,也不能删除public角色的成员。public数据库角色默认的权限很少。

可以利用系统函数IS_MEMBER检查当前用户是否是数据库角色或Windows域组的成员。

可以利用系统存储过程sp_helprolemember显示数据库角色的成员。

可以利用系统存储过程sp_helpuser报告有关当前数据库中数据库级主体的信息。

可以利用系统存储过程sp_helprotect报告当前数据库中某对象的用户权限或语句权限的信息。

–查询用户拥有的数据库角色

useyourdb

execsp_helpuser ‘UserName’

go

–查询用户被赋予的权限

useyourdb

SQL server 2023数据库有什么优点和缺点?

SQL Server 2023的十大最新特性

在商界,每样东西都在竞争中争取“更好、更快、更便宜”——SQL Server 2023也提供了很多个新特性来节省精力、时间和金钱。从编程到管理能力,这个版本的SQL Server都优于其他版本的产品,并且它还对SQL Server 2023中已经存在的特性进行了加强。这里我按照它的重要程度列出前十个最重要的新特性。

1、加强的T-SQL (事务处理SQL )

T-SQL 天生就是基于的关系型数据库管理系统编程语言,可以提供高性能的数据访问。现在,它与许多新的特性相结合,包括通过同时使用TRY和CTACH来进行错误处理,可以在语句中返回一个结果集的通用表表达式(CTEs),以及通过PIVOT 和UNPIVOT命令将列转化为行和将列转化为行的能力。

2、CLR(Common Language Runtime,通用语言运行时)

SQL Server 2023中的第二个主要的增强特性就是整合了符合.NET规范的语言 ,例如C#, ASP.NET 或者是可以构建对象(存储过程,触发器,函数等)的 VB.NET。这一点让你可以在数据库管理系统中执行.NET代码以充分利用.NET功能。它有望在SQL Server 2023环境中取代扩展的存储过程,同时还扩展了传统关系型引擎功能。

3、服务代理(Service Broker)

服务代理处理的是以松散方式进行联系的发送者和接收者之间的消息。一个消息被发送、处理和回答,完成整个事务。这大大扩展了数据驱动应用程序的性能,以符合工作流或者客户业务需求。

4、数据加密

SQL Server 2023没有用来在表自身加密数据的有文档记载的或者公共支持的首谈函数。企业需要依赖第三方产品来满足这个需求。SQL Server 2023自身带有支持对用户自定义数据库中存储的数据进行加密的功能。

5、TP邮件

在SQL Server 2023中直接发送邮件是可能的,但是很复杂。在SQL Server 2023中,微软通过合并TP邮件提高了自身的邮件性能。SQL Server从此跟Outlook说“bye-bye”!

6、HTTP终端

你可以很轻松地通过一个简单的T-SQL 语句使一个对象可以在因特网上被访问,从而创建一个HTTP终端。这允许从因特网上呼叫一个简单的对象来获取需要的数据。

7、多活动结果集(Multiple Active Result Sets ,简称MARS)

多活动结果集允许从单个的客户端到数据库保持一条持久的连接,以便在者困碰每个连接上拥有超过一个的活动请求。这是一个主要的性能改善,它允许开发人员让用户在使用SQL Server工作的时候拥有新的能力。例如,它允许多个查询,或者一个查询的同时输入数据。底线就是一个客户端连接可以同时拥有多个活动的进程。

8、专用管理员连接

如果所有的内容都出错了,那么只能关闭SQL Server服务或者按下电源键。专用管理员连接结束了这种状况。这个功能允许数据库管理员对尺兄SQL Server发起单个诊断连接,即使是服务器正在出现问题。

9、SQL Server综合服务(SSIS)

SSIS已经作为主要的ETL(抽取、传输和载入)工作替代了DTS(数据传输服务),并且随着SQL Server免费发布。这个工具,从SQL Server 2023开始被完全重新编写,现在已经拥有了很大程度的灵活性,来满足复杂的数据移动需求。

10、数据库镜像

我并没有指望这个功能会在11月份的RTM 中随着SQL Server 2023一起发布,但是我认为这个特性具有很大的潜力。数据库镜像是本地高可用性能力的扩展。所有,仍然在对更多的细节进行调整……那么现在,祝福吧。

还有两项技术不能在SQL Server 2023的前十列表中遗漏的是它的分析服务和报告服务。虽然SQL Server 2023没有介绍其中的任何一项,但是将它们整合进了SQL Server综合服务之中,以求微软的核心商务智能套件的完美。这些技术对于商务智能的成功至关重要。学习新的特性,以及企业如何在实际项目中实现它。

怎么安装SQL Server 数据库

1、双击直接打开SQL2023的安装镜像,然后将里面的所有文件复制到D盘(或其他盘)的文件夹Setup中。如果直接使用安装镜像中的setup安装可能无法安装成功,因此将其中的文件复制到磁盘根目录下的一个文件夹中。  2、点击Setup,启动后点击Installation,单击右侧的New SQL Server…。  3、安装程序进行自检。  4、点击Next,输入安装Key。  5、同意许可。  6、选择需要安装的选项,如果不知道哪些是对自己有用的安装项目,那么可以全选。   7、数据库的实例,保持默认派野衫的即可。  8、安装程序计算出需要占用的磁盘空间。  9、服务器配置,点击 对SQL服务选择相同的账号,然后选择 NT AUTHORRITY\System。   10、账号验证模式选择混合模式,输入密码然后单击添加当前的用户,然后点击Next。   11、再次单击 添加当前的用户。  12、安装本地模式的默认配置,保持默认设置单脊源击Next。  13、是否向微软发送一些报告之类的,可以不勾选。  14、验证安装尘腔规则,此时遇到了有一个不符合项,提示VS2023的版本偏旧,然后到网上下载VS2023 的SP1补丁。  15、这一步是打补丁的过程,如果没有遇到上面的VS2023的提示,那么就不需要此步。   16、打完补丁后,单击再次验证规则,全部通过即可进行下一步。  17、安装程序提示将要安装的SQL项目。  18、接下来就是安装过程。  19、安装过程完毕,单击Next。  20、提示SQL2023已经成功安装了。

关于sql server 数据库镜像的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » SQL Server 数据库镜像:高可用性和灾难恢复的更佳解决方案 (sql server 数据库镜像)