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

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,关注后即可获取最新文章推送

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/205507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据科学:Matplotlib、Seaborn笔记

数据科学:Numpy、Pandas 数据科学:Matplotlib、Seaborn笔记 数据科学:Numpy、Pandas、Matplotlib、Seaborn、Scipy、Scikit-Learn 三、Matplotlib1.Matplotlib subplots函数2.tight_layout()函数3.Matplotlib grid()设置网格格式4.fill_bet…

<蓝桥杯软件赛>零基础备赛20周--第9周--前缀和与差分

报名明年4月蓝桥杯软件赛的同学们,如果你是大一零基础,目前懵懂中,不知该怎么办,可以看看本博客系列:备赛20周合集 20周的完整安排请点击:20周计划 每周发1个博客,共20周(读者可以按…

大屏可视化基础学习-通用可套用模板【大屏可视化项目案例-15】

🎉🎊🎉 你的技术旅程将在这里启航! 🚀🚀 本专栏包括但不限于大屏可视化、图表可视化等等。订阅专栏用户在文章底部可下载对应案例源码以供大家深入的学习研究。 🎓 每一个案例都会提供完整代码和详细的讲解,不论你是初学者还是资深开发者,这里都有适合你的内容。…

从零开始的c语言日记day41——自定义类型结构体

一、结构体的声明 1.1结构的基础知识 结构是一些值的集合,这些值称为成员变量。结构的每个成员可以是不同类型的变量。 Tag结构体标签 Member-list成员列表-里面可以有很多成员 Variable-list变量列表 结构体类型的定义方式 S1,s2是struct stu类型的…

黑苹果之显卡篇

一、什么是显卡 显卡GPU(Video card、Display card、Graphics card、Video adapter)是个人计算机基础的组成部分之一,将计算机系统需要的显示信息进行转换驱动显示器,并向显示器提供逐行或隔行扫描信号,控制显示器的正…

python数据分析

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 pandas统计分析基础实训 实训1 读取并查看某地区房屋销售数据的基本信息1. 训练要点2. 需求说明3.实现思路及步骤 实训2 提取房屋售出时间信息并描述房屋价格信息1. 训练要点…

数据结构 图的广度优先搜索和深度优先搜索

一、广度优先搜索 广度优先搜索等价于树的层次遍历,将起点的每一层进行遍历 当这一层结点全部被遍历完时,再遍历下一层次,从图中可以根据距离遍历起点的长度进行层次选择 例: 以a结点作为开始结点 a的下一层次有b c e三个结点 所以…

nginx 一键切换停机维护页面 —— 筑梦之路

背景说明 进行停机维护或者系统升级等操作,会影响到用户使用,如果停机维护期间用户未看到停机维护的通知,仍去访问系统,会提示默认不太友好的访问错误界面 ,这时如果在维护的时候直接展示停机公告的具体信息&#xff0…

Spark Structured Streaming使用教程

文章目录 1、输入数据源2、输出模式3、sink输出结果4、时间窗口4.1、时间窗口4.2、时间水印(Watermarking) 5、使用例子 Structured Streaming是一个基于Spark SQL引擎的可扩展和容错流处理引擎,Spark SQL引擎将负责增量和连续地运行它&#…

Spring Security 自定义异常失效?从源码分析到解决方案

🚀 作者主页: 有来技术 🔥 开源项目: youlai-mall 🍃 vue3-element-admin 🍃 youlai-boot 🌺 仓库主页: Gitee 💫 Github 💫 GitCode 💖 欢迎点赞…

JAVA 企业面试题

JAVA 企业面试题 面试题集 面试题集共分为以下十部分: 一、 Core Java: 1 — 95 题 1 — 24 页 基础及语法: 1 — 61 题 1 — 13 页 异常: 62 — 69 题 13 — 15 页 集合: 70 — 80 题 15 — 18 页 线程&#xff1a…

使用阿里巴巴同步工具DataX实现Mysql与ElasticSearch(ES)数据同步

一、Linux环境要求 二、准备工作 2.1 Linux安装jdk 2.2 linux安装python 2.3 下载DataX: 三、DataX压缩包导入,解压缩 四、编写同步Job 五、执行Job 六、定时更新 6.1 创建定时任务 6.2 提交定时任务 6.3 查看定时任务 七、增量更新思路 一、Linux环境要…

微信小程序js数组对象根据某个字段排序

一、排序栗子 注: 属性字段需要进行转换,如String类型或者Number类型 //升序排序 首元素(element1)在前 降序则(element1)元素在后 data data.sort((element1, element2) >element1.属性 - element2.属性 ); 二、代码 Page({/*** 页面的初始数据*/data: {user:…

每日一练 | 华为认证真题练习Day144

1、DHCPv6无状态自动分配方案中,主机不需要发送任何DHCPv6报文。 A. 对 B. 错 2、IPv4最后一个选项字段(option)是可变长的可选信息,该字段最大长度为? A. 40B B. 20B C. 60B D. 10B 3、关于ARP协议的作用和报文…

SpringSecurity安全授权

目录 前言 正文 1.基本流程 2.基本用法 3.配置项 4.HttpSecurity 方式和内存认证方式 5.认证流程 6.基于数据库查询的登录验证 7.多种角色权限认证 8.自定义权限认证 总结 前言 安全对于任何系统来说都是非常重要的,权限的分配和管理一直都是开发者需…

C语言——输出菱形

法一&#xff1a; #include<stdio.h> #define N 7 //假设输出7层菱形 int main(){int i;//i控制第几行 int j;//j控制每一行空格的循环个数 int k;//k控制每一行*的循环次数 for(i1;i<4;i){//将图形分为两部分,前四行(第一部分) for(j1;j<4-i;j){//输出第i行的…

echarts双折线图

引用 //反应时长 durationCharts categoryCommonChart(studyBehavior.durationCharts, durationCharts) function categoryCommonChart(odata, dom){var myChart echarts.init(document.getElementById(dom));let oarr []oarr odata.series.map(function(item){let color…

随笔-这都是命吗

我与鹏哥、小付有个小群&#xff0c;前几天&#xff0c;鹏哥在群里发了一个图&#xff0c;是他那个城市准备扶持的高新产业&#xff0c;有元宇宙、量子信息、生物制药、人工智能什么的。 先前的时候鹏哥给我说过&#xff0c;当地准备了六百多亩地&#xff0c;准备发展高新产业…

Linux-进程之间的通信

目录 ​编辑 一.什么是进程之间的通信 二.进程之间的通信所访问的数据 三.进程之间的通信是如何做到的 四.基于内存文件级别的通信方式——管道 1.什么是管道 2.管道的建立过程——匿名管道 a.什么是匿名管道 b.匿名管道特点&#xff1a; c.使用匿名管道的…

风格迁移网络修改流程(自用版)

一. AdaAttN-Revisit Attention Mechanism in Arbitrary Neural Style Transfer&#xff08;ICCV2021&#xff09; 下载vgg_normalised.pth打开visdom python -m visdom.server在 train_adaattn.sh 中配置 content_path、style_path 和 image_encoder_path&#xff0c;分别表…