一、常见数据库对象

  1.基本对象

  

  对应的对象英文名参考https://docs.oracle.com/cd/B19306_01/server.102/b14220/intro.htm#sthref69

  2.表操作简介

    其他对象将会在后续章节介绍

      用户创建的表:包含用户创建和维护的表,

    查看创建的表:

    使用如下语句查看用户创建的表:(当然PL/SQL中可视化提供了十分方便的查看)

SELECT * FROM user_tables;
SELECT    * FROM      user_catalog ;

     表的命名规则:与JAVA命名规则略有偏差:

表名和列名:
必须以字母开头
必须在 1–30 个字符之间
必须只能包含 A–Z, a–z, 0–9, _, $, 和 #
必须不能和用户定义的其他对象重名
必须不能是Oracle 的保留字

      创建表先决条件:

        CREATE TABLE权限

        存储空间

      创建表语法:

CREATE TABLE [schema.]table
(column datatype [DEFAULT expr][, ...]);

      简单示例:

CREATE TABLE emp1(
id NUMBER(10),
name VARCHAR2(20),
salary NUMBER(10,2),
hire_date DATE
)

    也可以使用SELECT通过结果集创建

CREATE TABLE emp2
AS
SELECT employee_id id,last_name name FROM employees

    当然,也可以只复制表结构而不需要表数据:(直接通过过滤条件不成立进行筛选)

CREATE TABLE emp3
AS
SELECT * FROM employees WHERE 1=2

     给字段加注释的写法(注意主MYSQL不一样!)

comment  on  column  表名.字段名   is  '注释内容';
comment on column OPERATOR_INFO.MAIN_OPER_ID is '归属操作员';
comment on table 表名 is '注释内容';
comment on table OPERATOR_INFO is '操作员信息表';

     数据类型:

    

  完整数据类型请参考官方文档https://docs.oracle.com/cd/E11882_01/server.112/e41084/sql_elements001.htm#SQLRF30020

     修改表:

    语法:

    

    示例:

  增加列:

ALTER TABLE emp1
ADD(product VARCHAR2(100))

  修改列:

ALTER TABLE emp1
MODIFY(product VARCHAR2(101))

  删除列:

ALTER TABLE emp1
DROP COLUMN product

      删除表:

DROP TABLE dept80;

      清空表:(DELETE可以回滚,而TRUNCATE无法回滚)

TRUNCATE TABLE

    用于清除表数据,释放存储空间,只清空表数据,但保留表结构

    改变对象名称:

RENAME dept TO detail_dept;

二、数据处理

  插入记录

  语法:(单条记录)

INSERT INTO    table [(column [, column...])]
VALUES (value [, value...]);

  示例:

INSERT INTO emp1 VALUES(1,'明',3000,to_date('2018-01-05','yyyy-mm-dd'));

  // 插入指定列等不再赘述,参考MySQL章节

  使用结果集进行插入:

INSERT INTO emp1(col1,col2) SELECT col1,col2 FROM empyolees

  创建插入脚本:

INSERT INTO departments
(department_id, department_name, location_id)
VALUES (&department_id, '&department_name',&location);

  之后会弹出对话框:

  

  更新记录

  语法:

UPDATE        table
SET column = value [, column = value, ...]
[WHERE condition];

  示例:(请使用条件语句过滤,除非你确定需要更改全表的记录!)

UPDATE emp2 SET NAME = '刚' WHERE ID = 1;

  当然,如果没有显式地使用COMMIT,是可以使用rollback进行回滚

一个数据库事务起始于一个SQL语句,中止于以下4种事件之一:
COMMIT或ROLLBACK语句
DDL/DCL隐式提交
用户退出时自动提交
系统强行关闭时取消事务
事务结束后,下一条SQL语句将开始一个新的事务。

  关于rollback的一些介绍,参考http://blog.csdn.net/jack_ywj/article/details/52151975

  删除记录

  语法:(未提交的支持回滚)

DELETE FROM      table
[WHERE condition];

  示例:

DELETE FROM emp2 WHERE ID = 206;

三、数据库事务

    更多概念介绍参考MySQL与JDBC随笔

  Oracle事务由以下几部分组成: 

    一个或多个DML 语句

    一个 DDL(Data Definition Language – 数据定义语言) 语句

    一个 DCL(Data Control Language – 数据控制语言) 语句

  事务的开始与结束:

      以第一个 DML 语句的执行作为开始

    以下面的其中之一作为结束:

              ——在结束之前其他用户是看不到改变的,直到提交才能在数据库显示而被所有用户查看到。并且也有类似MySQL的行锁!

      COMMIT 或 ROLLBACK 语句

      DDL 语句(自动提交)

      用户会话正常结束

      系统异常终止

  事务控制

  

    

       使用 SAVEPOINT 语句在当前事务中创建保存点。

    使用 ROLLBACK TO SAVEPOINT 语句回滚到创建的保存点。

    示例:

UPDATE...
SAVEPOINT update_done;
Savepoint created.
INSERT...
ROLLBACK TO update_done;
Rollback complete.

