数据库

磁盘上存储的数据的集合 在物理上表现为数据文件、日志文件和控制文件等

在逻辑上以表空间形式存在 必须首先创建数据库,然后才能使用Oracle

数据库实例

每个启动的数据库都对应一个数据库实例,由这个实例来访问和控制数据库 为了运行数据库,

Oracle系统所运行的所有进程和分配的内存结构的组合体

数据库: 永久的,硬盘上

数据库实例:临时的,内存中

数据库物理结构

数据文件 扩展名是.DBF,用于存储数据库数据的文件 数据库表和数据文件不存在一对一对应关系

控制文件 扩展名是.CTL,是数据库启动及运行所必需的文件 默认包含3个控制文件

日志文件 扩展名是.LOG,它记录了对数据的所有更改信息 多个日志文件组之间循环使用

数据库逻辑结构

表空间 每个Oracle数据库都是由若干个表空间构成,用户在数据库中建立的所有内容都被存储到表空间中 创建数据库时会自动创建若干表空间

通过选择“控制面板”→“管理工具”→“服务”,打开“服务”窗口,可以看到Oracle服务

OracleService<SID>:数据库实例服务

OracleOraDb10g_hom1TNSListener :数据库监听服务

OracleDBConsoles<SID>:企业管理器服务

OracleOraDb10g_hom1iSQL*Plus:iSQL*Plus服务

SYS和SYSTEM用户都是Oracle 的系统用户,它们都使用SYSTEM表空间,SYS拥有更大的权限

为某用户解锁:

alter user scott account unlock;

最好为不同的用户创建独立的表空间 通过CREATE TABLESPACE命令创建表空间

CREATE TABLESPACE epet_tablespace  //空间名

DATAFILE 'E:\oracle\product\10.2.0\oradata\JBITDB\EPET.DBF'  //路径

SIZE 100M;   //大小

CREATE USER epet  //创建用户

IDENTIFIED BY bdqn  //添加密码

DEFAULT TABLESPACE epet_tablespace; // 指定表空间

角色是具有名称的一组权限的组合常用系统预定义角色

CONNECT:临时用户

RESOURCE:更为可靠和正式的用户

DBA:数据库管理员角色,拥有管理数据库的最高权限

#把CONNECT、RESOURCE角色授予用户epet

GRANT CONNECT,RESOURCE TO epet;

#撤销用户epet的RESOURCE角色

REVOKE RESOURCE FROM epet;

#允许用户查看 EMP 表中的记录 GRANT SELECT ON emp TO epet;

#允许用户更新 EMP 表中的记录 GRANT UPDATE ON emp TO epet;

数据类型

字符数据类型 CHAR:存储固定长度的字符串

VARCHAR2 :存储可变长度的字符串

NCHAR和NVARCHAR2 :存储Unicode字符集类型

NUMBER:存储整数和浮点数,格式为NUMBER(p, s)

column_name NUMBER { p = 38, s = 0}

column_name NUMBER (p) {整数}

column_name NUMBER (p, s) {浮点数}

日期时间数据类型

DATE:存储日期和时间数据

TIMESTAMP:比DATE更精确

LOB数据类型

BLOB:存储二进制对象,如图像、音频和视频文件

CLOB:存储字符格式的大型对象

示例:

CREATE TABLE master(

id NUMBER(11,0) PRIMARY KEY,

loginid NVARCHAR2(50) NOT NULL,

password NVARCHAR2(20) NOT NULL,

status CHAR(1) DEFAULT 1 NOT NULL

);

CREATE TABLE pet_type(

id NUMBER(11) NOT NULL,

name NVARCHAR2(50) NOT NULL,

status CHAR(1) DEFAULT 1 NOT NULL

);

ALTER TABLE pet_type ADD CONSTRAINT pet_type_pk PRIMARY KEY (id);

CREATE TABLE pet(

id NUMBER (11),

master_id NUMBER (11) NOT NULL,

name NVARCHAR2 (50),

type_id NUMBER (11) NOT NULL,

health NUMBER (11) DEFAULT 100 NOT NULL,

love NUMBER (11) DEFAULT 100 NOT NULL,

prop1 NVARCHAR2 (100),

prop2 NVARCHAR2 (100),

prop3 NVARCHAR2 (100),

adopt_time DATE NOT NULL,

status CHAR(1) DEFAULT 1 NOT NULL,

CONSTRAINT pet_pk PRIMARY KEY(id),

CONSTRAINT m_fk FOREIGN KEY (master_id ) REFERENCES master(id),

CONSTRAINT t_fk FOREIGN KEY (type_id) REFERENCES pet_type(id)

);

指定表的字段的注释

COMMENT ON TABLE pet IS '宠物';

COMMENT ON COLUMN pet.name IS '宠物昵称';

COMMENT ON COLUMN pet.health IS '宠物健康值';

序列是一个数据库的内置对象  产生一系列唯一的数值,作用是实现类似SQL Server中主键自增的效果

#创建序列  初始值为1,步长为1,无最大值,在缓存中保存预分配10个值

CREATE SEQUENCE master_seq

START WITH 1

INCREMENT BY 1

NOMAXVALUE CACHE 10;

#使用序列

INSERT INTO master VALUES(master_seq.nextval,'lkl','lkl',1); //NEXTVAL将返回序列的下一个值

INSERT INTO master VALUES(master_seq.nextval,'lyg','801',1);

SELECT master_seq.currval FROM dual; //查看序列的当前值

SELECT master_seq.nextval FROM dual; //查看序列的下一个值

