`
zheyiw
  • 浏览: 1016386 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

sqlserver基础:database schema user

    博客分类:
  • SQL
阅读更多

sqlserver中的User和Schema的关系
如果我们想了解数据库中的User和Schema到底什么关系,那么让我们首先来了解一下数据库中User和Schema到底是什么概念。
                在SQL Server2000中,由于架构的原因,User和Schema总有一层隐含的关系,让我们很少意识到其实User和Schema是两种完全不同的概念,不过在SQL Server2005中这种架构被打破了,User和Schema也被分开了。
                首先我来做一个比喻,什么是Database,什么是Schema,什么是Table,什么是列,什么是行,什么是User?我们可以可以把Database看作是一个大仓库,仓库分了很多很多的房间,Schema就是其中的房间,一个Schema代表一个房间,Table可以看作是每个Schema中的床,Table(床)就被放入每个房间中,不能放置在房间之外,那岂不是晚上睡觉无家可归了J。,然后床上可以放置很多物品,就好比Table上可以放置很多列和行一样,数据库中存储数据的基本单元是Table,现实中每个仓库放置物品的基本单位就是床, User就是每个Schema的主人,【所以Schema包含的是Object,而不是User】,其实User是对应与数据库的(即User是每个对应数据库的主人),既然有操作数据库(仓库)的权利,就肯定有操作数据库中每个Schema(房间)的权利,就是说每个数据库映射的User有每个Schema(房间)的钥匙,换句话说,如果他是某个仓库的主人,那么这个仓库的使用权和仓库中的所有东西都是他的(包括房间),他有完全的操作权,可以扔掉不用的东西从每个房间,也可以放置一些有用的东西到某一个房间,呵呵,和现实也太相似了吧。我还可以给User分配具体的权限,也就是他到某一个房间能做些什么,是只能看(Read-Only),还是可以像主人一样有所有的控制权(R/W),这个就要看这个User所对应的角色Role了,至于分配权限的问题,我留在以后单独的blog中详述。比喻到这里,相信大家都清楚了吧。
OK,我们话题继续!
在SQL Server2000中,假如我们在某一个数据库中创建了用户Bosco,按么此时后台也为我们默认地创建了默认Schema 【Bosco】。Schema的名字和User的名字相同,这也是我们分不清楚用户和Schema的原因。
在SQL Server2005中,为了向后兼容,当你用sp_adduser 存储过程创建一个用户的时候,SQL Server2005同时也创建了一个和用户名相同的Schema,然而这个存储过程是为了向后兼容才保留的,我们应该逐渐熟悉用新的DDL语言Create User和Create Schema来操作数据库。在SQL Server2005中,当我们用Create User创建数据库用户时,我们可以为该用户指定一个已经存在的Schema作为默认Schema,如果我们不指定,则该用户所默认的Schema即为dbo Schema,dbo 房间(Schema)好比一个大的公共房间,在当前登录用户没有默认Schema的前提下,如果你在大仓库中进行一些操作,比如Create Tabe,如果没有指定特定的房间(Schema),那么你的物品就只好放进公共的dbo房间(Schema)了。但是如果当前登录用户有默认的Schema,那么所做的一切操作都是在默认Schema上进行(比如当前登录用户为login1,该用户的默认Schema为login1,那么所做的所有操作都是在这个login1默认Schema上进行的。实验已经证明的确如此)。估计此时你会有一点晕,为什么呢?我刚才说dbo是一个Schema,但是你可以在数据库中查看到,dbo同时也是一个user,晕了吧,呵呵。
在SQL Server2005中创建一个数据库的时候,会有一些Schema包括进去,被包括进去的Schema有:dbo,INFORMATION_SCHEMA, guest,sys等等(还有一些角色Schema,不提了,有晕了)。
我在上文中已经提到了,在SQL Server2005中当用存储过程sp_adduser创建一个user时,同时SQL Server2005也为我们创建了一个默认的和用户名相同的Schema,这个时候问题出来了,当我们create table A时,如果没有特定的Schema做前缀,这个A表创建在了哪个Schema上,即进入了哪个房间?答案是:
1.       如果当前操作数据库的用户(可以用Select current_user查出来)有默认的Schema(在创建用户的时候指定了),那么表A被创建在了默认的Schema上。
2.       如果当前操作数据库的用户没有默认的Schema(即在创建User的时候默认为空),但是有一个和用户名同名的Schema,那么表A照样被创建在了dbo Schema上,即使有一个和用户名同名的Schema存在,由于它不是该用户默认的Schema,所以创建表的时候是不会考虑的,当作一般的Schema来处理,别看名字相同,可是没有任何关系哦。
3.       如果在创建表A的时候指定了特定的Schema做前缀,则表A被创建在了指定的 Schema上(有权限吗?)
现在问题又出来了,在当前操作数据库的用户(用select current_user可以查看到,再次强调)没有默认Schema的前提下,当我们用Create table A语句时,A表会去寻找dbo Schema,并试图创建在dbo Schema上,但是如果创建A表的用户只有对dbo Schema的只读权限,而没有写的权限呢?这个时候A表既不是建立不成功,这个就是我以后会提及到的Login,User, Role和Schema四者之间的关系。在这里,为了避免混淆和提高操作数据库的速度(在少量数据范围内,对我们肉眼来说几乎看不到差异),我们最好每次在操作数据库对象的时候都显式地指定特定的Schema最为前缀。
现在如果登录的用户为Sue,该用户有一个默认Schema也为Sue,那么如果现在有一条查询语句为Select * from mytable, 那么搜寻每个房间(Schema)的顺序是怎样的呢?顺序如下:
1.       首先搜寻sys.mytable   (Sys Schema)
2.       然后搜寻Sue.mytable                     (Default Schema)
3.       最后搜寻 dbo.mytable      (Dbo Schema)
执行的顺序大家既然清楚了,那么以后在查询数据库表中的数据时,最好指定特定的Schema前缀,这样子,数据库就不用去扫描Sys Schema了,当然可以提高查询的速度了。
另外需要提示一下的是,每个数据库在创建后,有4个Schema是必须的(删都删不掉),这4个Schema为:dbo,guest,sys和INFORMATION_SCHEMA,其余的Schema都可以删除。

分享到:
评论

相关推荐

    SQL电商网站数据库设计案例database-schema.sql

    常见电商网站的业务需求包括商品管理、用户管理、订单管理、购物车管理等。...运行:sqlite3 your_database_name.db < database_schema.sql 打开数据库:sqlite3 your_database_name.db 显示表结构:.schema

    sqlserver数据库SSH配置1

    SQLServer 数据库 SSH 配置详解 SQLServer 数据库 SSH 配置是将 SQLServer 数据库与 Secure Shell(SSH)协议集成,以实现加密的数据传输和身份验证。本文将详细介绍 SQLServer 数据库 SSH 配置的实现步骤和相关...

    【Mycat1.6之操作SQLServer案例】

    在配置Mycat连接SQLServer时,你需要在`schema.xml`文件中定义数据节点(Data Node)和数据源(Data Source)。`schema.xml`是Mycat的核心配置文件,它定义了数据表的分片规则、数据源信息以及路由策略等。例如: `...

    Python库 | dbt_sqlserver-1.0.0rc1-py3-none-any.whl

    6. **SQL Server支持**:dbt_sqlserver适配器专门针对Microsoft SQL Server数据库,使得dbt的功能能够无缝对接到SQL Server环境中,包括Azure SQL Database等云服务。 7. **部署与环境管理**:dbt支持多环境配置,...

    SQL Server数据库建用户授权

    SQL Server 数据库用户授权 SQL Server 数据库用户授权是指在 SQL Server 数据库中创建用户账户并赋予相应的权限,以便用户可以访问和管理数据库中的对象。本文将详细介绍如何使用 SQL 语句创建数据库用户,赋予...

    在SQL Server中创建用户角色及授权(使用SQL语句) .pdf

    在SQL Server中,管理和控制数据库访问是至关重要的任务。这篇文档主要讲述了如何使用SQL语句在SQL Server中创建用户角色并进行授权。首先,我们从创建登录账户开始,然后创建数据库用户,接着将登录账户与数据库...

    Beginning T-SQL with Microsoft SQL Server 2005 and 2008

    The SQL Server client tools must be installed on your desktop computer and the SQL Server relational database server must be installed on either your desktop computer or on a remote server with ...

    log4net写入SQL server数据库(测试案例)

    **SQL Server集成** 将log4net配置为将日志信息存储在SQL Server数据库中,首先需要创建一个适合存储日志信息的数据库表,通常包含日期、级别、类名、消息等字段。然后在log4net的配置文件中指定数据库连接字符串和...

    数据库中的Schema和Database的区别

    在mysql中创建一个Schema和创建一个Database的效果好像是一样的,但是在sqlserver和orcal数据库中效果又是不同的,目前我只能理解为在mysql中schema<==>database;  数据库中的user和schema的关系:  假如...

    Tomcat通过JNDI方式连接SqlServer数据库

    使用Tomcat通过JNDI方式连接SqlServer数据库 在本文中,我们将介绍如何使用Tomcat通过JNDI方式连接SqlServer数据库。JNDI(Java Naming and Directory Interface)是一种Java API,用于访问命名和目录服务。在...

    SQL Server跨服务器连接的多种方法

    1. **链接服务器**(Linked Servers):允许在一个服务器上定义其他服务器为链接服务器,然后通过四部分名称(如`<server>.<database>.<schema>.<table>`)直接访问远程数据。 2. **分布式查询**(Distributed ...

    C# 读取SQLServer数据库 并生成数据结构图

    C#是一种广泛使用的编程语言,它提供了丰富的库和工具来与各种数据库系统交互,包括Microsoft SQL Server。本篇文章将详细探讨如何利用C#来读取SQL Server数据库,并生成数据结构图。 首先,要实现C#与SQL Server的...

    数据库原理与SQL Server教程

    通过学习本教程,你将掌握数据库的基础理论,理解SQL Server的工作原理,并能熟练运用SQL语言进行数据操作。同时,你还将了解到SQL Server在安全性、备份恢复、性能优化等方面的专业知识,以及其在大数据分析和报表...

    Oracle与SQL和Mysql的对比笔记

    - SQL Server: 使用`EXEC sp_help '表名'`或`SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = '表名'` - MySQL: 使用`DESC 表名`或`SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME = '...

    SQL Server 2005新特性体验

    ### SQL Server 2005新特性体验 #### 一、引言 SQL Server 2005作为Microsoft推出的一款重要的关系型数据库管理系统,在企业级应用中占据着举足轻重的地位。相比于之前的版本,SQL Server 2005引入了许多新特性与...

    sqlserver下oracle驱动新测好用含使用说明

    提供的压缩包文件"sqlserver下oracle驱动新测好用含说明"包含了最新的驱动程序和详细的使用指南。请解压文件并按照指南进行安装和配置,以便在你的SQL Server环境中顺利连接Oracle数据库。在使用过程中遇到任何问题...

    asp.net c# 自动创建SqlServer数据库实现

    在ASP.NET中,使用C#语言来自动化创建SQL Server数据库是一项常见的任务,特别是在开发Web应用程序时,为了确保用户能够快速地设置和初始化他们的数据库环境。本文将深入探讨如何通过C#代码来实现这一功能。 首先,...

Global site tag (gtag.js) - Google Analytics