Orcal笔记3-DDL-DML

一.Oracle的支持数据类型
     1.字符串类型
         char  固定长度(定义时即已确定长度,空余位置被补全),最大长度255,如 name char(10),‘中‘会占用10个长度;
         varchar2 长度不固定,根据实际情况占用,空余被放弃,最大长度3999,如 name varchar2(10),‘中‘会占用2个长度;

2.数值类型
         number(3) 最大数据999
         number(3,2) 最大数据9.99

3.大数值类型
         long:最大长度2G,相当于mysql中的longtext;
         clob:最大长度4G;
         blob:最大长度4G

4.日期类型
         data:相当于mysql中的datatime,格式为yyyy-mm-dd hh:mi:ss;
         timestamp:时间戳,精度高,精确到小数点后9位;

二.DDL和DML
     --查看当前用户的权限
     SELECT * FROM session_privs;

--创建表空间和数据文件
     CREATE TABLESPACE qin_space DATAFILE ‘c:\\qin.dbf‘ SIZE 5M AUTOEXTEND ON NEXT 1M;

--创建用户
     CREATE USER qin IDENTIFIED BY qin DEFAULT TABLESPACE qin_space;

--赋予权限 3个角色 dba resource connect
     GRANT DBA TO qin;

--创建表 t_student
     CREATE TABLE t_student(
            tid NUMBER(8),
            tname VARCHAR2(30) NOT NULL,
            telephone VARCHAR2(11),
            gender CHAR(1),
            birthday DATE,
           
            CONSTRAINT pk_tid PRIMARY KEY(tid),           --主键约束
            CONSTRAINT unique_column UNIQUE(telephone),   --唯一约束
            CONSTRAINT check_column CHECK(gender IN(0,1)) --检查约束
     )

--插入数据
     INSERT INTO t_student VALUES(1,‘小潘‘,‘110000011‘,‘0‘,to_date(‘2017-09-16‘,‘yyyy-mm-dd‘));
     SELECT * FROM t_student;

--创建orders表
     CREATE TABLE orders(
            o_id NUMBER(8) PRIMARY KEY,
            o_totalprice NUMBER(8,2)
     )

--插入数据
     INSERT INTO orders VALUES(1,1000);
     INSERT INTO orders VALUES(2,2000);
     SELECT * FROM orders;

--创建表orderdetail,设置与orders表的外键关联
     CREATE TABLE orderdetail(
            od_id NUMBER PRIMARY KEY,
            od_name VARCHAR2(30),
            o_id NUMBER(8),
            CONSTRAINT fk_o_id FOREIGN KEY(o_id) REFERENCES orders(o_id)
     );

--插入数据
     INSERT INTO orderdetail VALUES(1,‘mouse‘,1);
     INSERT INTO orderdetail VALUES (2,‘keyboard‘,2);
     SELECT * FROM orderdetail

--快速建表
     CREATE TABLE myemp AS SELECT * FROM SCOTT.emp;
     CREATE TABLE mydept AS SELECT * FROM SCOTT.dept;

--update  需求:给NEW YORK地区的部门员工加薪100元
     --查询NEW YORK地区的部门员工
     SELECT * FROM myemp WHERE deptno IN (SELECT deptno FROM mydept WHERE loc = ‘NEW YORK‘);
     UPDATE myemp SET sal = sal+100 WHERE deptno IN (SELECT deptno FROM mydept WHERE loc = ‘NEW YORK‘);

--修改表结构
     --t_student表加一列address
     ALTER TABLE t_student ADD( address VARCHAR2(30));
     --修改address字段的长度为200
     ALTER TABLE t_student modify(address varchar2(200));
     --删除address列
     ALTER TABLE t_student DROP COLUMN address;

三.delete和truncate区别
   delete只是删除了数据,truncate是摧毁了表然后重建
   delete语句会产生磁盘碎片,而truncate不会
   delete删除的数据可以找回的

四.Oracle的其它对象
     1.视图:
         视图是一个虚表,可以用来封装复杂的sql语句和隐藏敏感列;视图是原数据表的引用,操作视图会改变原表;
         语法:create view 视图名称 as sql查询语句

只读视图: with read only
         create view view_emp as select ename, empno, job, mgr from myemp with read only;

2.序列:
         独立于表之外的一个对象,主要用于主键自增
         语法:
         create sequence seq_test;
         select seq_test.nextval from dual;
         select seq_test.currval from dual;

序列的完整语法:
         create sequence seq_sequence
         increment by 2   --递增值 默认1
         start with 3     --起始值 默认1
         maxvalue 15      --最大值  默认 19个9
         minvalue 2       --最小值  默认1
         cycle            --循环  默认 nocycle
         cache 5          --缓存的数量  默认缓存20

3.索引
         创建索引可以提高查询效率
         语法格式:create index 索引名字 on 表名(列名)
         当数据量较小或数据经常被修改时,不建议创建索引.

4.同义词(synonym)
         优点:可以缩短访问对象的名称;
         语法:create [public] synonym 名称 for 对象;
         举例:
         create synonym e for scott.emp;
         select * from e;

