下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

oracle教程:Informix SQL 常见的实用技巧

作者:oracle教程     来源: www.kokojia.com点击数:1041发布时间: 2015-10-16 11:09:11

标签: oracle教程oracle培训oracle学习视频

本期的Oracle教学内容:一些Informix SQL 的使用技巧,献给广大informix学习者、爱好者参考学习。我们在学习Oracle的时候,也常用到informix的常用SQL语句,今天的Oracle教程学习中我们就讲一些Informix SQL 的使用技巧。
oracle教程:Informix SQL 常见的实用技巧
在开始本节Oracle培训学习之前,我们先了解一下概念性的东西。尽管Informix一直扮演一个小角色,但是随着Unix和SQL在80年代走向流行,但现在我们还是有必要再了解一下这方面的知识的。SQL和早期的Informix产品最显著的区别就在于将数据库存取码分散至一个引擎进程中(sqlexec),而不是将其直接嵌入客户端,这样来为和用户的电脑分离开的数据库服务。好了,废话不多说,我们正式开始学习这方面的技巧吧。
一、提高SELECT COUNT(DISTINCT)的速度
通常“SELECT COUNT(DISTINCT)”这样的操作要花费比较长的时间,如果你这样作:
SELECT UNIQUE xxx INTO TEMP XXX " 然后再"SELECT COUNT(*) FROM TEMP XXX"  
这样通常可以提高几倍的效率。
二、建立一个表结构和永久表完全一致的临时表。
 例如:CREATE TEMP TABLE mytemp (prodno LIKE product.prodno  desc LIKE product.desc)  
你可以使用如下的语句:
SELECT prodno, desc FROM product 
WHERE ROWID = -1 
INSERT INTO TEMP mytemp
三、当遇到sysprocplan表被锁的提示
sysprocplan表是sysmaster库中的一个表,其中记录存储过程经过优化的查询计划。每当查询树中的数据库对象有任何结构上的变化,这个查询计划就会自动更新。如果对查询树中存在的任何表有update statistics操作,也会自动更新查询计划。在查询计划更新的时候,会对sysporcplan表中的相关记录加锁。
注意:每次你对一个表更新统计的时候,也同时会更新于这个表相关的存储过程,即UPDATE STATISTICS FOR PROCEDURE 。
你可以作的另外一件事情就是:在存储过程中使用SET OPTIMIZATION LOW,这会让优化器在存储过程运行的时候不会试图去重新优化它。否则存储过程通常都会被重新优化一次。
四、删除掉表中重复的记录
假设“keycol”字段的值唯一,而且没有对表进行分片,并且没有其它的人正在删除"sometable"中的记录,你可以执行如下的SQL:
delete from sometable as a  where rowid <> (select min(rowid) from sometable where keycol = a.keycol)
如果这个表使用表分片,rowid不存在,你还可以用如下的方法:
BEGIN WORK; 
SELECT DISTINCT * FROM Table INTO TEMP Temp1; 
DELETE FROM Table WHERE 1 = 1; 
INSERT INTO Table SELECT * FROM Temp1; 
COMMIT WORK; 
对于规模较小或中等的表,并且你有足够的存储空间来存储整个的临时表的时候,这种方法通常十分有效。 
五、在shell脚本中使用一个sql查询的结果
以下的是一个运行在sh/ksh下面的脚本。在online中,如果你想要更新一个有许多表的数据库的统计信息。这个脚本不太好。因为这个脚本只能单个处理数据库中的表,而不能同时处理大量的表。 
例子: 
# update_em  
# Run UPDATE STATISTICS on a table by table basis  
#  DATABASE=$1  
if [ -z "$DATABASE" ]  
then  
echo "usage: update_em dbname" >&2  
exit 1  
fi  
isql $DATABASE - < dev/null | isql $DATABASE -  
output to pipe "cat" without headings  
select "update statistics for table ", tabname, ";"  
from systables where tabid >= 100 order by tabname;  
EOF 
exit 0  
也许你已经注意到exit的返回值对不同的isql不是都相同,因此这样作不是很可靠,代替通过$?来检查返回值的更好的主意是将标准错误重定向到一个文件中,然后在这个文件中grep “error"。例如: 
# Generate the data  
isql -qr <<!>stage.rep 2>$stage.err  
database $database;  
select ...  
!  
# Check for errors  
if grep -i "error" $stage.err >/dev/null  
then 
...error_handler...  
fi 
六、在发生错误的时候终止sql脚本的执行
如果你创建了一个sql脚本,并且在Unix命令行中使用以下的方式来执行这个脚本:
$ dbAccess  <脚本文件名> 
这时,脚本中的所有的sql语句都会被执行,即使其中的一个sql语句发生了错误。例如,如果你脚本中为如下的语句: 
BEGIN WORK;  
INSERT INTO history  
SELECT *  
FROM current  
WHERE month = 11;  
DELETE FROM current  
WHERE month = 11;  
COMMIT WORK;  
如果INSERT语句失败了,DELETE语句仍旧会继续执行。直到commit work。这样的后果可能会很严重。你可以通过设置一个环境变量来防止这种情况的发生。 
DBACCNOIGN=1 
七、设置decimal字段运算结果的精度
假定你使用dbaccess或者isql,设置环境变量DBFLTMASK=6 就可以设置为小数点后面6位,比如:
CREATE TEMP TABLE t  
( col_a DECIMAL(8,4) NOT NULL,  
col_b DECIMAL(8,4) NOT NULL,  
col_c DECIMAL(8,4) NOT NULL  
);  
INSERT INTO t VALUES(1.2345, 3.4567, 5.6789);  
SELECT (col_a + col_b) / col_c AS value FROM t;  
value 0.826075  
如果DBFLTMASK=7 
value 0.8260755 
八、对一个计算产生的字段创建视图
应该这样写: 
CREATE VIEW tst (cout) AS  
SELECT ship_charge - totval  
FROM orders WHERE ship_charge > 0; 
九、只select 出数据库中的部分数据(例如10%)
问题:如果你想要得到一个select 语句正常返回的数据的一部分,例如:
SELECT firstname, lastname, city, state  
FROM bigdatabase  
WHERE state = "TX" 
回答: 有一个方法可以返回一个近似值,只需要在where后加上:AND rowid=(trunc(rowid/x)*x)  
其中的x代表你想要返回的总的记录的1/x。需要说明的是,这种方法只能返回一个近似的值,并且表中的数据在物理上分布的连续性。 
十、更改seRIAl类型下一次插入操作产生的值
我们知道serial类型的字段是系统自动增加的整数字段,那么怎样能控制下一个serial类型字段的值。想要下一个插入的serial类型的值比默认值大,可以用: 
ALTER TABLE tabname MODIFY( ser_col_name SERIAL([new_start_number]) 
想要下一个插入的serial类型的值比默认的值要小,首先需要将serial类型重新置为1: 
INSERT INTO table (serial_column) VALUES (2147483647);  
INSERT INTO table (serial_column) VALUES (0); -- 重新从1开始!  
....然后执行ALTER TABLE(就像上面的做法一样)。 
总结:以上便是一些有经验的数据库高手为大家归纳的一些在工作学习中Informix SQL 常见的使用技巧,大家可以参考一下,更多的oracle学习视频可以登录课课家官网查询相关课程了解。

赞(104)
踩(1)
分享到:
华为认证网络工程师 HCIE直播课视频教程