向一个表发散弹枪: ⑴ insert into table_name [(column[,column...])] select_statement 每次只能插入一个表,但性能上比写多条insert语句要高。另外,Oracle还提供create table table_name as select ...,as不可少!实现直接创建并且插入表,依赖于后面的s
向一个表发散弹枪:⑴ insert into table_name [(column[,column...])] select_statement
每次只能插入一个表,但性能上比写多条insert语句要高。另外,Oracle还提供create table table_name as select ...,as不可少!实现直接创建并且插入表,依赖于后面的select语句的结果,如:create table new_table as select * from source_table where 1=0
-
案例:
表mxt新增一列time,那么这个列会被置在最后,现想把此列放于第2
create table copy_mxt as select id,time,name from mxt;
drop table mxt;
rname copy_mxt to mxt;
向多个表发散弹枪:
类型:
① 无条件的insert
② 带条件的insert all
③ 带条件的insert first
④ pivoting insert
多表insert的使用限制:
① 只能对table使用insert,不能对视图或物化视图使用
② 不能对远程表使用这个插入操作
③ 多表插入时,不能指定一个表的集操作
④ 多表insert的into的目标表加在一起的列数不能超过999
㈠ 无条件的insert
语法:
insert all
into dest_table1 [column(,column...)] [values (...)]
into dest_table2 [column(,column...)] [values (...)]
...
select_statement --values中指定是select结果列,如果没有values指定列,那么表示目标表的列类型和顺序与select语句查询的结果完全一致。建议不要省略目标表中的列和values,增强可读性。
例子:
1.create table emp_1 as select employee_id,last_name from employees where 1=0;
2.create table emp_2 as select * from employees where 1=0;
3.create table emp_3 as select * from employees where 1=0;
4.insert all
5.--不指定emp_1后面的列,也没有values指定列,那么emp_1所有列类型和顺序与查询的列的类型和顺序一致
6.--也就是emp_1中只有查询结果中的那几列,而且类型和顺序一致
7. into emp_1
8.--指定了emp_2后面的列,但没有values指定列,表示emp_2中要插入的列被选择出来,与查询结果列的类型和顺序一致
9.--emp_2也有很多列,不止这两列
10. into emp_2(employee_id,last_name)
11.--指定emp_3后面的列和values指定列,那么values后面的列名必须与查询结果一致,如果查询有别名,必须在values中使用别名
12.--emp_3指定的列的类型和顺序必须与values保持一致
13.--emp_3也可能列数大于指定列数
14. into emp_3(employee_id,last_name) values(e_id,e_last_name)
15. select employee_id e_id,last_name e_last_name
16. from employees
语法:
insert all
when condition_statement
then into dest_table1[指定列] values[查询中的列]
when condition_statement
then into dest_table2[指定列] values[查询中的列]
select_statement
注释:带条件的insert all与insert first的区别在于只按条件对查询的结果进行刷选,不会考虑前面已经匹配过的记录,每次都是全量匹配,而insert first对已经匹配过的记录不予考虑,下一个when会自动过滤掉上一个匹配过的行记录
例子:
1.insert all
2. --将查询结果s_id>20的插入,条件中指定的列必须与查询结果名字一致,如果有别名,请用别名 3. when e_id>20 4. then into emp_1 5. --s_last_name为M开头的插入,可能插入的行与s_id有重复 6. when e_last_name like 'M%' 7. then into emp_2(employee_id,last_name) 8. --如果指定else,则不满足上面条件的插入到emp_3,插入的行不会与上面两个重复 9. else 10. into emp_3(employee_id,last_name) values(e_id,e_last_name) 11. select employee_id e_id,last_name e_last_name 12. from employees

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

SublimeText3 Chinese version
Chinese version, very easy to use

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Dreamweaver CS6
Visual web development tools