Oracle入门第四天(上)——表管理与数据处理的更多相关文章

  1. Oracle入门第四天(下)——约束

    一.概述 1.分类 表级约束主要分为以下几种: NOT NULL UNIQUE PRIMARY KEY FOREIGN KEY CHECK 2.注意事项 如果不指定约束名 ,Oracle server ...

  2. oracle入坑日记<五>数据表

    1   数据表 1.1.数据表是存放数据字段信息的地方:在Oracle,数据表拥有者单位是用户,同时数据表属于表空间.如: 登录my_user用户在orcl表空间下创建的表就是 my_user用户在o ...

  3. TYUT程序设计入门第四讲练习题题解--数论入门

    程序设计入门第四讲练习题题解--数论入门 对于新知识点的学习,需要不断地刷题训练,才能有所收获,才能更好地消化知识点. 题组链接: 程序设计入门第四讲练习题--数论 by vjudge 题解: A. ...

  4. JavaMail入门第四篇 接收邮件

    上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操 ...

  5. Kotlin入门第四课:简单工厂模式

    Kotlin基础知识的学习,请参考之前的文章: Kotlin入门第一课:从对比Java开始 Kotlin入门第二课:集合操作 Kotlin入门第三课:数据类型 初次尝试用Kotlin实现Android ...

  6. Oracle入门第三天(上)——多表查询与分组函数

    一.多表查询 所有的连接分析,参考之前随笔:http://www.cnblogs.com/jiangbei/p/7420136.html 1.笛卡尔积 select last_name, depart ...

  7. Oracle入门第五天(上)——数据库对象之视图

    一.概述 1.什么是视图(VIEW) 视图 从表中抽出的逻辑上相关的数据集合(是一张虚表). 2.为什么使用视图 1.控制访问 2.简化查询 3.视图的分类 二.视图管理 1.创建视图 CREATE ...

  8. Oracle数据安全(四)j角色管理

    一.角色管理的概述 1.角色的概念 为了简化数据库权限的管理,在Oracle数据库中引入了角色的概念.所谓的角色就是一系列相关权限的集合. 2.角色的特点 在数据库中,角色的名称必须是唯一的,不能与用 ...

  9. CTF---密码学入门第四题 困在栅栏里的凯撒

    困在栅栏里的凯撒分值:10 来源: 北邮天枢战队 难度:易 参与人数:4531人 Get Flag:2124人 答题人数:2285人 解题通过率:93% 小白发现了一段很6的字符:NlEyQd{sef ...

随机推荐

  1. Oracle手工修改JOB属性

    以下由sqlplus 来执行,具体参照一下相关的文档VARIABLE jobno number;BEGINDBMS_JOB.SUBMIT(:jobno,’p_test;’SYSDATE,’SYSDAT ...

  2. mysql install steps

    the official documents for mysql 5.6 install key steps: # Preconfiguration setup shell> groupadd ...

  3. Access用OleDbParameter无法更新数据解决方案

    昨天遇到了一个非常郁闷的问题,这个问题我几乎花了一天的时间才找到了造成问题的症结并解决. 问题是这样,原本一个使用Sqlserver数 据库的系统,我要让它实现Access数据接口,即我可以很方便地把 ...

  4. sychronized关键字(多线程)

    sychronized关键字: 1. 作用:利用该关键字来创建内置锁,实现线程同步: 2. 分类:(1)sychronized同步方法:(2)sychronized同步代码块: 3. sychroni ...

  5. RedisClient的安装及基本使用

    管理redis的可视化客户端目前较流行的有三个:Redis Client ; Redis Desktop Manager ; Redis Studio. 这里目前给大家介绍Redis Client 的 ...

  6. 2018-2019-2 《网络对抗技术》Exp0 Kali安装 Week1 20165322

    Exp0 Kali安装 由于VMWare已经装好,镜像也是从上届拷下来的.下载部分就省略.. 新建虚拟机 安装好VM后点击新建虚拟机 选择稍后安装操作系统,系统选择Linux-ubuntu 接下来根据 ...

  7. LayIM.AspNetCore Middleware 开发日记(四)主角登场(LayIM介绍)

    前言 在前几篇中已经初步介绍了开发AspNetCore中间件的一些基础知识,不过都没有很深入的去研究,后续还是需要去看看源码.本篇呢,终于有点开头的味道了,就是要介绍LayIM了,其实标题写的是主角, ...

  8. 6 spark 存储体系 --内存管理

    6.5  memoryMode

  9. Spring(十四)之事务

    事务管理 一个数据库事务是一个被视为单一的工作单元的操作序列.这些操作应该要么完整地执行,要么完全不执行.事务管理是一个重要组成部分,RDBMS 面向企业应用程序,以确保数据完整性和一致性.事务的概念 ...

  10. ROS C++ 规范概要

    一.动机 代码一致才能可读.联调.高效率.高复用.可移植性. 二.命名方式 CamelCased camelCased under_scored ALL_CAPITALS 2.1 Package命名方 ...