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

数据库中的user和schema的关系:

假如我们想了解数据库中的user和schema的关系,首先必须要清楚数据库中的user和schema的概念。

在sqlserver2000中,由于架构的原因,user和schema总有一层隐含的关系,让我们很少意识到其实user和schema是两种完全不同的概念,不过在sqlserver2005中这种架构被打破了,user和schema也被分开了。

首先来做一个比喻,什么是database,schema,table,列,行,user?可以把database看作是一个大的仓库,仓库分了很多很多的房间,schema就是其中的房间,一个schema代表一个房间,table可以看作是每个schema中的床,table(床)就被放入每个房间中,不能放置在房间之外,那岂不是晚上睡觉无家可归啊。然后床上可以放置很多物品,好比table可以放置很多列和行一样,数据库中存储数据的基本单元是table,现实中每个仓库放置物品的基本单位就是床,user就是每个schema的主人,(所以schema包含的object,而不是user),其实user是对应与数据库的(即user是每个对应数据库的主人),既然有操作数据库的(仓库)的权利,就肯定有操作数据库中每个schema(房间)的权利,就是说每个数据库映射的user有每个schema(房间)的钥匙,换句话说,如果它是某个仓库的主人,那么这个仓库的使用权和仓库中的所有东西都是他的(包括房间),他有完全的操作权,可以扔掉不用的东西从每个房间,也可以放置一些有用的东西到某一个房间,这个现实中的相似,我还可以给user分配具体的权限,也就是他到某一房间能做些什么,是只能看(read-only),还是可以像主人一样有所有的控制权(r/w),这个就要看这个user所对应的角色role了。

在sqlserver2000中,假如我们在某一数据库中创建了用户Bosco,那么此时后台也为我们默认的创建了schema【Bosco】,schema的名字和user的名字相同,这也是我们分不清用户和schema的原因。

在sqlserver2005中,为了向后兼容,当你用sp_adduser存储过程创建一个用户的时候,sqlserver2005同时也创建了一个和用户名相同的schema,然而这个存储过程是为了向后兼容才保留的,我们应该逐渐熟悉用新的DDL语言create user和create schema来操作数据库,在sqlserver2005中,当我们用create user创建数据库用户时,我们可以用该用户指定一个已经存在的schema作为默认的schema,如果我们不指定,则该用户所默认的schema即为dbo schema,dbo房间(schema)好比一个大的公共房间,在当前登录用户没有默认schema的前提下,如果你在大仓库中进行一些操作,比如create table,如果没有制定特定的房间(schema),那么你的物品就只好放进公共的dbo房间(schema)了。但是如果当前登录用户有默认的schema,那么所做的一切操作都是在默认的schema上进行(比如当前登录用户为login1,该用户的默认schema为login1,那么所做的所以操作都是在这个login1默认schema上进行的。实验已经证明的确如此)。估计此时你会有一点晕,刚才说dbo是一个schema,但是你可以在数据库中查看到,dbo同事也是一个user,晕了吧。

在sqlserver2005中创建一个数据库的时候,会有一些schema包括进去,被包括进去的schema有:dbo,INFORMATION_SCHEMA,guest,sys等等(还有一些角色schema)。

在上文中已经提到了,在sqlserver2005中当用存储过程sp_adduser创建一个user时,同时sqlserver2005也为我们创建了一个默认的和用户名相同的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都可以删除。

posted on 2013-12-18 11:02 顺其自然EVO 阅读(321) 评论(0)  编辑  收藏 所属分类: 数据库

