MySql 知识大汇总

数据库索引

数据库索引是一种数据结构,用于提高数据库查询的速度和效率。索引可以看作是表中一列或多列的值的快速查找方式,类似于书籍的目录。通过创建索引,可以减少数据库的扫描量,加快数据的检索速度。

常见的索引类型

常见的索引类型包括:

  1. B-Tree索引:B-Tree(平衡树)是一种常见的索引结构,适用于范围查询和精确查找。它能够快速定位到满足条件的数据块,然后在块内进行查找。B-Tree索引适用于大部分查询场景,是最常用的索引类型。

  2. 哈希索引:哈希索引使用哈希函数将索引值映射到一个哈希表中的槽位,然后在槽位中查找数据。哈希索引适用于等值查询,但不适用于范围查询和排序操作。

  3. 全文索引:全文索引用于在文本数据中进行全文搜索。它可以快速定位到包含指定关键词的文档或记录。

  4. 空间索引:空间索引用于存储和查询空间数据,如地理位置信息。它可以支持空间关系查询,如距离查询、相交查询等。

创建索引时,需要选择合适的列作为索引列,并根据实际情况选择合适的索引类型。一般来说,主键列和经常用于查询的列是常见的索引列选择。但是,过多或不合理的索引可能会导致性能下降,因此需要根据实际情况进行性能测试和调优。

在使用索引时,可以在查询语句中使用关键字来优化查询性能,如WHERE子句中使用等值条件、前缀匹配条件,ORDER BY子句中使用索引列等。

需要注意的是,索引并非万能的,对于小型表或者频繁更新的表,索引的维护成本可能大于查询的性能提升。因此,在创建索引时需要谨慎选择索引列,并根据实际情况进行性能测试和调优。

索引的分类

  1. 唯一索引(UNIQUE INDEX):索引列的值必须唯一,用于加速对唯一值的查询。可以用于主键和唯一约束。
CREATE UNIQUE INDEX index_name ON table_name (column_name);
  1. 主键索引(PRIMARY KEY):主键是一种特殊的唯一索引,用于唯一标识表中的每一行。一个表只能有一个主键。
ALTER TABLE table_name ADD PRIMARY KEY (column_name);
  1. 外键索引(FOREIGN KEY):外键是关联两个表的字段,可以用于加速关联查询。
ALTER TABLE table_name ADD FOREIGN KEY (column_name) REFERENCES other_table (other_column);
  1. 聚簇索引(CLUSTERED INDEX):聚簇索引按照索引列的顺序对表中的数据进行物理排序。一个表只能有一个聚簇索引。
CREATE CLUSTERED INDEX index_name ON table_name (column_name);
  1. 非聚簇索引(NONCLUSTERED INDEX):非聚簇索引在索引列上创建一个独立的数据结构,用于加速对索引列的查询。
CREATE NONCLUSTERED INDEX index_name ON table_name (column_name);
  1. 全文索引(FULLTEXT INDEX):全文索引用于在文本数据中进行全文搜索。
CREATE FULLTEXT INDEX index_name ON table_name (column_name);
  1. 空间索引(SPATIAL INDEX):空间索引用于存储和查询空间数据,如地理位置信息。
CREATE SPATIAL INDEX index_name ON table_name (column_name);

需要根据实际需求选择合适的索引类型,并根据查询场景进行性能测试和调优。请注意,在创建索引时,需要考虑索引的维护成本和对写操作的影响。

mysql 常用的一些函数

以下是一些常用的MySQL函数及其对应的SQL语句示例:

  1. 字符串函数:
  • CONCAT():将多个字符串连接在一起。
SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM employees;
  • SUBSTRING():截取字符串的一部分。
SELECT SUBSTRING(description, 1, 10) AS short_desc FROM products;
  • LENGTH():返回字符串的长度。
SELECT LENGTH(email) AS email_length FROM customers;
  • UPPER():将字符串转换为大写。
SELECT UPPER(last_name) AS last_name_upper FROM employees;
  • LOWER():将字符串转换为小写。
SELECT LOWER(first_name) AS first_name_lower FROM employees;
  • REPLACE():替换字符串中的某个子串。
SELECT REPLACE(description, 'old_value', 'new_value') AS new_description FROM products;
  1. 数值函数:
  • ROUND():对数值进行四舍五入。
SELECT ROUND(price, 2) AS rounded_price FROM products;
  • CEIL():向上取整。
SELECT CEIL(quantity) AS rounded_quantity FROM inventory;
  • FLOOR():向下取整。
SELECT FLOOR(total_amount) AS rounded_amount FROM orders;
  • ABS():返回数值的绝对值。
