A. 在sql语句中用PARALLEL指定并行查询,应该怎么用
并行查询在sql语句上不用设置。
是通过系统参数,将并行设置打开的。
oracle 11g中,parallel_degree_prolicy控制的,默认是manual关闭
在未开启的状态下,也可以对执行表进行并行处理
1. alter table table_name parallel;
2.也可以sql中加hits 如 select /*+ PARALLEL(t1, <degree>)*/ * from t1
<degree>如果不输入,是使用默认的值
B. 数据库中这个parallel函数是什么意思啊例如这行代码: SELECT /*+ Parallel(t,8) */ * FROM a;
parallel不是函数,/* */在Oracle中拿肆是hint,这句sql意思是强行启用并行模式来执行当前SQL,按理是数字消搜轿越大,执行效率越高,但与CPU个数漏悉有关
C. SQL数据库并发处理(如何处理数据库并发问题)
并发(concurrent)和并行(parallel)这两个概念,在数据库系统的资料中经常出现,然而有关它们的定义和区别却没有明确的说法。这里,我们根据这两个概念在资料中的使用,对它们的不同做一个说明。
并发是指多个任务的同时执行,任务与任务之间没有联系。由于数据库系统要同时为许多用户提供服务,每个用户都可以发出自己的访问请求,一个请求就是一个任务。在一个时间点,数据库系统可能要同时处理多个戚培任务。因此,数据库系统一定要具备并发处理能力。
并行是指将一个任务划分为多个子任务,这些子任务同时执行。在所有子任务处理完成后,将它们的结果进行合并,就得到该任务的最终处理结果。在数据库系统中,如果要执行一个大的数据查询,为了提高速度、降低响应时间,用户可以通过系统配置或者在命令中,要求对该大数据量查询进行并行处理,将该查询划分成多个子查询。这些子查询同时执行,最后系统将所有子查询的处理结果进行合并,作为该查询处理的最终结果。现有的大型数据库系统都支持并行处理。
需要说明的是,并发和并行与数据库系统采用多进程仔局还是多线程体系结构无关。对采用多进程结构的数据库系统,所有的任务、子任务通过进程来处理;而对采用多线程结构的数据库系统,这些工作是由线程来完成。
数据库系统的并发控制,涉及到任务的调度、数据的一致性及可靠性等,而数据库系统的并行处理,高戚唯主要涉及任务的处理速度、系统性能等方面。
D. ORACLE 快速查询数据SQL语句
单条匹配,没有索引也不准备建索引。只能靠并发来加快检索速度,最快的语句应该是:select /*+ full(A) parallel(A,10) */ * from A where b=c;理由有2:full table scan 时,oracle会一次读出多个block加快速度parallel指定并发10线程检索,当然如果允许,你指定20也可以。最好等于CPU个数。 不过还是建议在b列上建索引,这是最好的办法。
E. 请教一个sql使用parallel hint的问题
测试了第一种方式:
设置了index的parallel degree后
在9.2.0.1和9.2.0.8下
select count(1) from xx_test;如果使用这个语句的话,则不会并发(10g后就会并发)
select /*+ parallel(t,4) count(1) from xx_test t;可以并发查询,但是需要在enable parallel query之后可以并行.
在10.2.0.1数据库下
select count(1) from xx_test;
select /*+ parallel(t,4) count(1) from xx_test t;
上面两个都会并行查询,前提都是要enable parallel query.
对于使用parallel_index hint的第二种方法
我在10g中测试没有问题,但是在9i中我使用下面的语句却不会并行
select /*+ parallel_index(xx_test,4) */ count(1) from xx_test;
第三种方法在两个版本中都没有问题
select /*+ parallel(t,4)full(t) */
F. 如何使用SQLloader导入数据
1、打开要导出为oracle的Excel,将Excel文件保存为test.txt文件(文件->另存为)
2、创建SQL*Loader输入数据所需要的文件,均保存到C:,用记事本编辑:
控制文件:input.ctl,内容如下:
load data--1、控制文件标识
infile 'test.txt'
--2、要输入的数据文件名为.txt,注意路径
append intotable Table_Name --3、向oracle表中追加记录
fields terminatedby X'09'
--4、字段终止于X'09',是一个制表符(TAB)
(Col1,Col2…) 定义列对应顺序
a、insert,为缺省方式,在数据装载开始时要求表为空
b、append,在表中追加新记录
c、replace,删除旧记录,替换成新装载的记录
d、truncate,同上
3、在DOS窗口下使用SQL*Loader命令实现数据的输入
C:>sqlldr userid=system/managercontrol=input.ctl
默认日志文件名为:input.log
默认坏记录文件为:input.bad
4、ok,现在就可以查看数据是否导入了。
ORACLESQL
Loader的详细语法
SQL*LOADER是ORACLE的数据加载工具,通常用来将操作系统文件迁移到ORACLE数据库中。SQL*LOADER是大型数据仓库选择使用的加载方法,因为它提供了最快速的途径(DIRECT,PARALLEL)。
要使用SQL*Loader,必须编辑一个控制文件(.ctl),及一个数据文件(.dat)
首先,我们认识一下SQL*LOADER
在windows下,SQL*LOADER的命令为SQLLDR,在UNIX下一般为sqlldr/sqlload。
如执行:d:\oracle>sqlldr
用法: SQLLOAD 关键字=值 [,keyword=value,...]
例如:>sqlldr user/pass
control=控制文件名 log=日志文件名
SQL*LOADER参数列表
参数名称 功能描述
Userid
数据库用户名及口令
Control 控制文件名称,描述数据加载的文件信息
Log 日志文件名称,用于记录数据加载过程的信息
Bad 坏信息文件名称,用于记录不符合要求的数据信息
Data 数据文件名称,记录要加载的原始数据
Discard 丢掉文件名称,记载了不满足条件而被过滤的数据
Discardmax 允许丢掉数据量,默认为全部丢掉
Skip 跳过几个逻辑记录,缺省为0
Load 要加载的记录数,默认为全部加载
Errors 允许出现的错误数,缺省为50
Direct 是否使用直接路径加载数据,默认为false
Readsize 缓冲区大小默认为1048576字节
1、首先创建空表
SQL>create table stu(stunonumber(5),name
varchar(10),addr varchar(20));
数据文件格式分为自由格式和固定格式
固定格式数据文件(mydata.txt)
001 SHUI LIAOHE
002 LIU BEIJING
其控制文件分别如下
#Load.ctl
Load data
Infile mydata.txt
Into table stu
(stuno position(01:03) integer external,
Name position(05:08) varchar,
Addr position(10:16) varchar)
导入数据
>sqlldr test1/test1
control=’d:\load.ctl’log=’d:\load.log’
自由格式数据文件(mydata.txt)
003,”shuics”,”new york”
004,”liujianxin”,”Beijing”
005,”shuiym”,”Canada”
其控制文件如下
#load.ctl
Load data
Infile mydata.txt
Append|insert|replace|truncate
Into table stu
Fields terminated by ‘,’
Optionally enclosed by ‘”’
(stuno,name,addr)
导入数据
将Excel数据加载到oracle数据库
1、将excel文件另存为文本文件(制表符分隔)
2、创建控制文件如下
Load data
Infile ‘book.txt’
Append
Into table stu
Fields terminated by X’09’
(stuno,name,addr)
其中X’09’是一个制表符(TAB)