Oracle基本理论

l  主流数据库

微软公司:SQL Server  ACCESS

IBM公司:DB2  infomix

Oracle公司:Oracle  MySQL(AB公司)

小型数据库

ACCESS

FoxBase

开发人数:100人

访问量:10人/秒

开发成本:1000元

中型数据库

SQL Server

My SQL

Infomix

开发人数:1000人

访问量:500人/秒

开发成本:10000元

大型数据库

Oracle

DB2

开发人数:3.6万

访问量:海量

开发成本:无上限

l  数据库发展史

层次型数据库网络型数据库

关系型数据库:

1970年 IBM公司研究员E.F.Codd博士奠定了关系型数据库的理论基础

1978年Oracle公司CEO 拉里.艾利森开发了第一个商用大型关系型数据库 Oracle

1983年 IBM公司推出DB2

l  Oracle版本

Oracle9i(internet互联网)-Oracle10g(grid网格化)-Oracle11g-Oracle12c(Cloud云)

l  Oracle平台工具

SQL Plus

PLSQL developer

l  Oracle服务 services.msc

OracleXXXXXXTNSListener—第三方工具监听服务:1521

OracleServiceXXXX-核心服务(物理运行结构-SGA  XXXX实例数据库)

l  Oracle账户

n  系统账户

u  sys         角色:sysdba  主人可以create database

u  system          角色:sysoper大管家不可以create database

u  scott角色:normal 实例用户大管家给他什么权限,他就有什么权限

切换一个账户:

Conn scott/123456

Conn 用户名/密码

查看SCOTT用户下表的数据字典:

Desc emp;

Desc 表名

查看SCOTT用户下的表内容:

Select * from emp;

Select * from 表名

l  自定义账户 conn system/123456;

创建账户

--创建一个用户

createuser rose identified by123456

修改账户

--修改一个用户的密码

alter user rose identified by 123456;

--解锁一个用户

alter user rose account unlock;

--修改用户向表空间插入数据的限制

alteruser rose quota 1m on users

账户授权

--授予链接数据库的权限

grant create session to rose;

grant createtableto rose;

grant create session ,createtableto rose

删除账户

drop user rose;

ORA-01940: 无法删除当前连接的用户

select username,sid,serial# from v$session;

alter system kill session '8,836';

ORA-01922: 必须指定 CASCADE 以删除 'ROSE'

drop user rose cascade;

创建表

?????

l  权限

n  系统权限select * from system_privilege_map;

语法:

授权:grant 系统权限|角色|ALL to 用户

撤销权限:revoke系统权限|角色|ALLfrom用户

n  对象权限select * from table_privilege_map;

语法:

授权:grant 对象权限|ALL on 对象 to 用户

撤销权限:revoke对象权限|ALL on 对象 from 用户

案例一:学生管理系统student(stuno 
integer, stuname varchar2(10),stuBir date,stuSex char(3) );

步骤一:创建一个表空间

--创建一个表空间

create tablespace demoschool

datafile
'D:/demoschool.dbf'

size 5m

autoextend
on

步骤二:创建一个实例账户,管理表空间

create user lily identified
by 123456 default tablespace demoschool;

alteruser lily identified by123456default
tablespace demoschool

步骤三:授予实例账户系统权限

骤四:登录这个账户

步骤五:建立student表

步骤六:表中插入2条数据

步骤七:查询学生名字

步骤八:修改学生信息

步骤九:删除学生

步骤十:把表删除

执行物理路径中的sql脚本

@
D:/school.sql

Start  D:/school.sql

删除表空间

drop tablespace demoschool;

--连硬盘中的物理文件一起删除

drop tablespace demoschool including contents and datafiles;

Oracle数据库的主要数据类型

一字符串类型

Char 固定长度字符CHAR字段最多可以存储2,000字节的信息。

VARCHAR2类型可变长度类型VARCHAR2最多可以存储4,000字节的信息。

二. 数字类型

NUMBER(P,S)是最常见的数字类型,可以存放数据范围为10^130~10^126(不包含此值),需要1~22字节(BYTE)不等的存储空间。

P 是Precison的英文缩写,即精度缩写,表示有效数字的位数,最多不能超过38个有效数字

S是Scale的英文缩写,可以使用的范围为-84~127。Scale为正数时,表示从小数点到最低有效数字的位数,它为负数时,表示从最大有效数字到小数点的位数

INTEGER类型INTEGER是NUMBER的子类型,它等同于NUMBER(38,0),用来存储整数。若插入、更新的数值有小数,则会被四舍五入。

FLOAT类型FLOAT类型也是NUMBER的子类型。

Float(n),数 n 指示位的精度,可以存储的值的数目。N 值的范围可以从 1 到 126。若要从二进制转换为十进制的精度,请将 n 乘以 0.30103。要从十进制转换为二进制的精度,请用 3.32193 乘小数精度。126 位二进制精度的最大值是大约相当于 38 位小数精度。

三. 日期类型

DATE是最常用的数据类型,日期数据类型存储日期和时间信息。虽然可以用字符或数字类型表示日期和时间信息,但是日期数据类型具有特殊关联的属性。为每个日期值,Oracle
存储以下信息:世纪、年、月、日期、小时、分钟和秒。一般占用7个字节的存储空间。

TIMESTAMP类型

这是一个7字节或12字节的定宽日期/时间数据类型。它与DATE数据类型不同,因为TIMESTAMP可以包含小数秒,带小数秒的TIMESTAMP在小数点右边最多可以保留9位

四. LOB类型

CLOB 数据类型

它存储单字节和多字节字符数据。支持固定宽度和可变宽度的字符集。CLOB对象可以存储最多 (4 gigabytes-1) * (database
block size) 大小的字符

