科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道教你快速掌握Informix SQL的11个使用技巧 (2)

教你快速掌握Informix SQL的11个使用技巧 (2)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

如果有可能的话,尽量避免过多地使用or: WHERE a = "B" OR a = "C" 要比 WHERE a IN ("B","C") 慢。 有时甚至UNION会比OR要快。

作者:ziyi 来源:赛迪网 2007年9月19日

关键字: SQL Informix OEMS MINUS

  • 评论
  • 分享微博
  • 分享邮件
 

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"
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章