`
lkangjin
  • 浏览: 10283 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Informix SQL 地运用灵活技术

阅读更多

一、加快sql的执行速度

1.select 语句中使用sort,或join

如果你有排序和连接操作,你可以先select数据到一个临时表中,然后再对临时表进行处理。因为临时表是建立在内存中,所以比建立在磁盘上表操作要快的多。

如:

SELECT time_records.*, case_name 

FROM time_records, OUTER cases 

WHERE time_records.client = "AA1000" 

AND time_records.case_no = cases.case_no 

ORDER BY time_records.case_no 

这个语句返回34个经过排序的记录,花费了5分钟42秒。而:

SELECT time_records.*, case_name 

FROM time_records, OUTER cases 

WHERE time_records.client = "AA1000" 

AND time_records.case_no = cases.case_no 

INTO temp foo; 

SELECT * from foo ORDER BY case_no 

返回34条记录,只花费了59秒。

2.使用not in 或者not exists 语句



下面的语句看上去没有任何问题,但是可能执行的非常慢:

SELECT code FROM table1 

WHERE code NOT IN ( SELECT code FROM table2 

如果使用下面的方法:

SELECT code, 0 flag 

FROM table1 

INTO TEMP tflag; 

然后:

UPDATE tflag SET flag = 1

WHERE code IN ( SELECT code  FROM table2 

WHERE tflag.code = table2.code ; 

然后:

SELECT * FROM 

tflag 

WHERE flag = 0; 

看上去也许要花费更长的时间,但是你会发现不是这样。

事实上这种方式效率更快。有可能第一种方法也会很快,那是在对相关的每个字段都建立了索引的情况下,但是那显然不是一个好的注意。

3.避免使用过多的“or"

如果有可能的话,尽量避免过多地使用or: WHERE a = "B" OR a = "C" 

要比  WHERE a IN ("B","C")  慢。 有时甚至UNION会比OR要快。

4.使用索引

在所有的join和order by 的字段上建立索引。  在where中的大多数字段建立索引。 

WHERE datecol >= "this/date" AND datecol <= "that/date"  要比  WHERE datecol BETWEEN "this/date" AND "that/date" 慢 

二、在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

三、对一个计算产生的字段创建视图

应该这样写:

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。需要说明的是,这种方法只能返回一个近似的值,并且表中的数据在物理上分布的连续性。

五、创建一个表结构和永久表完全一致的临时表。 例如:CREATE TEMP TABLE mytemp (prodno LIKE product.prodno  desc LIKE product.desc) 

你可以使用如下的语句:

SELECT prodno, desc FROM product 

WHERE ROWID = -1 

INSERT INTO TEMP mytemp

六、更改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(就像上面的做法一样)。 

七、在发生错误的时候终止sql脚本的执行

如果你创建了一个sql脚本,并且在UNIX命令行中使用以下的方式来执行这个脚本:

$ dbaccess <database> <脚本文件名>

这时,脚本中的所有的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 



九、遇到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; 

对于规模较小或中等的表,并且你有足够的存储空间来存储整个的临时表的时候,这种方法通常十分有效。 

十一、加快SELECT COUNT(DISTINCT)的速度

通常“SELECT COUNT(DISTINCT)”这样的操作要花费比较长的时间,如果你这样作:

SELECT UNIQUE xxx INTO TEMP XXX " 然后再"SELECT COUNT(*) FROM TEMP XXX" 

这样通常可以提高几倍的效率。

分享到:
评论

相关推荐

    informix SQL指南

    由于提供的文件信息中,大部分内容是混乱的字符序列和无意义的片段,这些片段...如果需要更深入地了解Informix SQL的具体语法、函数、存储过程、触发器等高级特性,建议查阅IBM Informix官方文档或获取相关的培训资料。

    informix入门和SQL优化

    伴随着数据库的发展,Informix还提供了一系列开发工具,如4GL和ESQL/C等,这些工具为开发者提供了强大的数据库应用开发能力,极大地提升了开发效率和应用程序的性能。 #### 二、数据库管理与系统维护 数据库管理...

    Informix SQL参考指南

    扩展并行服务器特性使得Informix SQL能够高效地处理大数据集,因此它也被广泛应用于数据分析领域,如市场趋势分析、客户行为分析等。 #### 3.3 高可用性解决方案 Informix SQL还提供了一系列高可用性解决方案,包括...

    INFORMIX SQL 开发指南

    根据提供的信息,我们可以推断这份文档是关于IBM Informix SQL的开发指南,主要涉及SQL语言在IBM Informix数据库系统中的应用。尽管文档片段难以直接理解,但我们可以从中提取出一些关键点,并围绕这些点展开详细...

    IBM Informix IDS SQL 指南 参考大全

    根据提供的标题、描述以及部分内文,我们可以了解到这是一份关于IBM Informix IDS SQL的官方中文版指南。...通过学习这份文档,读者可以全面掌握IBM Informix IDS SQL的强大功能,并能够灵活应用于实际项目中。

    informix数据库sql查询优化

    ### Informix数据库SQL查询优化 在数据库管理领域中,SQL查询优化是一项至关重要的技术,它直接影响到系统的响应时间和资源消耗。...在实际应用中,结合具体情况灵活运用这些优化技巧,可以有效提升系统性能。

    Informix SQL语句查询器(v1.0)

    这款工具的界面设计灵感来源于MS-SQL Server查询分析器,用户可以方便地执行SQL查询,并以清晰直观的方式查看结果。 首先,让我们深入了解这款查询器的核心特点——PHP中使用的Informix包裹函数。Informix数据库在...

    informix sql

    在IT领域,数据库管理系统(DBMS)是不可或缺的一部分,而Informix作为一款高效且灵活的DBMS,其SQL(Structured Query Language)应用广泛,为数据存储和检索提供了强大的支持。Informix SQL是Informix数据库系统与...

    informix-sql教程

    在信息技术领域,数据库管理系统的运用是至关重要的,而Informix作为一款高效、灵活且功能强大的关系型数据库管理系统,被广泛应用于各种规模的企业中。SQL(Structured Query Language)是用于管理和操作数据库的...

    Informix SQL参考指南 V9.4.rar

    总的来说,《Informix SQL参考指南 V9.4》是Informix用户不可或缺的工具,它将帮助你理解和掌握Informix SQL的各个方面,从而更好地利用这个强大的数据库系统进行数据管理和应用开发。通过阅读和实践,你将能够充分...

    Informix sql手册.rar

    Informix是一款高效、可靠的数据库系统,广泛应用于各种业务场景,而SQL作为其核心查询语言,对于理解和操作Informix数据库至关重要。 在《Informix SQL手册》中,你可以找到以下关键知识点: 1. **SQL基础**:...

    informix数据库SQL查询语言及应用

    **Informix数据库SQL查询语言及应用** Informix是一款高效、灵活的关系型数据库管理系统,由IBM公司开发并维护。SQL(Structured Query Language)是用于管理关系数据库的标准语言,它在Informix中的应用至关重要,...

    INFORMIX数据库学习资料

    Informix数据库是一款高效且灵活的关系型数据库管理系统,广泛应用于企业级应用,尤其在金融、电信等领域。本学习资料集合包含了Informix数据库操作、SQL语法、编程、性能优化、服务器管理、备份恢复等多个方面的...

    Informix Sql

    - 随着技术的发展,Informix 不断地更新和完善其产品线,以适应不断变化的市场需求和技术趋势。无论是对于初学者还是经验丰富的开发者来说,掌握 Informix 的核心技术和最佳实践都是非常有价值的。

    unix下的INFORMIX SQL语句的使用

    这种嵌入式SQL编程方式能够更加高效地操作数据库,并且具有高度的灵活性。下面我们将详细探讨INFORMIX数据库中的嵌入式SQL语句的独特之处及其使用方法。 #### 一、嵌入式SQL语句概述 嵌入式SQL语句允许程序员直接...

    informix学习使用手册

    这本书详细解释了Informix的核心功能,包括SQL语言的应用,使读者能够有效地管理和操作数据。 一、Informix数据库系统概述 Informix是一种高性能的关系型数据库管理系统(RDBMS),广泛应用于企业级应用中。它的...

    Informix原理及管理技术

    Informix是一款高效、灵活的数据库管理系统,广泛应用于企业级数据存储和处理。以下是该主题下的一些关键知识点: 1. **Informix简介**:Informix是由IBM公司开发的一款关系型数据库管理系统(RDBMS),以其高性能...

    informix嵌入式SQL编程.pdf

    嵌入式SQL(Embedded SQL)是将SQL语句直接嵌入到宿主语言(如C、COBOL等)程序中的编程方式,它使得应用程序可以直接与数据库进行交互,极大地提高了数据处理的效率。 1. **引言** - 本教程适合已经对SQL有一定...

    informix for windows数据库安装配置

    Informix for Windows 数据库安装配置...Informix for Windows 数据库提供了强大且灵活的数据存储和管理功能,适用于多种应用场景。通过本文的介绍,希望读者能够快速入门 Informix for Windows 数据库安装配置过程。

Global site tag (gtag.js) - Google Analytics