首页 > 数据库 >SQL CREATE INDEX 语句- 提高数据库检索效率的关键步骤

SQL CREATE INDEX 语句- 提高数据库检索效率的关键步骤

时间:2023-12-07 20:33:58浏览次数:42  
标签:关键步骤 INDEX Personid CREATE Persons SQL 语句

SQL CREATE INDEX 语句

SQL CREATE INDEX 语句用于在表中创建索引。

索引用于比其他方式更快地从数据库中检索数据。用户无法看到索引,它们只是用于加速搜索/查询。

注意: 使用索引更新表比不使用索引更新表需要更多的时间(因为索引也需要更新)。因此,只在经常进行搜索的列上创建索引。

CREATE INDEX 语法

在表上创建索引。允许重复值:

CREATE INDEX index_name
ON table_name (column1, column2, ...);

创建唯一索引的语法如下:

CREATE UNIQUE INDEX index_name
ON table_name (column1, column2, ...);

注意: 创建索引的语法在不同的数据库中有所不同。因此,请检查您的数据库中创建索引的语法。

CREATE INDEX 示例

下面的 SQL 语句在 "Persons" 表的 "LastName" 列上创建一个名为 "idx_lastname" 的索引:

CREATE INDEX idx_lastname
ON Persons (LastName);

如果要在多列的组合上创建索引,可以在括号内列出列名,用逗号分隔:

CREATE INDEX idx_pname
ON Persons (LastName, FirstName);

DROP INDEX 语句

DROP INDEX 语句用于删除表中的索引。

MS Access:

DROP INDEX index_name ON table_name;

SQL Server:

DROP INDEX table_name.index_name;

DB2/Oracle:

DROP INDEX index_name;

MySQL:

ALTER TABLE table_name
DROP INDEX index_name;

通过这些 SQL 语句,您可以在数据库中创建索引,提高数据检索的效率。如果索引不再需要,也可以使用 DROP INDEX 语句将其删除。

SQL AUTO INCREMENT字段

AUTO INCREMENT 允许在将新记录插入表时自动生成唯一编号。通常,这是我们希望每次插入新记录时自动创建的主键字段。

MySQL 语法

以下 SQL 语句在 "Persons" 表中定义了 "Personid" 列为自动递增主键字段:

CREATE TABLE Persons (
    Personid int NOT NULL AUTO_INCREMENT,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int,
    PRIMARY KEY (Personid)
);

MySQL 使用 AUTO_INCREMENT 关键字来执行自动递增功能。默认情况下,AUTO_INCREMENT 的起始值为 1,每插入一条新记录它就会递增 1。

要让 AUTO_INCREMENT 序列从另一个值开始,请使用以下 SQL 语句:

ALTER TABLE Persons AUTO_INCREMENT=100;

要将新记录插入 "Persons" 表中,我们将无需为 "Personid" 列指定值(将自动添加唯一值):

INSERT INTO Persons (FirstName, LastName)
VALUES ('Lars', 'Monsen');

上面的 SQL 语句将在 "Persons" 表中插入一条新记录。 "Personid" 列将被分配一个唯一值。 "FirstName" 列将设置为 "Lars",而 "LastName" 列将设置为 "Monsen"。

SQL Server 语法

以下 SQL 语句在 "Persons" 表中定义了 "Personid" 列为自动递增主键字段:

CREATE TABLE Persons (
    Personid int IDENTITY(1,1) PRIMARY KEY,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int
);

MS SQL Server 使用 IDENTITY 关键字执行自动递增功能。在上面的示例中,IDENTITY 的起始值为 1,每插入一条新记录它就会递增 1。

提示: 要指定 "Personid" 列应从值 10 开始递增 5,请将其更改为 IDENTITY(10,5)

要将新记录插入 "Persons" 表中,我们将无需为 "Personid" 列指定值(将自动添加唯一值):

INSERT INTO Persons (FirstName, LastName)
VALUES ('Lars', 'Monsen');

上面的 SQL 语句将在 "Persons" 表中插入一条新记录。 "Personid" 列将被分配一个唯一值。 "FirstName" 列将设置为 "Lars",而 "LastName" 列将设置为 "Monsen"。

Access 语法

以下 SQL 语句在 "Persons" 表中定义了 "Personid" 列为自动递增主键字段:

CREATE TABLE Persons (
    Personid AUTOINCREMENT PRIMARY KEY,
    LastName varchar(255) NOT NULL,
    FirstName varchar(255),
    Age int
);

MS Access 使用 AUTOINCREMENT 关键字执行自动递增功能。默认情况下,AUTOINCREMENT 的起始值为 1,每插入一条新记录它就会递增 1。

提示: 要指定 "Personid" 列应从值 10 开始递增 5,请将 AUTOINCREMENT 更改为 AUTOINCREMENT(10,5)

要将新记录插入 "Persons" 表中,我们将无需为 "Personid" 列指定值(将自动添加唯一值):

INSERT INTO Persons (FirstName, LastName)
VALUES ('Lars', 'Monsen');

上面的 SQL 语句将在 "Persons" 表中插入一条新记录。 "Personid" 列将被分配一个唯一值。 "FirstName" 列将设置为 "Lars",而 "LastName" 列将设置为 "Monsen"。

Oracle 语法

在 Oracle 中,代码会复杂一些。您将不得不使用序列对象,此对象生成一个数字序列,来创建一个自动递增字段。