SELECT ABS(balance) AS absolute_balance FROM accounts;
  • MOD():返回两个数值相除的余数。
SELECT MOD(quantity, 2) AS remainder FROM inventory;
  1. 日期和时间函数:
  • NOW():返回当前日期和时间。
SELECT NOW() AS current_datetime;
  • CURDATE():返回当前日期。
SELECT CURDATE() AS current_date;
  • CURTIME():返回当前时间。
SELECT CURTIME() AS current_time;
  • DATE_FORMAT():将日期格式化为指定的格式。
SELECT DATE_FORMAT(order_date, '%Y-%m-%d') AS formatted_date FROM orders;
  • DATE_ADD():在日期上添加指定的时间间隔。
SELECT DATE_ADD(order_date, INTERVAL 7 DAY) AS new_date FROM orders;
  1. 聚合函数:
  • COUNT():计算行数。
SELECT COUNT(*) AS total_rows FROM customers;
  • SUM():计算总和。
SELECT SUM(quantity) AS total_quantity FROM orders;
  • AVG():计算平均值。
SELECT AVG(price) AS average_price FROM products;
  • MAX():找出最大值。
SELECT MAX(salary) AS max_salary FROM employees;
  • MIN():找出最小值。
SELECT MIN(age) AS min_age FROM employees;
  1. 条件函数:
  • IF():根据条件返回不同的值。
SELECT IF(quantity > 0, 'In Stock', 'Out of Stock') AS stock_status FROM products;
  • CASE WHEN…THEN…ELSE…END:多条件判断。
SELECTCASEWHEN grade >= 90 THEN 'A'WHEN grade >= 80 THEN 'B'WHEN grade >= 70 THEN 'C'ELSE 'F'END AS letter_grade
FROM students;

这些示例SQL语句演示了如何使用常用的MySQL函数来处理和操作数据。您可以根据自己的需求进行调整和扩展。

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

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

相关文章

Linux进程调度

初探Linux进程调度 已知:父进程创建子进程后,父子进程同时运行。 问题:如果计算机只有一个处理器,父子进程以什么方式同时执行? 基本概念 运行:一个可执行程序从文件,变成进程的过程。 执行…

MySQL碎片清理

为什么产生? 经过大量增删改的表,都可能存在碎片 MySQL数据结构是B树, 删除某一记录,只会标记为删除,后续插入一条该区间的记录,就会复用这个位置。 删除整个数据页的记录,则整个页标记为“可…

微软对Visual Studio 17.7 Preview 4进行版本更新,新插件管理器亮相

近期微软发布了Visual Studio 17.7 Preview 4版本,而在这个版本当中,全新设计的扩展插件管理器将亮相,并且可以让用户可更简单地安装和管理扩展插件。 据了解,目前用户可以从 Visual Studio Marketplace 下载各式各样的 VS 扩展插…

常用的CSS渐变样式

