首页 > 开发 > 综合 > 正文

SQL循序渐进(18)索引

2024-07-21 02:12:39
字体:
来源:转载
供稿:网友
菜鸟学堂:

索引

索引允许dbms更快地访问数据。系统创建了这个内部地数据结构(即索引),它导致当查询以列为索引的时候搜索行,这样查询会快得多。这个索引对于给定列索引数值的时通知dbms找到表中某一行,这有点象书的索引,它告诉你对于给定的字你能找到哪一页。下面让我们在antiqueowners列中为ownerid创建索引:

create index oid_idx on antiqueowners (ownerid);

下面语句是为名字创建所以:

create index name_idx on antiqueowners (ownerlastname, ownerfirstname);

为了删除索引,你可以利用drop:

drop index oid_idx;

就象前面教程中,我们也可以"drop"(删除)一个表。上面第二个例子中,是在两列上创建索引的。

有些dbms不强迫要求主键,换句话说就是,类的唯一性不会自动强制。这是什么意思呢,好象听起来云里雾里的。好吧,再给你举个例子,如果你象插入另外一行到antiqueowners表中,比如这个ownerid是02,有些系统可以让你这样做即使我们要求所有行的数值都要是不同的。为了避免两行有相同的值,我们有一种方法来克服,就是在列上创建唯一的索引,而在这个列上我们需要它成为主键,这样就可以系统不会出现复制的情况:

create unique index oid_idx on antiqueowners (ownerid);

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表