mysql schema和database_数据库中的Schema和Database的区别相关推荐

  1. 数据库中的schema是什么(简)

    数据库中的Schema 突然想到数据库中的schema是什么,于是多方搜索有了基本了解,做一个简单记录: 在SQL环境下,schema就是数据库对象的集合,所谓的数据库对象也就是常说的表,索引,视图, ...

  2. mysql one database_数据库中schema和database有什么区别?

    在MySQL中创建一个Schema好像就跟创建一个Database是一样的效果,在SQL Server和Orcal数据库中好像又不一样. 目前我只能理解,在mysql中 schema<==> ...

  3. mysql schema table_关于数据库中table与schema的区别详解

    什么是Database,什么是Schema,什么是Table,什么是列,什么是行,什么是User? 相关mysql视频教程推荐:<mysql教程> 我们可以把Database看作是一个大仓 ...

  4. 关于数据库中的schema的注释

    关于数据库中的schema schema:模式,在SQL Server中文版文档中翻译为架构. 在数据库学习过程中,有一个schema概念,如概念模式.物理模式.内部模式.外部模式.逻辑模式,以及DB ...

  5. 数据库中的Schema是什么?

    在数据库中,schema(发音 "skee-muh" 或者"skee-mah",中文叫模式)是数据库的组织和结构,schemas 和schemata都可以作为复 ...

  6. mysql 数据缓冲区,MySQL写入缓冲区在数据库中的作用( Change Buffer )

    原标题:MySQL写入缓冲区在数据库中的作用( Change Buffer ) 介绍另外一种重要的数据变更日志,也就是InnoDB change buffer.Change buffer的主要目的是将 ...

  7. 数据库中char varchar nchar nvarchar的区别

    数据库中char varchar nchar nvarchar的区别 我们在进行数据库的设计的时候,很多情况下表中的字段都是用的是字符串类型的数据,其中就有四种选择char varchar nchar ...

  8. 数据库中的Schema(模式)和View(视图)

    Schema(模式) 在mysql中,Schema和database即数据库的概念类似,利用建模式的语句 create schema name同样可以创建一个库 而在其他数据库中,例如oracle,S ...

  9. mysql支持非关系_说下oracle、mysql、非关系型数据库中的索引结构?

    谢邀~~树懒君悉心整理了一篇索引结构方面的内容,跟各位知友分享分享~ Oracle 索引的数据结构:B-TreeOracle 数据库使用 B-trees 存储索引,来加速数据访问.若没有索引,你必须顺 ...

最新文章

  1. Android 数据库之Cursor
  2. linux 批量删除
  3. 《Spring实战》第四版读书笔记 第二章 装配Bean
  4. Android中ADT和SDK的关系
  5. 如何解决python3.5.2安装scrapy的无法查找到vsvarall的问题
  6. 3DSlicer7:FAQ-1
  7. MyEclipse设置选中单词其它同名单词前景色和背景色
  8. c语言数组求逆序对,LeetCode 面试题51. 数组中的逆序对
  9. 浅谈C/C++中的typedef和#define
  10. opencv抠人像_卸载PS吧!这个小程序就能一键AI抠图,超简单!
  11. tensorflow笔记2:TensorBoard
  12. 你好,未来! | 2018腾讯“云+未来”峰会五月启幕
  13. openCV 下载地址
  14. 用Everspin MR2xH40xDF SPI-MRAM替换赛普拉斯CY15B104QN SPI-FRAM
  15. bugly怎么读_Bugly迁入
  16. 大数据行业必须掌握的核心技术
  17. poi中excel锁定行列问题
  18. 敏捷项目管理21天学习计划--敏捷生命周期
  19. 8.互 联 网 上 的 音 频 和 视 频 服 务
  20. 疑因内部宫斗被离职,中兴70后程序员从公司坠楼 ​​​​

热门文章

  1. 看这里 一步学会ubuntu 16.04 安装windos的应用, 使用sscom串口工具来调试
  2. GPS/IMU事后差分
  3. golang中使用opencv(gocv)将本地摄像头转为ip摄像头
  4. 给你三个ASCII字符(不含空白字符:包括空格、制表符\t、回车换行符\n),找出其中最大的那个
  5. 室女座 - Virgo
  6. matlab根据纬度计算当地重力加速度
  7. [译] 响应式脑电波—如何使用 RxJS、Angular、Web 蓝牙以及脑电波头戴设备来让我们的大脑做一些更酷的事...
  8. 在Windows服务器上搭建WEB环境MySQL 5.7+JDK 1.8+Tomcat 8.5并使用war包进行部署+简单运行jar程序+Tomcat Manager快速部署
  9. matlab 幂法,数值分析试验幂法与反幂法matlab.doc
  10. matlab cftool光滑曲线导出为什么就不光滑了_【富怡CAD问题答疑】为什么我画的曲线有锯齿状,不光滑...