li
  当前位置:主页 > 配置管理 > 文章内容
li
ORACLE 常用的SQL语法和数据对象--数据控制语句 (DML) 部分
来源: www.ixdba.net  作者: Oracle+Linux专业技术门户    时间:2008-12-25   阅读:83  

1.INSERT  (往数据表里插入记录的语句)

INSERT INTO
表名(字段名1, 字段名2, ……) VALUES ( 1, 2, ……);
INSERT INTO
表名(字段名1, 字段名2, ……)  SELECT (字段名1, 字段名2, ……) FROM 另外的表名;
IXDBA.NET技术社区

字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’
如果字段值里包含单引号需要进行字符串转换, 我们把它替换成两个单引号 ''.
字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验.

日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒
或者用字符串转换成日期型函数TO_DATE(‘2001-08-01’,’YYYY-MM-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  WITH  1
MAXVALUE  99999  CYCLE  NOCACHE;

其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999
INSERT
语句插入这个字段值为: 序列号的名称.NEXTVAL

2.DELETE  (
删除数据表里记录的语句)

DELETE FROM表名 WHERE 条件;

注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused.

如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间
TRUNCATE TABLE
表名;
此操作不可回退.

3.UPDATE  (修改数据表里记录的语句)

UPDATE表名 SET 字段名1=1, 字段名2=2, …… WHERE 条件;

如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验;N超过定义的长度会出错, 最好在插入前进行长度校验..

注意事项:

A.      以上SQL语句对表都加上了行级锁, 确认完成后, 必须加上事物处理结束的命令 COMMIT 才能正式生效,否则改变不一定写入数据库里. 如果想撤回这些操作, 可以用命令 ROLLBACK 复原.

B.     
在运行INSERT, DELETE UPDATE 语句前最好估算一下可能操作的记录范围,应该把它限定在较小 (一万条记录) 范围内,. 否则ORACLE处理这个事物用到很大的回退段.程序响应慢甚至失去响应. 如果记录数上十万以上这些操作, 可以把这些SQL语句分段分次完成,其间加上COMMIT 确认事物处理.




  上一篇: oracle基础知识--常用SQL*Plus语...   下一篇: ORACLE 常用的SQL语法和数据对象...
li
 §相关评论  
 热点文章

·oracle Logfile的不同状态说明
·Oracle数据库的一些常用操作经
·Oracle10g(10.2) 在Redhat AS4
·oracle工具:浅谈LogMiner的使用
·RHAD AS4 上安装 Oracle 数据库
·oracle基础知识(物理结构)
·oracle基础:Oracle中null的使用
·Oracle常用基本语法操作集锦
·oracle数据库查询前台正在发出
·AIX+ORACLE10G安装手册
·oracle数据库9i升级到oracle10
li
 编辑推荐
·oracle Logfile的不同状态说明
·Oracle数据库的一些常用操作经
·Oracle10g(10.2) 在Redhat AS4
·oracle工具:浅谈LogMiner的使用
·RHAD AS4 上安装 Oracle 数据库
·oracle基础知识(物理结构)
·oracle基础:Oracle中null的使用
·Oracle常用基本语法操作集锦
·oracle数据库查询前台正在发出
·AIX+ORACLE10G安装手册
·oracle数据库9i升级到oracle10
li
 相关篇章
·oracle基础知识--常用SQL*Plus语...
·利用ORADEBUG命令DUMP控制文件
·oracle日常操作汇总:表空间篇
·oracle日常操作汇总:日志篇
·ORA-02449: unique/primary keys...
·ORACLE表间关系详述
·如何查询一个表中某字段重复记录...
·ORA-01688:unable to extend tab...
·ORA-03113:end-of-file on comm...
·逻辑standby数据库的创建过程
·ORACLE 常用的SQL语法和数据对象...
·Oracle10g中SCN与TimeStamp的相互...
·又见ORA-19809,垃圾的oracle闪回...
·主键与外键之ORA-02292: integri...
 
li
设为首页 | 关于我们 | 技术服务 | 收藏本站 | 网站地图 | 联系方式 | 本站友情连接