五.数据导入导出(dos窗口下,不需要连接到oracl)
     1. 导出Scott用户下的所有对象
       exp 用户名/密码@IP:1521/orcl   file=‘位置\\想要保存的文件名称.dmp‘ owner=用户名

2.  导入到用户qin中
       imp 用户名/密码@IP:1521/orcl   file=‘位置\\已有的想要导入的文件名称.dmp‘ full=y

时间: 2024-11-07 11:30:33

Orcal笔记3-DDL-DML的相关文章

Orecle Mysql 基本sql语句DDL & DML 介绍与总结 by 冰琉璃

先给大家普及一下安装mysql的简易方法:yum yum search mysql (查找关于mysql的内容) 找到后需要安装3个内容 mysql.i386 mysql-server.i386 mysql-devel.i386 安装过后 service mysqld start (启动mysql服务) 进入mysql mysql -h -u root -p 密码直接回车 开始密码为默然:以后可以在mysql里面改密码或者创建账号等操作 Mysql的sql语句大致分为4种  DDL (定义语句)

【Mysql学习笔记】DDL、DML、DCL区别

DDL (Data Definition Language)数据定义语言,主要用于改变表的结构,数据类型,表之间的链接和约束等初始化工作上,多用于建表时.主要命令有CREATE,ALTER,DROP DML(Data Manipulation Language)数据操控语言,主要用于对表的操作,查询更新等,常用命令为SELECT ,UPDATE,INSERT,DELETE DCL(Data Control Language)数据控制语言,主要用于设置或者理发数据库用户定义或角色,定义权限的语句,

SQL中的四种语言DDL,DML,DCL,TCL

1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema. DDL是SQL语言的四大功能之一.用于定义数据库的三级结构,包括外模式.概念模式.内模式及其相互之间的映像,定义数据的完整性.安全控制等约束DDL不需要commit.CREATEALTERDROPTRUNCATECOMMENTRENAME 2.DML(Data Manipulation Lang

DDL\DML\DCL\DQL

[DML] DML = Data Manipulation Language,数据操纵语言,命令使用户能够查询数据库以及操作已有数据库中的数据的计算机语言.具体是指是UPDATE更新.INSERT插入.DELETE删除.主要是对数据库中一条或者多条数据进行操纵. [DDL] 数据库模式定义语言DDL(DataDefinition Language),是用于描述数据库中要存储的现实世界实体的语言.一个数据库模式包含该数据库中所有实体的描述定义.这些定义包括结构定义.操作方法定义等.包括了CREAT

数据库必会必知 之 SQL四种语言:DDL DML DCL TCL

作者:泥瓦匠 今天群里面讨论,DDL 还是 DML,我这种小白还是总结下他们的区别吧. 1. DDL - Data Definition Language 数据库定义语言:定义数据库的结构. 其主要命令有CREATE,ALTER,DROP等,下面用例子详解.该语言不需要commit,因此慎重. CREATE - to create objects in the database   在数据库创建对象 例:CREATE DATABASE test; // 创建一个名为test的数据库 ALTER

SQL四种语言:DDL,DML,DCL,TCL

1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema. DDL是SQL语言的四大功能之一.用于定义数据库的三级结构,包括外模式.概念模式.内模式及其相互之间的映像,定义数据的完整性.安全控制等约束DDL不需要commit.CREATEALTERDROPTRUNCATECOMMENTRENAME 2.DML(Data Manipulation Lang

ddl dml dcl

分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 首先,简要介绍基础语句: 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份数据的 device USE

oracle DDL,DML,DCL, 基础概念详解

一.SQL语言,有两个组成部分: DML(data manipulation language):它们是SELECT.UPDATE.INSERT.DELETE,命令是用来对数据库里的数据进行操作的语言. DDL(data definition language):主要的命令有CREATE.ALTER.DROP等,DDL主要是用在定义或改变表(TABLE)的结构,数据类型,表之间的链接和约束等初始化工作上,他们大多在建立表时使用. 二.SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML

DDL/DML是什么?

DDL:(Data Definition Language)数据库定义语言 它是定义数据库的语言, 里面包含: CREATE ALTER DROP TRUNCATE COMMENT RENAME DML:(Data Manipulation Language)数据操纵语言 它是对数据库进行操作的语言,查询和更新等操作. 动作有: SELECT INSERT UPDATE DELETE MERGE CALL EXPLAIN PLAN LOCK TABLE 参考文章:http://www.cnblo

一张表格阐释DDL,DML,DCL,DQL

名称 英文 中文释义 涉及的命令关键字 关系 DDL Data Definition Language 数据库模式定义语言 CREATE,TRUNCATE ,DROP,ALTER 共同组成数据库的完整语言 DML Data Manipulation Language 数据操纵语言 INSERT.UPDATE.DELETE DCL Data Control Language 数据库控制语言 grant.revoke 等 DQL Data Query Language 数据库查询语言 SELECT