mysql的索引在内存中吗,包括数据库中索引的创建SQL语句存储在那个表中?

第六讲 数据库与T-SQL语言

一、关系模型的基本概念

关系数据库以关系模型为基础,它有以下三部分组成:

●数据结构——模型所操作的对象、类型的集合

●完整性规则——保证数据有效、正确的约束条件

●数据操作——对模型对象所允许执行的操作方式

关系(Relation)是一个由行和列组成的二维表格,表中的每一行是一条记录(Record),每一列是记录的一个字段(Field)。表中的每一条记录必须是互斥的,字段的值必须具有原子性。

二、SQL语言概述

SQL(结构化查询语言)是关系数据库语言的一种国际标准,它是一种非过程化的语言。通过编写SQL,我们可以实现对关系数据库的全部操作。

●数据定义语言(DDL)——建立和管理数据库对象

●数据操纵语言(DML)——用来查询与更新数据

●数据控制语言(DCL)——控制数据的安全性

T-SQL语言是Sybase对SQL92标准的一种扩展,主要在它的基础上增加了三个方面的功能:自己的数据类型/特有的SQL函数/流程控制功能

T-SQL中的标识符使用说明:

(1)标识符由1-30个字符或数字构成,但首字符必须为字母。临时表的表名以#开头,长度不能超过13个字符。

(2)数据库对象的标识方法举例

database.owner.tablename.columnname

执行远程存储过程:

EXEC server.db.owner.proc_name

当执行语句在批处理的句首时,EXEC可以省略。

三、Sybase的数据类型

在创建表或声明局部变量时,必须使用Sybase系统预定义类型。

1.字符类型

Char(n) VarChar(n)

2.数值类型

整数类型——Integer SmallInt TinyInt

浮点类型——Real Float Number[P,S] Decimal[P,S]

货币类型——Money SmallMoney

3.日期/时间类型

Datetime SmallDatetime

两者时间部分的精度不同,前者精确到分,后者精确到1/30秒。

4.文本和图像类型

Text Image

5.二进制数据类型

Binary(n) VarBinary(n)

四、数据定义语言

用来定义数据库对象。数据库对象是Sybase用来存储数据的逻辑实体,主要有:

表(Table)、视图(View)、临时表(Temp Table);

主键(Primary Key)、外键(Foreign Key)、索引(Index)、规则(Rule)、默认值(Default);

存储过程(Stored Procedure)、触发器(Trigger)

●基本语法

下面给出创建主要数据库对象的语法:

1.表

创建表的基本语法是:

Create table[database.[owner].]table_name

