免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4164 | 回复: 10
打印 上一主题 下一主题

急急急,索引问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-07-30 15:53 |只看该作者 |倒序浏览
请问各位大侠,SYBASE的一次查询,一张表是否只能用一个索引呢?

论坛徽章:
0
2 [报告]
发表于 2007-07-30 15:56 |只看该作者
可以有很多个索引,但是只能最多有一个聚簇索引

论坛徽章:
0
3 [报告]
发表于 2007-07-30 16:02 |只看该作者

RE:索引

SYBASE 您的意思是说在一次查询中,能使用一张表的多个非聚簇索引是吗?

论坛徽章:
0
4 [报告]
发表于 2007-07-30 16:05 |只看该作者
可能

论坛徽章:
0
5 [报告]
发表于 2007-07-30 16:06 |只看该作者

RE:急急急!

我找了1小时的资料,也没找到确切的文字说,SYBASE里一次查询,对一张表,只能用到一个索引,这一个索引包括聚簇与非聚簇索引的和,是这样的吗?请版主尽快回复我好吗?

论坛徽章:
0
6 [报告]
发表于 2007-07-30 16:21 |只看该作者
关键要看你要达到什么功能,把你的具体的东西写出来。
给你一个例子
比如:一个表有 a(a int,b char(10),c int,d char(10))
index1 a(a,b)   index2 (c,d)
select a,b from a where a=1 and b="hello" union(select c,d from a where c=2 and d="part")

论坛徽章:
0
7 [报告]
发表于 2007-07-30 16:25 |只看该作者

RE:急急急!

这是我们团队的设计思想,要汇报的,因为我看现在的查询计划里都是一个查询,一张表只有一个索引,作为汇报和理论指导,我想版主能否肯定就是这样呢?

论坛徽章:
0
8 [报告]
发表于 2007-07-30 16:31 |只看该作者

RE:急急急!

版主的这个例子会使用两个索引吗?

论坛徽章:
0
9 [报告]
发表于 2007-07-30 16:46 |只看该作者
会QUERY PLAN FOR STATEMENT 1 (at line 1).


    STEP 1
        The type of query is INSERT.
        The update mode is direct.

        FROM TABLE
            a1
        Nested iteration.
        Index : index1
        Forward scan.
        Positioning by key.
        Index contains all needed columns. Base table will not be read.
        Keys are:
            a  ASC
            b  ASC
        Using I/O Size 2 Kbytes for index leaf pages.
        With LRU Buffer Replacement Strategy for index leaf pages.
        TO TABLE
            Worktable1.

    STEP 1
        The type of query is INSERT.
        The update mode is direct.

        FROM TABLE
            a1
        Nested iteration.
        Index : index2
        Forward scan.
        Positioning by key.
        Index contains all needed columns. Base table will not be read.
        Keys are:
            c  ASC
            d  ASC
        Using I/O Size 2 Kbytes for index leaf pages.
        With LRU Buffer Replacement Strategy for index leaf pages.
        TO TABLE
            Worktable1.

    STEP 1
        The type of query is SELECT.
        This step involves sorting.

        FROM TABLE
            Worktable1.
        Using GETSORTED
        Table Scan.
        Forward scan.
        Positioning at start of table.
        Using I/O Size 16 Kbytes for data pages.
        With MRU Buffer Replacement Strategy for data pages.

Total estimated I/O cost for statement 1 (at line 1): 96.

The sort for Worktable1 is done in Serial


a           b
----------- ----------
           1 hello
           2 part

(2 rows affected)

论坛徽章:
0
10 [报告]
发表于 2007-07-30 17:08 |只看该作者

RE:急急急!

真谢谢版主,我看了本机的查询计划,是能用两个索引,刚才我就应该测试一下的,还问您,情急智昏,真谢谢您!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP