• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql目录与视图

mysql 搞代码 7年前 (2018-06-06) 136次浏览 已收录 0个评论

mysql索引与视图


原始表student字段:

mysql> select column_name,data_type     -> from information_schema.columns     -> where table_name = 'student'; +-------------+-----------+ | column_name | data_type | +-------------+-----------+ | stu_id      | int       | | stu_name    | varchar   | | stu_tel     | int       | | stu_score   | int       | +-------------+-----------+ 4 rows in set (0.01 sec)

欢迎大家阅读《mysql目录与视图》,跪求各位点评,by 搞代码

表中原始数据:

mysql> select * from student; +--------+----------+---------+-----------+ | stu_id | stu_name | stu_tel | stu_score | +--------+----------+---------+-----------+ |      1 | a        |     151 |        60 | |      2 | b        |     152 |        61 | |      3 | c        |     153 |        62 | |      4 | d        |     154 |        63 | +--------+----------+---------+-----------+ 4 rows in set (0.00 sec)


索引创建格式:

create [ <index type> ] index <index name> [ using {btree | hash} ] on table specification ( <column in index> [,<column in index> ] ) <index type> := unique | fulltext | spatial <column in index>:=<column name> [asc | desc] 

创建一个最简单的索引:

mysql> create index stu_index      -> on student(stu_id); Query OK, 0 rows affected (0.36 sec) Records: 0  Duplicates: 0  Warnings: 0

这里创建立一个非唯一性的索引,其中默认使用asc升序排列。

如果没有指定using声明的话,mysql自动创建一个B树。所以上面的索引其实是这样子的:

mysql> create index stu_index using btree      -> on student(stu_id asc); Query OK, 0 rows affected (0.19 sec) Records: 0  Duplicates: 0  Warnings: 0

当然,btree索引可以换成哈希索引。

也可以为多个列创建唯一的索引:

mysql> create unique index stu_index using hash      -> on student(stu_id,stu_name); Query OK, 0 rows affected (0.19 sec) Records: 0  Duplicates: 0  Warnings: 0

添加索引:

mysql> alter table student     -> add unique index stu_index2     -> using hash (stu_tel); Query OK, 0 rows affected (0.36 sec) Records: 0  Duplicates: 0  Warnings: 0

删除索引:

mysql> drop index stu_index on student; Query OK, 0 rows affected (0.22 sec) Records: 0  Duplicates: 0  Warnings: 0

创建表时定义索引:

mysql> create table student(     -> stu_id          int primary key,     -> stu_name        varchar(5) not null,     -> stu_tel         int(5) unique,     -> stu_score       int(2),     -> index stu_index(stu_id)     -> );

只需在表的最后添加创建索引的语句即可。

视图是数据库中的虚拟表,它存储的不是自己的内容,而是经过select从其他表整合而来的。当其他表的内容改变是,视图内的内容跟着改变。在一定条件下,对视图的更新也将改变源表。

创建视图:

create [ or replace ] view <view name> [<column list>] as <table expression> [with [ cascaded |local ] check option ] mysql> create view view1 as     -> (select * from student); Query OK, 0 rows affected (0.16 sec) 
mysql> select * from view1; +--------+----------+---------+-----------+ | stu_id | stu_name | stu_tel | stu_score | +--------+----------+---------+-----------+ |      1 | a        |     151 |        60 | |      2 | b        |     152 |        61 | |      3 | c        |     153 |        62 | |      4 | d        |     154 |        63 | +--------+----------+---------+-----------+ 4 rows in set (0.00 sec)

创建视图时,如果视图已存在,可用replace重新覆盖创建。

创建视图时还可以更改原始列名。

mysql> create or replace view view1(id,name,tel,score) as     -> (select * from student); Query OK, 0 rows affected (0.03 sec)
mysql> select * from view1; +----+------+------+-------+ | id | name | tel  | score | +----+------+------+-------+ |  1 | a    |  151 |    60 | |  2 | b    |  152 |    61 | |  3 | c    |  153 |    62 | |  4 | d    |  154 |    63 | +----+------+------+-------+ 4 rows in set (0.00 sec)

当一个视图可以更新时,就能够使用[with [ cascaded |local ] check option ]选项对更新对有效检查。

删除视图:

drop view view1;




搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql目录与视图

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址