边框渐变 方案1: 边框渐变( 支持圆角) width: 726px;height: 144px;border-radius: 24px;border: 5px solid transparent;background-clip: padding-box, border-box; background-origin: padding-box, border-box; background-image: linear-gradient(to right, #f…

linux/drivers/leds/leds-gpio.c学习

linux/drivers/leds/leds-gpio.c学习 linux/drivers/leds/leds-gpio.c 是 Linux 内核中的一个驱动程序文件&#xff0c;用于控制 GPIO 引脚上的 LED 灯。下面是对该文件的更详细解读&#xff1a; 1. 头文件引入&#xff1a;该文件引入了一些必要的头文件&#xff0c;包括 <…

Kotlin Multiplatform 使用 CocoaPods 创建多平台分发库

Kotlin Multiplatform 支持直接创建Framework 方式和使用CocoaPods 方式创建Framework。 1、不同之处在于创建的时候需要选择不同的方式。 2、使用CocoaPods 方式还需要在 build.gradle(.kts) 文件中添加内容 在build.gradle(.kts) 文件中添加完成后,执行一下文件。剩下的集成…

Java和Python一些处理sql方式总结

将查询结果导入csv文件中 public static int executeUpdate(String sql, Object[] param) {//创建一个PreparedStatement对象用来操作数据库PreparedStatement pstmt null;//getConnection()方法为我自己定义的获取数据库连接的方法pstmt getConnection().prepareStatement(s…

基于Matlab实现指纹识别技术(附上完整源码)

指纹识别是一种常用的生物识别技术&#xff0c;具有独特性高、可靠性强的特点。本文介绍了基于Matlab的指纹识别技术实现的方法和步骤。首先&#xff0c;对指纹图像进行预处理&#xff0c;包括图像增强和去噪处理。然后&#xff0c;使用特征提取算法提取指纹特征。最后&#xf…

HTML+CSS前端 简易用户登录界面

Day1 刚学了一些html和css的简单语法&#xff0c;尝试写一个非常简易的静态用户登录界面。 login_simple.html <!DOCTYPE html> <html lang"en"><head><meta name"viewport" content"widthdevice-width,initial-scale1.0"…

【adb】adb常用命令

Android Debug Bridge (adb) Android 调试桥 (adb) 是一种功能多样的命令行工具&#xff0c;可让您与设备进行通信。adb 命令可用于执行各种设备操作&#xff0c;例如安装和调试应用。adb 提供对 Unix shell&#xff08;可用来在设备上运行各种命令&#xff09;的访问权限。它…

Mac 终端美化显示

Linux 也可安装 Zsh 后使用此套配置。 1. 安装 Oh My Zsh sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"2. 更换主题&#xff0c;修改文件&#xff1a;~/.zshrc&#xff0c;原内容&#xff1a; ZSH_THEME&quo…

opencv中轮廓相关属性

一、介绍 findContours() &#xff1a;The function retrieves contours from the binary image。 二、代码 void main() {Mat src imread("match00.bmp", IMREAD_GRAYSCALE);Mat mask;threshold(src, mask, 128, 255, cv::THRESH_BINARY_INV);Mat element cv::g…

Matlab实现遗传算法仿真(附上40个仿真源码)

遗传算法&#xff08;Genetic Algorithm&#xff0c;GA&#xff09;是一种基于生物进化理论的优化算法&#xff0c;通过模拟自然界中的遗传过程&#xff0c;来寻找最优解。 在遗传算法中&#xff0c;每个解被称为个体&#xff0c;每个个体由一组基因表示&#xff0c;每个基因是…

介绍下Django中的表单(forms)模块中的类forms.CharField

在Django中&#xff0c;forms.CharField() 是用于定义表单字段的类&#xff0c;它属于 Django 的表单&#xff08;forms&#xff09;模块。CharField 是用于处理字符型数据的表单字段类。它允许用户在表单中输入文本数据&#xff0c;并对该数据进行验证和处理。 forms.CharFie…

6门新兴语言,小众亦强大

编码语言在塑造我们创建软件的方式方面起着至关重要的作用。多年来&#xff0c;我们观察到Python&#xff0c;Java和C等成熟语言的流行。然而&#xff0c;如今一波新的编码语言浪潮已经出现&#xff0c;提出了创造性的解决方案&#xff0c;并推动了软件工程领域所能完成的极限。…

Cesium 实战 - Blender调整模型组件原点,实现直升机尾翼旋转

Cesium 实战 - Blender调整模型组件原点&#xff0c;实现直升机尾翼旋转 1.模型原点问题2.导入模型&#xff08;zhisheng.glb&#xff09;3.导出模型4. 通过 czml 调试代码 某个项目需求&#xff0c;在操作直升机模型的时候&#xff0c;希望直升机机翼和尾翼旋转起来。 机翼旋…

Pytorch参数优化

前言&#xff1a; 当我们训练神经网络时&#xff0c;我们需要调整模型的参数&#xff0c;使得损失函数的值逐渐减小&#xff0c;从而优化模型。但是模型的参数我们一般是无法看见的&#xff0c;所以我们必须学会对参数的更新&#xff0c;下面&#xff0c;我将介绍两种参数更新的…

适配器模式——不兼容结构的协调

1、简介 1.1、概述 有的笔记本电脑的工作电压是20V&#xff0c;而我国的家庭用电是220V&#xff0c;如何让20V的笔记本电脑能够在220V的电压下工作&#xff1f;答案是引入一个电源适配器&#xff08;AC Adapter&#xff09;&#xff0c;俗称充电器&#xff0f;变压器。有了这…

解决Ubuntu 22.04 虚拟机克隆出多台造成的IP地址冲突的问题

在被克隆的机器上编辑 /etc/netplan/00-installer-config.yaml 文件 network:ethernets:enp0s5:dhcp4: truedhcp-identifier: mac #添加次行version: 2这样每次克隆出来的机器都会有唯一的IP地址 简单说明 如果是克隆 centos 会发现不会出现这一情况&#xff0c;而克隆 ubu…

Qt 2. QSerialPortInfo显示串口信息

在ex2.pro 添加&#xff1a; QT serialport//main.cpp #include "ex2.h" #include <QtSerialPort/QtSerialPort> #include <QApplication>int main(int argc, char *argv[]) {QApplication a(argc, argv);Ex2 w;w.show();QList<QSerialPortInfo>…