3.数据库操作相关术语,Oracle认证,insert into,批量插入,update tablename set,delete和truncate的差别,sql文件导入
1相关术语
|
语句 |
含义 |
操作 |
|
DML语句 |
(Data Manipulation Language) 数据库操作语言 |
insert update delete select |
|
DDL语言 |
(Date definition Language) 数据库定义语言 |
create table;create view index sequence synonvm同义词,truncate |
|
DCL语言 |
(Data control Language) 数据控制语言 |
commit rollback savepoint |
2数据库认证
|
Oracle数据库管理员认证专员(OCA) |
Oracle Certified Associate |
|
Oracle数据库管理员认证专家(OCP) |
Oracle Certified Professional |
|
Oracle数据库管理员认证大师(OCM) |
Oracle Certified Master |
3 insert语句
A插入一个完整记录:
insert into emp values (1, 'aaa', 'clerk',7092, '17-12月-80',
8000, NULL, 20);
B插入部分记录:
insert into emp(empno,ename,deptno)values(2,'bb',20);
C插入空值(显示和隐式)
D插入日期
insert into empvalues(3,'ccc','clerk',7092,sysdate,8000,NULL,20);
E创建脚本 取地址符
& ,通过这样的方式能够让用户自己定义输入
SQL> insert into emp(empno,ename,deptno)
2 values(&empno,&ename,20);
输入 empno的值: 4
输入 ename的值: 'cccc4'
原值 2: values(&empno,&ename,20)
新值 2: values(4,'cccc4',20)
已创建 1行。
F select ename,job,&tt from emp;
4批量插入数据
A把10号部门的员工copy到另外一个表中
|
创建表结构 |
|
create table emp10 as select * from emp where 1=2; |
|
|
|
批量插入数据 |
|
insert into emp10 select * from emp where deptno = 10; |
|
|
5 update语句,语法结构例如以下:
|
UPDATE table SET column = value [, column = value, ...] [WHERE |
|
update emp10 set deptno = 20 where empno = 7782; |
|
|
6 delete语句
|
语法结构: |
|
DELETE [FROM] table [WHERE condition]; |
7 delete与truncate的差别
|
delete(删除表的数据)和truncate表(truncate实质把表drop然后又一次建表)差别: |
|
1、delete逐条删除,truncate先摧毁在重建 |
|
2、delete语句是DML语句,truncate是DDL语言 A DML语句能够闪回 做错的而且提交了,能够通过闪回,撤销操作 B DDL语言不能够闪回 flashback |
|
3、delete是逐条删除,会产生碎片,truncate不会产生碎片 行移动功能:要开启闪回功能,必需要开启行移动功能。 |
|
4、delete不会释放空间 |
|
5、delete能够回滚 truncate不能够 |
|
6、oracle delete快,mysql |
网络上关于delete和truncate的差别的介绍:
|
语法: |
|
delete from tablename; truncate table tablename; |
|
差别: |
|
1、 delete 2、 delete 3、 delete 4、 当使用行锁运行DELETE语句时,将锁定表中各行以便删除。Truncate始终锁定表和页,而不是锁定各行。 5、 假设有identity产生的自增id列,delete 6、 truncate不会触发delete的触发器,因此truncate操作不记录各个行删除。 |
|
总结: |
|
1、 truncate和delete仅仅删除数据,不删除表的结构(定义) drop语句将删除表的结构,被依赖的约束(constrain),触发器(trigger),索引(index);依赖于该表的存储过程/函数将保留,可是变为invalid状态。 2、 delete语句是dml操作,这个操作会放到rollback 3、 delete语句不影响表所占用的extent,高水线(high 4、 速度,一般来说:drop 5、 安全性:小心使用drop和truncate,尤其没有备份的时候,否则哭都来不及。 6、 使用上,想删除部分数据行用delete,注意带上where子句。回滚段要足够大。想删除表,当然用drop,想保留表而将全部数据删除。假设和事务无关,用truncate就可以,假设和事务有关,或者想触发trigger,还是用delete,假设是整理表内部的碎片,能够用truncate跟上reuse |
8从文件里导入数据,通过命名delete和
truncate删除表数据
|
从文件导入数据 |
|
SQL> set timing off; SQL> set feedback off; SQL> drop table testdelete purge; SQL> @c:\Sql.sql; SQL> SQL> set timing on; //最后删除数据表的时候,把时间打开,记录时间 SQL> delete from testdelete; 已用时间: 00: 00: 00.09 |
|
从文件导入数据: |
|
set timing off; @c:\Sql.sql; set timing off; select count(*) from testdelete; set timing on; //最后删除数据表的时候,把时间打开,记录时间 truncate table testdelete; 已用时间: 00: 00: 00.51 |
|
总结: |
|
truncate表一般比delete表的速度快,但Oracle做了优化,delete数据的时候更快些! |
3.数据库操作相关术语,Oracle认证,insert into,批量插入,update tablename set,delete和truncate的差别,sql文件导入的更多相关文章
- 【AOP】操作相关术语---【Spring】的【AOP】操作(基于aspectj的xml方式)
[AOP]操作相关术语 Joinpoint(连接点):类里面哪些方法可以被增强,这些方法称为连接点. Pointcut(切入点):在类里面可以有很多的方法被增强,比如实际操作中,只是增强了类里面add ...
- 一条insert语句批量插入多条记录
一条insert语句批量插入多条记录 常见的insert语句,向数据库中,一条语句只能插入一条数据: insert into persons (id_p, lastname , firstName, ...
- mybatis oracle两种方式批量插入数据
mybatis oracle两种方式批量插入数据 注意insert,一定要添加: useGeneratedKeys="false" ,否者会报错. <insert id=&q ...
- 【树莓派】h2数据库操作相关
之前在树莓派上面操作时候,遇到一些业务方面的bug,和团队中的同事经过多次尝试,但就是难以重现用户现场的问题. 但是问题却实实在在地发生,虽然并不是必然可重现的bug,但是也比较闹心: 发生了问题,也 ...
- 数据库操作相关(sql语句-php)
文件:db.config.smarty.php 这个文件主要是用于数据库配置 <?php $db = array( 'host'=>'localhost', 'user'=>'roo ...
- linux 操作之一 如何在linux将本地数据*.sql文件导入到linux 云服务器上的mysql数据库
liunx 版本ubuntu 16.4 mysql 版本 5.6 1)准备*.sql文件 (* 是准备导入的sql文件的名字) 2)liunx 远程客户端 SecureCRT 7.0 alt+p ...
- 【JDBC】使用Spring提供的JDBCTemplate通过Statement向MySql数据库插入千万条数据,耗时4m55s,使用insert语句批量插入方式二
这回依然是使用 insert批量插入这种方式 insert into emp(name,age,cdate) values ('A' , 20, '2019-10-13 00:00:00'), ('B ...
- Mybatis 针对ORACLE和MYSQL的批量插入与多参数批量删除
今天利用Mybatis的<for each>标签做oracle的批量插入数据时,发现和MySQL数据库有区别.在此记录下,以防之后再踩坑. 一.批量插入: 1.controller: /* ...
- MYSQL批量插入数据库实现语句性能分析【转】 批量插入!程序里面对于数据库插入的功能尽量用【异步处理+批量插入+(事务)】
假定我们的表结构如下 代码如下 CREATE TABLE example (example_id INT NOT NULL,name VARCHAR( 50 ) NOT NULL,value VA ...
随机推荐
- Android开发之Intent.Action
1 Intent.ACTION_MAIN String: android.intent.action.MAIN 标识Activity为一个程序的開始.比較经常使用. Input:nothing Out ...
- iOS 苹果app提交 ITC.apps.validation.prerelease_build_missing
提示这信息,由于没有选择包文件, 在提交页面以下bulid的区域, 加入你的app就可以 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYWxpbmNleG ...
- RequireJs运行原理
在require中,根据AMD(Asynchronous Module Definition)的思想,即异步模块加载机制,其思想就是把代码分为一个一个的模块来分块加载,这样无疑可以提高代码的重用. 在 ...
- jquery中push()的用法(数组添加元素)
push定义和用法 push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度. 语法 arrayObject.push(newelement1,newelement2,....,newele ...
- 图文讲解基于centos虚拟机的Hadoop集群安装,并且使用Mahout实现贝叶斯分类实例 (7)
接下来,我们开启hadoop集群. 如果之前打开过Hadoop,可能会发生lock的问题,解决方案:http://blog.csdn.net/caoshichaocaoshichao/article/ ...
- Java学习——继承
将学生工人的共性描述提取出来,单独进行描述,只要让学生和工人与单独描述的这个类有关系,就可以了. 继承:1,提高了代码的复用性.2,让类与类之间产生了关系.有了这个关系,才有了多态的特性. 注意:千万 ...
- Ubuntu中nfs服务器安装与配置
一.执行命令 sudo apt-get install nfs-kernel-server 二.为创建nfs文件夹 sudo mkdir /usr/nfs 更改目录权限:sudo chmod 777 ...
- C++程序设计实践指导1.7超长数列中n个数排序改写要求实现
改写要求1:将以上程序改写为适合超长整数 改写要求2:将以上程序改写为适合超长数列 改写要求3:将数列中指定位置m开始的n个结点重新按降序排序 改写要求4:输出指定位置m开始的n个结点的超长整数 #i ...
- linux学习笔记之文件结构和函数
本文参考<UNIX环境高级编程> 一.基础介绍. 1:文件的构成. 1,首先声明,这里的文件和目录,表示普通的文件和目录.不确定是否可以应用到:设备,管道等特殊形式的文件(UNIX把它们也 ...
- windows查询端口
依次点击“开始→运行”,键入“cmd”并回车,打开命令提示符窗口.在命令提示符状态下键入“netstat -an”,按下回车键后就可以看到以数字形式显示的TCP和UDP连接的端口号及状态.