(column_name datatype [default {constant_expression|user|null}]

{[{identity|null|not null}]|[[constraint constraint_name]

{{unique|primary key}[clustered|nonclustered]

[with{fillfactor|max_rows_per_page}=x]

[on segment_name]

|references[[database.]owner.]ref_table

[(ref_column)]

|check(search_condition)}]}…

在建立大型的数据库时,可以考虑将创建表乃至其它数据库对象的过程写到一个文本里,当数据库系统出现问题时,在最坏的情况下,重建过程可以得到简化,也能比较好的对数据库的建设过程进行监视。

创建表的过程完成下列活动:

·定义表的每一列;

·定义列名和列的数据类型并指定列是否处理空值;

·指定列是否具有IDENTITY属性;

·定义列级的完整性约束和表级的完整性约束

上述过程可见,创建表的过程可以设定填充因子,将列置于段上,设计索引,外键等等。

2.索引

索引对查询性能的影响很大,要引起重视。

索引加速了数据检索,Adaptive Server有三类索引:

·复合索引——索引包含多列;当两列或多列由于它们的逻辑关系而作为整体被查询时可建立这种索引;

·唯一索引——索引列的值不允许重复;

·簇聚索引和非簇聚索引——簇聚索引强迫Server不断地对表中数据排序或重排序以保证表中数据的物理顺序和逻辑顺序的一致性,簇聚索引对范围查询性能影响极大;非簇索引没有这样的要求,非簇聚索引对修改操作有利。

何时建索引?

·如果手动插入identity列,则创建唯一索引以保证不插入已经存在的值;

·经常被排序访问的列,即被列在order by子句中的列,最好对其建立索引以便Adaptive Server能充分利用索引顺序的优点;

·如果列经常用手连接,则可对列建立索引,这样系统能更快地执行连接;

·包含主键的列一般都有簇聚索引,尤其是当它频繁地和其它表的列相关联;

·经常被范围查询的列最好为其建立簇聚索引,一旦查询范围内的第一个值被发现,则随后的值在物理上一定相近。簇聚索引对单值查询并没有什么优点。

创建索引的基本语法:

Create [unique][clustered|nonclustered]index index_name

On [[database.]owner.]table_name

(column_name[,column_name]…)

[on segment_name][with consumers=x]

上述语法包含了这样的暗示:将簇聚索引和它的基表分离在不同的段上;段是逻辑概念,但段可以位于不同的物理设备上,也即将簇聚索引和基表物理上分开。 这是不允许的,我们将在后面讨论设备、数据库、段、表分区时作详细讨论。

3.键(key)

理解键是理解关联的关键。

键和索引往往是一回事。键的意义在概念上,键用于参照完整性约束。

主键是表的单值列的集合,主键通过在放置它们的表上创建一个单值索引来实现其单值性的。实际上主键是作为标志表的标志符而存在的,一旦主键确定,则由该主键就确定了的表也就确定了。

外键是和其它表中的主键相关的列,主键和外键的关系确定了外键的值域,该值域即为相应主键的取值范围。这样就从理论上强制实现了表与表之间的参照完整性。

前面创建表的语法里包含了创建键的成分。也可以通过其它途径创建主键和外键。

◇Unique约束和Primary key约束的区别

Unique约束和Primary key约束用来保证同一表中指定的列上没有重复值,这两个约束都产生唯一索引确保数据一致性,默认情况下,Unique约束产生唯一的非聚集索引,Primary key约束产生唯一的聚集索引。Primary key约束比Unique约束严格:Primary key列不允许有空值,Unique列允许有空值。

4.视图

视图是查看多表中数据的方法,视图从基表派生,它并非物理存在,而是逻辑表;视图也系统提供管理表的一种安全机制。视图使得用户集中精力在感兴趣的数据集上。

创建视图的语法:

create view [[database.]owner.]view_name

[(column_name[,column_name]…)]

as select [distinct] select_statement

[with check option]

有distinct关键字的视图不能更新。当视图涉及关联时,定义视图要小心,这时是对多表操作,完整性显得很重要。

五、数据操纵语言

1.Select语句

基本语法:

SELECT[all|distinct]字段列表

[into表名]

[from表名]

[where条件表达式]

[group by [all]字段列表]

[having筛选表达式]

[order by 字段列表[asc|desc]]

[compute聚集函数列表[by字段列表]]

注意:Select语句中的子句必须按照上述顺序使用。也就是说,若该语句包括一个group by子句和一个order by子句where,group by子句必须放在order by子句之前。

Having子句类似于where子句,不同之处有两点:(1)Having子句必须结合group by子句使用;(2)where子句不能用聚集函数,而Having子句可以。

下面通过实例来对Select的通常用法加以介绍。

例1:选择所有的列,语法为select * from table_list

如:select * from publishers

例2:选择指定的列,语法为

select column_name[,column_name]…

from table_name

如:select pub_id,pub_name from publishers

例3:重命名查询结果中的列,语法为

select column_heading= column_name

from table_name

如:select Publisher=pub_name,pub_id

from publishers

例4:select列表中的计算值,可以对select列表中的数值数据进行计算,下面列出了算术运算符。

符号运算

+加

-减

/除

*乘

%取模

如select title_id,total_sales,total_sales*2 from titles

例5:使用distinct消除重复的查询结果

可选的关键词消除select语句的结果中的重复行。若不指定distinct,缺省值为all,将检索出包含重复行的所有行数据。

如:select distinct au_id from titleauthor

例6:选择行——where语句

select语句中的确切指定要检索哪些行的准则,其一般格式为:

select select_list from table_list where search_conditions

where子句中的搜索条件(或称限制)包括:

·比较运算符(=,<,>,!=等=

如:where advance*2>total_sales*price

·范围(between和not between)

如:where total_sales between 5000 and 10000

·列表(in和not in)

如:where state in(“CA”,”IN”,”MD”)

·匹配字符(like和not like)

如:where phone like “0535%”

·未知值(is null和is not null)

如:where advance is null

·以上各项的组合(and, or)

如:where advance<5000 or total_sales between 500 and 1000

取消

评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值