使用以下 CREATE SEQUENCE 语法:

CREATE SEQUENCE seq_person
MINVALUE 1
START WITH 1
INCREMENT BY 1
CACHE 10;

上面的代码创建了一个名为 seq_person 的序列对象,从 1 开始递增 1。 它还将缓存最多 10 个值以提高性能。 缓存选项指定了将存储在内存中以加快访问速度的多少个序列值。

要将新记录插入 "Persons" 表中,我们必须使用 nextval 函数,此函数从 seq_person 序列检索下一个值:

INSERT INTO Persons (Personid, FirstName, LastName)
VALUES (seq_person.nextval, 'Lars', 'Monsen');

上面的 SQL 语句将在 "Persons" 表中插入一条新记录。 "Personid" 列将被分配 seq_person 序列的下一个数字。 "FirstName" 列

最后

为了方便其他设备和平台的小伙伴观看往期文章:

微信公众号搜索:Let us Coding,关注后即可获取最新文章推送

看完如果觉得有帮助,欢迎 点赞、收藏、关注

标签:关键步骤,INDEX,Personid,CREATE,Persons,SQL,语句
From: https://www.cnblogs.com/xiaowange/p/17883884.html

相关文章

  • selenium.common.exceptions.SessionNotCreatedException: Message: session not crea
    pyhon调selenium报:selenium.common.exceptions.SessionNotCreatedException:Message:sessionnotcreated:ThisversionofChromeDriveronlysupportsChromeversion103Currentbrowserversionis120.0.xxx.0withbinarypathC:\ProgramFiles\Google\Chrome\......
  • pip:Unable to create process using ‘“‘错误
    学习自:完美解决:执行pip时Unabletocreateprocessusing‘“‘错误(详细流程)-CSDN博客1、背景1)在一台新电脑上安装了python3.6;2)将python3.6和python3.6的Scripts目录都加入到了环境变量中;3)cmd命令行中输入python3可以顺利进入Python控制台;4)输入pip3报错Unabletocreatepro......
  • 应用报错:java.lang.OutOfMemoryError: unable to create new native thread
    上个月生产环境忽然出现部分交易处理缓慢甚至超时,查看对应应用日志发现一直在刷报错日志,报错信息如下java.lang.OutOfMemoryError:unabletocreatenewnativethread从报错上来看是说不能创建本地线程了,应用都是容器部署的,开始我怀疑是容器内存不够了导致内存泄露,但经过查看容器......
  • OpenCV4.1.0与CUDAcuda_10.1.105联合进行图像特征点提取和特征匹配时,运行程序时错误提
    问题描述:OpenCV4.1.0与CUDAcuda_10.1.105联合进行图像特征点提取和特征匹配时,运行程序时错误提示:无法定位程序输入点?createBFMatchercv@DescriptorMatcher@cuda@cv......于动态链接库......,如下图所示:解决办法:如果include、lib和dll的路径都配置正确的话,可以尝试将编译好的带......
  • 98、swift--- tableView.dequeueReusableCell(withIdentifier: cellID, for: indexPat
    作用:复用cell.可以用标识符从表视图中获得可重用单元格.for:indexPath通过指定单元格位置获得可重用单元格,不需要判断.用于dequeue(出队)一个可复用的cell,用于在UITableView或UICollectionView中显示。这个方法接收两个参数:withIdentifier:一个字符串,表示要dequeue的......
  • pandas concat 左右拼接 ignore_index 容易误以为是忽略index 其实是忽略列名
    pandasconcat左右拼接ignore_index容易误以为是忽略index其实是忽略列名`pandas.concat`函数的`ignore_index`参数是一个布尔值,用于控制是否在拼接轴上使用索引值¹²。如果`ignore_index=True`,则不会使用拼接轴上的索引值,结果轴将被标记为0,…,n-1¹²。这在你拼接......
  • hive启动出现Either your MetaData is incorrect, or you need to enable "datanucleu
    hive启动出现:Requiredtablemissing:"`VERSION`"inCatalog""Schema"".DataNucleusrequiresthistabletoperformitspersistenceoperations.EitheryourMetaDataisincorrect,oryouneedtoenable"datanucleus.schema......
  • ElasticSearch之Index stats API
    获取指定索引的统计数据。获取指定索引的全部统计数据,命令样例如下:curl-XGET"https://localhost:9200/testindex_001/_stats?pretty"--cacert$ES_HOME/config/certs/http_ca.crt-u"elastic:ohCxPH=QBE+s5=*lo7F9"执行结果的样例,如下:{"_shards":{"total&q......
  • ElasticSearch之Get index settings API
    获取指定索引的参数的值。获取指定索引的全部参数,命令样例如下:curl-XGET"https://localhost:9200/testindex_002/_settings?pretty"--cacert$ES_HOME/config/certs/http_ca.crt-u"elastic:ohCxPH=QBE+s5=*lo7F9"执行结果的样例,如下:{"testindex_002":{"......
  • ElasticSearch之Get index API
    获取指定索引的基本信息。命令样例如下:curl-XGET"https://localhost:9200/testindex_001?pretty"--cacert$ES_HOME/config/certs/http_ca.crt-u"elastic:ohCxPH=QBE+s5=*lo7F9"执行结果的样例,如下:{"testindex_002":{"aliases":{},......