BLOB 数据类型

它存储非结构化的二进制数据大对象,它可以被认为是没有字符集语义的比特流,一般是图像、声音、视频等文件。BLOB对象最多存储(4 gigabytes-1) * (database block
size)的二进制数据。

五. RAW & LONG RAW类型

LONG类型它存储变长字符串,最多达2G的字符数据(2GB是指2千兆字节,而不是2千兆字符),与VARCHAR2
或CHAR 类型一样,存储在LONG 类型中的文本要进行字符集转换。

2017-10-31 18:30:59

Oracle 笔记(一)的更多相关文章

  1. Oracle笔记 目录索引

    Oracle笔记 一.oracle的安装.sqlplus的使用 Oracle笔记 二.常用dba命令行 Oracle笔记 三.function .select Oracle笔记 四.增删改.事务 Or ...

  2. Oracle笔记(1) 简单查询、限定查询、数据的排序

    Oracle笔记(四) 简单查询.限定查询.数据的排序   一.简单查询 SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及 ...

  3. 韩顺平Oracle笔记

    韩顺平Oracle笔记 分类: DataBase2011-09-07 10:24 3009人阅读 评论(0) 收藏 举报 oracle数据库sqljdbcsystemstring   目录(?)[-] ...

  4. Oracle笔记 多表查询

    Oracle笔记  多表查询   本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查 ...

  5. 转:oracle笔记

    oracle笔记1 卸载oracle developer server的方法: 1-1 oracle卸载工具中卸载对应的oracleds项目:在注册表中搜索ORACLEDS HOME对应的别名,删除对 ...

  6. Oracle笔记(六) 多表查询

    最近看了李兴华的oracle视频,这是网上别人做的笔记非常细致,分享给大家,第六篇 原创地址:http://www.cnblogs.com/mchina/archive/2012/09/07/2651 ...

  7. Oracle笔记二

    一.数据库语言分类  二.DML之数据插入 把一个表中的数据查询出来插入另外一个表中. create table student(id number,name varchar2(20),age num ...

  8. oracle笔记一

    一.Oracle简介 1.Oracle属于关系型数据库,是一款可以在Client/Server模式下运行的RDBMS产品.2009年,Oracle公司收购SUN. 2.Oracle是对象关系型数据库管 ...

  9. oracle笔记

    一.sql*plus常用命令 (1)connect 用法:conn 用户名/密码@网络服务名[as sysdba/sysoper] 当特权用户连接时,必须带上as sysdba或是as sysoper ...

  10. Oracle笔记3-高级查询

    高级查询 1.关联查询 作用:可以跨多表查询 --查询出员工的名字和他所在部门的名字 //错误//select first_name,name from s_emp,s_dept; //错误原因:产生 ...

随机推荐

  1. url 中的转义字符

    # 在使用 wireshark 进行抓包的时候,发现url中有一些特殊字符:%20  之类的. # 搜了一下,我理解的是url中会把特殊字符进行编码,规则是 % + 特殊字符的十六进制数: 比如空格的 ...

  2. java序列化和反序列化及序列化方式

    平时我们在Java内存中的对象,是无 法进行IO操作或者网络通信的,因为在进行IO操作或者网络通信的时候,人家根本不知道内存中的对象是个什么东西,因此必须将对象以某种方式表示出来,即 存储对象中的状态 ...

  3. Java 实现《编译原理》简单词法分析功能 - 程序解析

    Java 实现<编译原理>简单词法分析功能 - 程序解析 简易词法分析功能 要求及功能 (1)读取一个 txt 程序文件(最后的 # 作为结束标志,不可省去) { int a, b; a ...

  4. 本地安装sass出错问题解析

    2016年3月23日个人博客文章--迁移到segmentfault 安装sass ruby安装因为sass依赖于ruby环境,所以装sass之前先确认装了ruby.先导官网下载个ruby 在安装的时候 ...

  5. static成员变量

    可以创建一个由同一个类的所有对象共享的成员变量.要创建这样的成员,只需将关键字 static 放在变量声明的前面,如下面的类所示: class StatDemo { private: static i ...

  6. TTTTTTTTTTT 400D Dima and Bacteria 细菌 最短路

    题意: 题目大意:给出n,m和k,表示有n个细菌,m种仪器和k种细菌,给出k种细菌的数量ci,然后每个细菌按照种类排成一排(所以有第i种细菌的序号从∑(1≤j≤i-1)cj + 1 到∑(1≤j≤i) ...

  7. [VIJOS2053][SDOI2019]世界地图:最小生成树+虚树

    分析 可以发现第一列和最后一列永远不会被删除,于是我们可以想到维护前后缀最小生成树,但是直接维护的话显然时间空间两爆炸.(通过上网找题解)可以发现我们关心的只是最左边和最右边两列,而不关心内部的连边情 ...

  8. wkhtmltopdfhtml php生成pdf快照,网页截图,网页快照完整版 (原)

    首先,安装(linux安装为例) 1.下载wkhtmltopdf wget http://download.gna.org/wkhtmltopdf/obsolete/linux/wkhtmltopdf ...

  9. JavaWeb_Get和Post方法传输数据区别

    Get方法和Post方法传输数据区别: 传送门 GET在浏览器回退时是无害的,而POST会再次提交请求 GET产生的URL地址可以被Bookmark,而POST不可以 GET请求会被浏览器主动cach ...

  10. JS框架_(Progress.js)圆形动画进度条

    百度云盘 传送门 密码: 6mcf 圆形动画进度条效果: <!DOCTYPE html> <html lang="en"> <head> < ...