SQL Server与Oracle对比学习:表的管理和组织
http://blog.csdn.net/weiwenhp/article/details/8088979
我们知道数据库,顾名思义.最重要的东东就是管理数据,而数据在系统中主要是保存在表(table)中,所以数据库差不多所有的机制和操作都是围绕着table在打转转了.表的重要性可想而知.在表在数据库是怎么保存起来,怎么去访问呢?
Oralce中的表的管理机制
实际上数据库管理系统和文件系统很类似的.数据库中的所有信息最终也是保存在一个个实际的文件中.
Oracle中的表都是最终保存在一个个后缀为DBF的文件中.而我们使用文件时会看到一个个目录.那Oracle中的目录就是表空间(tablespace).目录下会有很多文件,那一个表空间中也会有很多个数据文件. 然后我们创建用户时是会指定用户的默认表空间,这样当前用户创建表时默认都保存到此表空间中,但也可以显式指定表空间中.用户是Oracle中的一个逻辑概念.是为了便于管理而设立的.另外oracle中还有个schema的概念.
schema与用户的区别
实际上现在的Oracle中可以把shcema和用户完全等同.那你可能会问这样的话应该可以完全去掉schema这个概念,免得误导人啊.之所以保存着schema据说是出于历史原因.刚开始时Oralce中schema与用户不是一一对应的.先是创立很多个schema,每个schema有个默认的表空间,然后在schema下面可以创建一个个的表.最后创建用户时可以让一个用户对应多个schema.但这样一来比较复杂,不便于管理和理解.于是把用户和schema一一对应了.这样就条理清晰,显得更整洁优美,更便于管理和理解.
这个据说我也没验证过,没玩啥oracle 8i或更早的.有些人就说之所以有schema和用户的区分,应该这样理解.表空间相当于一个仓库.而schema相当于其中的一个柜子.你可以在里面存各种东西.而每个用户拥有一个schema.拥有一个柜子.一一对应的关系.正常情况你不能访问别人的柜子.但如果你有特权你也可以.
上面说了一堆还是来举个例子.
假如有数据文件DBFile1.DBF 属于表空间TSpace1
有数据文件 DBFile2.DBF 属于表空间TSpcae 2
创建用户用户Arwen 指定默认表空间为TSpace1.
在用户Arwen下面创建表Table1 不指定表空间的话Table1就保存到表空间TSpace1中,由于此时表空间只有一个数据文件,所以表实际上就保存到DBFile1.DBF中
但你也可以显式指定Table1的表空间为TSpace2,此时Table1会保存到DBFile2中
表的保存是一目了然了吧. 表 --> 表空间 -->数据文件
我们访问表时就是 : select * from Arwen.Table1 如果是当前用户也可以省略Arwen这个前缀.
SQL Server表管理机制
实际上SQL Server的机制和Oracle非常类似.可能就像C#和Java那么类似了.有趣的是C#和SQL Server是微软的,Java和Oracle都是Oracle的
首先表自然也都保存一个个实际数据文件文件中,如果是系统表的话都保存在后缀为mdb的文件中,叫主要文件,其他的表一般保存在ndb文件,叫次要文件.实际上也可以把文件后缀名改成其他的,所以你要闲得蛋痛想恶作剧可以都改成跟Oracle一样,后缀为DBF,当然还得改些其他配置信息.但一般不推荐你去改后缀名.
在Oracle中数据文件会属于某个表空间,但sql server没表空间这个概念,但有文件组的概念.其实差不多拉.
然后用户会创立一个个的数据库(database),并指定它默认的文件组,然后在database下可以创建一个个表,如果不指定就保存在默认的文件组中,也可以显式指定.其实这里的database就相当于Oracle中的schema.然后再创建用户,一个用户可以可以对应多个database,相当于以前Oracle中一个用户名可以对应多个schema一样.
还是再举个例子吧.
假如有数据文件DBFile1.ndb 属于文件组group1
有数据文件 DBFile2.ndb 属于文件组group2
创建database db1 指定默认文件组group1
在db1下面创建表Table1 不指定文件组的话Table1就保存到文件组group1中,由于此时文件组只有一个数据文件,所以表实际上就保存到DBFile1.ndb中
但你也可以显式指定Table1的文件组为group2,此时Table1会保存到DBFile2.ndb中
我们可以创建用户weiwenhp, 对应的databse是db1
表的保存是一目了然了吧. 表 --> 文件组-->数据文件
我们访问表时就是 : select * from db1.dbo.Table1
这里还有个dbo,是schema.等会再补充下,开始以为sql server中没有呢.不过这里的schema跟Oracle中的不一样.
于是你用用户weiwenhp登陆就可以执行上面的SQL语句了.这里还没讨论用户的权限.下次再谈权限的问题去了.如果另外某个用户不一定有权限执行这SQL
(注意:想了下发现上面说的不太准确,涉及到SQL Server中有个非常误导人的概念login和user的区别.login可以对应多个database但user 不能对应多个database,只能对应多个schema.而user与login的关系是一个login可以对应多个user.在后面讲权限管理时再讨论这问题)
补充
SQL Server中的Schema
我们在创建用户时可以直接给用户指定一个databse.但这样可能比较浪费,而且不便于仅限管理.于是每个databse下面还可以创建很多schema.你可以这样想databse相当于一个大仓库,而schema是其中的小柜子.你每次创建一个databse时是用一个模板来初始化的,这样database默认下面就已经有一些schema了,有一些小柜子了.你最熟悉的可能是dbo这个柜子了.当然你指定用户map一个database相当于把所有的schema都给他了.
当有了一个database后,你还可以在里面加些任意数据的schema,一个仓库中你爱整多少个柜子就整几个.有了schema后我们创建一个用户时就可以不指定一个database给他,而是只指定一个或多个schema.这样此用户就只能使用一个或多个柜子了.
举例,
假如有用户Arwen,给它指定一个database 名为mydb.这个database下有dbo,sm等schema此时用户创建一个表tmp
create table tmp(name char(20));
此表没有指定保存到哪个schema中,默认就保存到dbo中
查找select * from db1.dbo.tmp //实际在management sudio这个图形界面的工具上,我们选了某个database后,然后查找时直接写
select * from tmp就行了.默认会加上db1.dbo
create table sm.mytable(name char(20));
此时指定了schema sm,则表保存到sm中.
要查找的话得select * from db1.sm.mytable //database加schema再加表名.
SQL Server与Oracle对比学习:表的管理和组织的更多相关文章
- SQL Server与Oracle对比学习:权限管理(二) 一些有趣的比喻
http://blog.csdn.net/weiwenhp/article/details/8094739 目录(?)[-] SQL Server权限管理 login 与user的区别 角色role ...
- SQL Server与Oracle对比学习:权限管理(一)
http://blog.csdn.net/weiwenhp/article/details/8093661 我们发现我们现在的生活中到处是涉及到密码,你要记各种各样的密码.比如银行卡,邮件,QQ,微博 ...
- 【转】SQL Server、Oracle、MySQL和Vertica数据库常用函数对比
SQL Server.Oracle.MySQL和Vertica数据库常用函数对比 Vertica数据库是HP公司新收购的用于BI方面的数据库. 1. 绝对值 S:select abs(-1) valu ...
- sql server 向oracle导入表
选择相应的数据库,右键,任务,选择导出数据 点击下一步 选择Microsoft OLE DB Provider for Sql Server 选择下一步 目标选择.net Framework data ...
- 【转载】SQL Server - 使用 Merge 语句实现表数据之间的对比同步
原文地址:SQL Server - 使用 Merge 语句实现表数据之间的对比同步 表数据之间的同步有很多种实现方式,比如删除然后重新 INSERT,或者写一些其它的分支条件判断再加以 INSERT ...
- Oracle和sql server中复制表结构和表数据的sql语句
在Oracle和sql server中,如何从一个已知的旧表,来复制新生成一个新的表,如果要复制旧表结构和表数据,对应的sql语句该如何写呢?刚好阿堂这两天用到了,就顺便把它收集汇总一下,供朋友们参考 ...
- 数据库 --> SQL Server 和 Oracle 以及 MySQL 区别
SQL Server 和 Oracle 以及 MySQL 区别 三者是目前市场占有率最高(依安装量而非收入)的关系数据库,而且很有代表性.排行第四的DB2(属IBM公司),与Oracle的定位和架构非 ...
- 关于sql server远程访问Oracle数据库 OpenQuery查询返回多条数据的问题
在Sql Server远程访问Oracle 中的数据库表时: 远程语法通常为: select * from OpenQuery(Oracle链接服务器名称,‘查询语句’) eg: select * f ...
- Win7 64位下sql server链接oracle的方法
继上一次mysql同步sql server后,这一次需要将Oracle同步到sql server上来,方案相似,只是在sql server链接oracle的时候费了很多时间. 一.测试环境 本方案实现 ...
随机推荐
- HDU 1166 敌兵布阵 线段树的基本应用——动态区间和问题
题目: http://acm.hdu.edu.cn/showproblem.php?pid=1166 简单题,1A了,这个好像就是传说中的“点树”. 设当前结点表示线段[left, right],编号 ...
- Xcode6 Xcode7 Xcode 官方链接 --备用
Xcode 6 官方下载链接: http://adcdownload.apple.com//wwdc_2014/xcode_6_beta_ie8g3n/xcode_6_beta.dmg Xcode ...
- unidac连接FireBird数据库
dbconn: TUniConnection; with dbconn do begin if not Connected then begin ...
- 加JENKINS的SLAVE节点(LINUX)要注意的事项
从昨天下午到现在,终于解决了所有的问题.作如下记录要点: 1,从节点只要建好目录,JENKINS的包,MASTER会推送过来. 2,ANT,MAVEN之类的,要配置好环境变量,PROFILE.D .B ...
- 李洪强漫谈iOS开发[C语言-030]-逻辑运算符
- SPRING IN ACTION 第4版笔记-第一章-002-DI介绍
一. 1.knight.xml <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=&qu ...
- USB 3.0连接器引脚、接口定义及封装尺寸
上篇整理了USB 2.0A型.B型和Mini USB接口定义及封装,本文补充USB 3.0接口定义,USB 3.0采用的双总线结构,在速率上已经达到4.8Gbps,所以称为Super speed,在U ...
- Android 拖动条(SeekBar)实例 附完整demo项目代码
1.拖动条的事件 实现SeekBar.OnSeekBarChangeListener接口.需要监听三个事件:数值改变(onProgressChanged)开始拖动(onStartTrackingTou ...
- 汉企C#面向对象——继承Practice
class Dianqi //创建电器类:父类 { private string _Dianqimingzi; public string Dianqimingzi { get { return _D ...
- JavaScript数学函数的操作
<script> var a=3.14; var a1=Math.ceil(a);//大于当前小数的最小整数; alert(a1); var a2=Math.floor(a);//小于当前 ...