#修改序列

ALTER SEQUENCE master_seq

INCREMENT BY 5

MAXVALUE 100000

NOCYCLE

NOCACHE;

#删除序列

DROP SEQUENCE master_seq;

oracle基础(基本介绍)的更多相关文章

  1. Oracle优化器介绍

    Oracle优化器介绍 本文讲述了Oracle优化器的概念.工作原理和使用方法,兼顾了Oracle8i.9i以及最新的10g三个版本.理解本文将有助于您更好的更有效的进行SQL优化工作. RBO优化器 ...

  2. Oracle 学习笔记(一)Oracle的基本介绍与语法

    1.1 Oracle基础知识 1.1.1 介绍 Oracle数据库的主要特点: 支持多用户.大事务量的事务处理 在保持数据安全性和完整性方面性能优越 支持分布式数据处理 具有可移植性 1.1.2 Or ...

  3. Oracle基础体系浅析

    不论是开发.管理.优化还是设计,对Oracle的基本原理的了解都是必不可少的,于是对自己最近关于Oracle的学习作出一点点的总结. 庖丁解牛之所以能做到"合于桑林之舞,乃中经首之会&quo ...

  4. 图说Oracle基础知识(一)

    本文主要对Oralce数据库操作的基础知识进行一下梳理,以便进行归纳总结.适用于未使用过Oracle数据库的读者,或需要学习Oracle数据库方面的基础知识.如有不足之处,还请指正. 关于SQL介绍的 ...

  5. android开发学习---linux下开发环境的搭建&& android基础知识介绍

    一.配置所需开发环境 1.基本环境配置 JDK 5或以上版本(仅有JRE不够) (http://www.oracle.com/technetwork/java/javase/downloads/ind ...

  6. oracle基础教程oracle客户端详解

    oracle基础教程oracle客户端工具详解 参考网址:http://www.oraclejsq.com/article/010100114.html 该教程介绍了oracle自带客户端sqlplu ...

  7. oracle基础教程(8)oracle修改字符集

    oracle基础教程(8)oracle修改字符集 1.用dba连接数据库 -->sqlplus / as sysdba 2.查看字符集 -->SELECT parameter, value ...

  8. oracle常用视图介绍

    oracle常用视图介绍---------------------2013/10/04(last updated) dba_开头:   dba_users     数据库用户信息   dba_segm ...

  9. 第三周博客之一---Oracle基础知识

    一.数据库的定义.作用介绍 1.定义:按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库. 2.数据库的发展历史: 2.1.在1962年数据库一词出现在系统研发的公司的技术备忘录中 2. ...

  10. Sql注入基础原理介绍

    说明:文章所有内容均截选自实验楼教程[Sql注入基础原理介绍]~ 实验原理 Sql 注入攻击是通过将恶意的 Sql 查询或添加语句插入到应用的输入参数中,再在后台 Sql 服务器上解析执行进行的攻击, ...

随机推荐

  1. 一张图一个题帮你迅速理解RLU算法

    下面是某年的软考题: 某进程页面访问序列为4,2,3,1,2,4,5,3,1,2,3,5,且开始执行时内存中没有页面,分配给该进程的物理块数是3,则采用RLU页面置换算法时的缺页率是多少? 对于这个问 ...

  2. cobalt strike批量发送钓鱼邮件

    0×01 利用Cobalt strike生成木马 这里我们生成木马可以用cs带的HTA.OFFICE宏.word宏来使目标上线cs,这里以word宏病毒为例子. 首先我们需要制作一个word宏病毒来进 ...

  3. 基于STL的堆略解

    什么是STL 以下内容摘自这儿. STL(Standard Template Library,标准模板库)是惠普实验室开发的一系列软件的统称.它是由Alexander Stepanov.Meng Le ...

  4. i春秋DMZ大型靶场实验(四)Hash基础

    下载工具包  打开目标机 通过目录爆破发现 phpmyadmin    在登录位置尝试注入 返现 可以注入 直接上sqlmap    上 bp 代理抓包 sqlmap.py  -r  bp.txt  ...

  5. ride.py 启动报错

    报错问题: C:\Users\iphauser>ride.py Traceback (most recent call last): File , in OnInit self._plugin_ ...

  6. 玩转 RTC时钟库 DS1302

    1.前言     最近博主在弄8266编程的时候,偶然发现两个全新时钟模块压仓货: DS1302 DS3231     为了避免资源浪费以及重复编写代码,博主还是抱着尝试的心态去寻找能够同时兼容 DS ...

  7. textbox获取焦点选中内容

    前台: <TextBox VerticalAlignment="> <TextBox.Style> <Style TargetType="TextBo ...

  8. LeetCode 5024 除数博弈 --(简单博弈论)

    今天在LeetCode的看到一到题目 这道题目有点坑,没有思路的话容易钻牛角. 刚刚开始时,我想的是直接用while循环来模拟计算,后来觉得这么好麻烦,也有复制的逻辑在里面.后面我推导了一下 以下是我 ...

  9. OptimalSolution(5)--数组和矩阵问题(1)简单

    一.转圈打印矩阵 题目:给定一个整型矩阵matrix,按照转圈的方式打印它. 要求:额外空间复杂度为O(1) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 打印结果为: ...

  10. JVM(2) Java内存溢出异常

    在Java虚拟机运行时数据区中,除了程序计数器之外,虚拟机栈.本地方法栈.方法区和Java堆都有发生OutOfMemoryError(简称OOM)异常的可能. 一.Java堆溢出 Java堆用于存储对 ...