Post Jobs

澳门新葡亰平台游戏根据子表的条件修改主表的数据

有这么一个需求:写一条sql语句,功能是当B表中的字段2值=X的时候,修改A表中的一个字段1=Y,SQL语句如下:

澳门新葡亰平台游戏,要像使用索引提高数据表的访问速度,首先要创建一个索引。

update A表 set A表.字段1 = Y from A表 inner join B表
on A表关联字段=B表关联字段 where B表.字段2=X

创建索引的方式有三种

  • 创建表的时候创建索引
  • 使用create index语句在已经存在的表上创建索引
  • 使用alter table语句在已经存在的表上创建索引

1. 创建表的时候创建索引

 

创建普通索引

在 t1 表中 id 字段上建立索引,SQL语句如下:

create table t1(
    id int,
    name varchar(20),
    score float,
    index(id)
);

创建唯一性索引

创建一个表名为 t2
的表,在表中的id字段上建立索引名为unique_id的唯一性索引,并且按照升序排列,SQL
语句如下:

create table t2(
    id int not null,
    name varchar(20) not null,
    score float,
    unique index unique_id(id asc)
);

创建全文索引

创建一个表名为 t3
的表,在表中的name字段上建立索引名为fulltext_name的全文索引,SQL语句如下:

create table t3(
    id int not null,
    name varchar(20) not null,
    score float,
    fulltext index fulltext_name(name)
) engine=MyISAM;

注:目前只有MyISAM存储引擎支持全文索引,对于经常需要索引的字符串、文字数据等信息,可以考虑存储到MyISAM存储引擎的表中。

创建单列索引

创建一个表名为 t4 的表,在表中的name字段上建立索引名为
single_name的单列索引,SQL语句如下:

create table t4(
    id int not null,
    name varchar(20) not null,
    score float,
    index single_name(name(20))
);

创建多列索引

创建一个表名为 t5
的表,在表中的idname字段上建立索引名为multi的多列索引,SQL语句如下:

create table t5(
    id int not null,
    name varchar(20) not null,
    score float,
    index multi(id,name(20))
);

创建空间索引

创建一个表名为 t6
的表,在空间类型为grometry的字段上创建空间索引,SQL语句如下:

create table t6(
    id int,
    space geometry not null,
    spatial index sp(space)
)engine=myisam;

注:创建空间索引时,所在字段的值不能为空值,并且表的存储引擎为MyISAM

2. 使用create index语句在已经存在的表上创建索引

创建表

create table book(
    bookid int not null,
    bookname varchar(255) not null,
    authors varchar(255) not null,
    info varchar(255) null,
    comment varchar(255) null,
    publicyear year not null
);

创建普通索引

book表中的bookid字段上建立一个名称为index_id的普通索引,SQL语句如下:

create index index_id on book(bookid);

创建唯一性索引

book表中的bookid字段上建立一个名称为uniqueidx的唯一性索引,SQL语句如下所示:

create unique uniqueidx on book(bookid);

发表评论

电子邮件地址不会被公开。 必填项已用*标注

相关文章

网站地图xml地图