1 / 22
文档名称:

oracle常用sql语句(汇总版).docx

格式:docx   大小:82KB   页数:22页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

oracle常用sql语句(汇总版).docx

上传人:aisheng191 2018/11/6 文件大小:82 KB

下载得到文件列表

oracle常用sql语句(汇总版).docx

文档介绍

文档介绍:Oracle 数据库常用 sql 语句
ORACLE 常用的 SQL 语法和数据对象
一. 数据控制语句 (DML) 部分
 T ( 往数据表里插入记录的语句 )
(
INSERT INTO 表名 (字段名 1, 字段名 2, …… ) VALUES值 1, 值 2, …… );

INSERT INTO 表名 (字段名 1, 字段名 2, ……)SELECT ( 字段名 1, 字段名 2, …… ) FROM 外的表名 ;

字符串类型的字段值必须用单引号括起来 , 例如 : ’GOOD DAY

如果字段值里包含单引号 ’需要进行字符串转换 , 我们把它替换成两个单引号 ''.
字符串类型的字段值超过定义的长度会出错 , 最好在插入前进行长度校验 .
‘ , -
日期字段的字段值可以用当前数据库的系统时间 SYSDATE, 精确到秒
或者用字符串转换成日期型函数 TO_DATE( 2001 -08- 01’’YYYYMM-DD’)
TO_DATE() 还有很多种日期格式 , 可以参看 ORACLE DOC.
年- 月-日 小时 : 分钟 :秒 的格式 YYYY-MM-DD HH24:MI:SS
INSERT 时最大可操作的字符串长度小于等于 4000 个单字节 , 如果要插入更长的字符串 , 请考虑字段用
CLOB 类型 ,
方法借用 ORACLE 里自带的 DBMS_LOB 程序包 .
INSERT 时如果要用到从 1 开始自动增长的序列号 , 应该先建立一个序列号
CREATE SEQUENCE 序列号的名称 (最好是表名 + 序列号标记 ) INCREMENT BY 1 START WI TH 1
MAXVALUE 99999 CYCLE NOCACHE;
其中最大的值按字段的长度来定 , 如果定义的自动增长的序列号 NUMBER(6) , 最大值为 999999
INSERT 语句插入这个字段值为 : 序列号的名称 .NEXTVAL
 ( 删除数据表里记录的语句 )
DELETE FROM 表名 WHERE 条件 ;
注意:删除记录并不能释放 ORACLE 里被占用的数据块表空间 . 它只把那些被删除的数据块标成 unused.
如果确实要删除一个大表里的全部记录 , 可以用 TRUNCATE 命令 , 它可以释放占用的数据块表空间
TRUNCATE TABLE 表名 ;
此操作不可回退 .
 ( 修改数据表里记录的语句 )

UPDATE 表名 SET 字段名 1= 值 1, 字段名 2= 值 2, …… WHERE 件 ;
如果修改的值 N 没有赋值或定义时 , 将把原来的记录内容清为 NULL, 最好在修改前进行非空校验 ;
值 N 超过定义的长度会出错 , 最好在插入前进行长度校验 ..
注意事项 :
A. 以上 SQL 语句对表都加上了行级锁 ,
确认完成后 , MIT 才能正式生效 ,
否则改变不一定写入数据库里 .
如果想撤回这些操作 , 可以用命令 ROLLBACK 复原 .
B. 在运行 INSERT, DELETE 和 UPDATE 语句前最好估算一下可能操作的记录范围 ,
应该把它限定在较小 ( 一万条记录 ) 范围内 ,. 否则 ORACLE 处理这个事物用到很大的回退段 .
程序响应慢甚至失去响应 . 如果记录数上十万以上这些操作 , 可以把这些 SQL 语句分段分次完成 ,
MIT 确认事物处理 .
二. 数据定义 (DDL) 部分
 ( 创建表 , 索引 , 视图, 同义词 , 过程 , 函数 , 数据库链接等 )
ORACLE 常用的字段类型有
CHAR 固定长度的字符串
VARCHAR2 可变长度的字符串
NUMBER(M,N) 数字型 M 是位数总长度 , N 是小数的长度
DATE 日期类型
创建表时要把较小的不为空的字段放在前面 , 可能为空的字段放在后面
创建表时可以用中文的字段名 , 但最好还是用英文的字段名
创建表时可以给字段加上默认值 , 例如 DEFAULT SYSDATE
这样每次插入和修改时 , 不用程序操作这个字段都能得到动作的时间
创建表时可以给字段加上约束条件
例如 不允许重复 UNIQUE, 关键字 PRIMARY KEY
( 改变表 , 索引 , 视图等 )
改变表的名称
ALTER TABLE 表名 1 TO 表名 2;
在表的后面增加一个字段
ALTER TABLE 表名 ADD 字段名 字段名描述 ;
修改表里字段的定义描述
ALTE