sql小总结

SQL的一些使用技巧:

1. null

我们在进行=/<>/in/not in等判断时,null会不包含在这些判断条件中,所以在对null的处理时可以使用nvl或者coalesce函数对null进行默认转换。

2. select *

尽可能提前对列进行剪裁,即使是全表字段都需要,也尽可能的把字段都写出来,一是减少了数据运算中不必要的数据读取,二是避免后期因为原表或者目标表字段增加,导致报错。

3. limit的使用

临时查询或者数据探查时,养成习惯加上limit,会快速的查询出你想要的数据,且消耗更少的资源。

4. 关联

左关联、内关联、右关联、left anti join 、left semi join等,可以实现不同情况下的多表关联。关联字段要确保字段类型的一致。

5. 窗口函数的使用

可以通过row_number()/rank()over(partition by order by )的方式实现数据按照某个字段分组的排序,也可以通过max(struct())的方式实现。

索引的使用:

合理使用索引可以大大提高查询速度,但过多的索引也可能会影响数据修改操作的性能。索引适合建立在查询较多但修改表较少的表,因为索引会影响修改表的速度。

外键:

( 外键建立在多对一中多的表 ,多的表为子表(外键设置表))

多对一中的一的父表的字段可以是主键也可以不是主键,但必须是唯一字段

多的表可以删除任一行。

插入一行时如果外键引用的列在父表不存在时不能插入,必须父表插入后子表才能插入

外键的删除/更新: 建立外键策略时注意要设置删除和更新两种策略

no action, restrict

cascade

set null

set default

多对多:建立一个中间表,设置两个外键联立两张表的主键

-- 创建学生表
CREATE TABLE students (student_id INT PRIMARY KEY,student_name VARCHAR(50)
);-- 创建课程表
CREATE TABLE courses (course_id INT PRIMARY KEY,course_name VARCHAR(50)
);-- 创建学生课程关联表
CREATE TABLE student_courses (student_id INT,course_id INT,PRIMARY KEY (student_id, course_id),FOREIGN KEY (student_id) REFERENCES students(student_id),FOREIGN KEY (course_id) REFERENCES courses(course_id)
);

连接

内联接: inner join

外联接: left join 左边所有数据和右边的交集 right join 右边所有数据和左边的交集

联合查询: 将多次查询的结果连接起来展现 union 和加了all的区别,all的会将重复字段再展现一次 union all

mysql中的等于只有一个等于号(=),此处区别于java

子查询: 标量子查询,where等等 列子查询 in , not in, any, some,all 行子查询 条件和列子查询一样 表子查询

事务:

查看 select @@autocommit 设置 set @@autocommit = 0 0为手动提交,1为自动提交 提交 commit 回滚 rollback

start transaction开启事务,再进行事务操作 设置事务为手动提交 set @@autocommit = 0 事务成功进行commit 失败时进行 rollback

出现异常时要进行回滚rollback

事务操作: 1开启事务 start transaction 2一系列操作 update等等 3提交事务 commit 4回滚事务 rollback

并发事务: 脏读 , 一个事务读到另一个事务还没提交的数据 不可重复读,一个事务先后读取同一条记录,但两次读取的数据不同 幻读,一个事务按照条件查询数据时,没有对应数据行,但在插入数据时发现这一行数据已经存在

事务隔离级别

  • read uncommitted

  • read committed

  • repeatable read (默认)

  • serializable

  • 隔离级别脏读不可重复读幻读
    read uncommitted
    read committed×
    repeatable read (默认)××
    serializable×××

事务管理:

使用BEGIN TRANSACTIONCOMMITROLLBACK等语句来确保数据的一致性和完整性。

在使用事务时,遵循ACID,应确保事务的原子性、一致性、隔离性和持久性。

使用参数化查询: 可以避免SQL注入攻击,提高查询效率。

 查看mysql版本

select version();

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

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

相关文章

android 在 Activity 的 onCreate 中获取View 的宽高

view 的 post 执行时&#xff0c;首先会判断view 的 mAttatchInfo 是否为空&#xff0c;如果不为空&#xff0c;则将Runnable 添加到mAttachInfo.handler 的 UI线程MessageQueue 中&#xff1b;如果为空&#xff0c;则先将Runnable 暂存在view 的类为HandlerActionQueue的mRunQ…

2024上海国际化工自动化仪器仪表展览会

2024上海国际化工自动化仪器仪表展览会 2024 Shanghai International Chemical Automation Instrument Exhibition 时间&#xff1a;2024年12月11-13日 地点&#xff1a;上海新国际博览中心 详询主办方陆先生 I38&#xff08;前三位&#xff09; I82I&#xff08;中间四位…

makefile 进阶

# 定义编译器 CC gcc CXX g #目标名称 TARAET : main # 定义目标文件存放目录 BUILD_DIR : _build#自定义命令 MKDIR mkdir -p $(dir $)# 定义头文件存放目录 INC_PATH : $(nullstring) # 定义源文件存放目录 SRC_PATH : $(nullstring)# 定义编译选项 CFLAGS : $(nullstring…

521源码-免费源码-子比主题最新版7.6绕授权破解完整教程

首先&#xff0c;zibll主题授权是向api.zibll.com发送请求&#xff0c;api.zibll.com就验证这个请求&#xff0c;如果参数(比如header)正确那么授权成功&#xff0c;然而众所周知&#xff0c;服务器可以修改本地host文件&#xff0c;来实现某些特定功能&#xff0c;把host文件加…

SpringBean-生命周期

Spirng Bean 元信息配置阶段 1 面向资源 xml配置&#xff08;很熟悉了不做讨论&#xff09;Properties配置 public class BeanMetaDemo {public static void main(String[] args) {DefaultListableBeanFactory factory new DefaultListableBeanFactory();PropertiesBeanDef…

【C语言】字符串及其函数速览

字符串及其函数速览 字符串及其函数1. 字符串的输入输出1.1 gets()1.2 fgets()1.3 puts()1.4 fputs()输入输出函数案例 2. 字符串相关函数速览2.1 字符串赋值strset()strnset()strcpy()strncpy()strdup()下面的mem系列函数不仅能作用于字符&#xff0c;也能作用于其他类型memse…

【Java面试】三、Redis篇(下)

文章目录 1、抢券场景2、Redis分布式锁3、Redisson实现分布式锁4、Redisson实现的分布式锁是可重入锁5、Redisson实现分布式锁下的主从一致性6、面试 1、抢券场景 正常思路&#xff1a; 代码实现&#xff1a; 比如优惠券数量为1。正常情况下&#xff1a;用户A的请求过来&a…

DeepRec Extension 打造稳定高效的分布式训练

DeepRec Extension 即 DeepRec 扩展&#xff0c;在 DeepRec 训练推理框架之上&#xff0c;围绕大规模稀疏模型分布式训练&#xff0c;我们从训练任务的视角提出了自动弹性训练&#xff0c;分布式容错等功能&#xff0c;进一步提升稀疏模型训练的整体效率&#xff0c;助力 DeepR…

开源RAG,本地mac启动 dify源码服务

一、Dify文档 参考官方文档来操作&#xff0c;基本没太大的问题。一些细节&#xff0c;我在本篇文章中补充了出来。 这篇文章主要讲以源码的方式启动后端服务&#xff0c;前端服务使用容器启动。 dify 文档地址 欢迎使用 Dify | 中文 | Dify Dify 本地源码部署文档&#xff…

如何解读伊朗发布的直升机事故调查报告?一般事故调查报告应怎么写?

如何解读伊朗发布的直升机事故调查报告&#xff1f;一般事故调查报告应怎么写&#xff1f; 据央视新闻客户端消息&#xff1a;当地时间5月23日&#xff0c;伊朗武装部队总参谋部发布首份已故总统莱希及其随行人员乘坐的直升机事故调查报告。以下是#李秘书讲写作#对报告内容的解…

C语言面向对象编程,linux同时控制TOF摄像头和RGB摄像头

linux应用层同时控制TOF和RGB摄像头&#xff0c;为了方便操作&#xff0c;统一接口&#xff0c;这里将TOF和RGB摄像头看成两个对象&#xff0c;对它们分别实现&#xff0c;初始化&#xff0c;去初始化&#xff0c;读取视频流&#xff0c;停止视频流&#xff0c;启动视频流&…

YOLOv8 | 卷积模块 | 即插即用的可变核卷积AKConv【附代码+小白可上手】

💡💡💡本专栏所有程序均经过测试,可成功执行💡💡💡 在目标检测领域内,尽管YOLO系列的算法傲视群雄,但在某些方面仍然存在改进的空间。在YOLOv8提取特征的时候,卷积的核是固定的K*K大小,导致参数数量随着大小的增加呈平方级增长。显然,不同数据集和目标的形状…

基于微信的家庭理财管理小程序的设计与实现(论文+源码)_kaic

摘 要 随着中国经济的飞速发展&#xff0c;家庭收入不断增高&#xff0c;人们的消费除了简单的维持日常生活之外&#xff0c;还有其他的消费方式&#xff0c;比如旅游、电商购物等&#xff0c;层出不穷的消费方式带给人快乐的同时&#xff0c;也常常让一些人逐渐无法把握住自…

【LeetCode】每日一题 2024_5_24 找出最具竞争力的子序列(栈,模拟,贪心)

文章目录 LeetCode&#xff1f;启动&#xff01;&#xff01;&#xff01;题目&#xff1a;找出最具竞争力的子序列题目描述代码与解题思路 每天进步一点点 LeetCode&#xff1f;启动&#xff01;&#xff01;&#xff01; 题目&#xff1a;找出最具竞争力的子序列 题目链接&a…

建材行业工程设计资质人员不足对资质有哪些影响

资质申请与审批&#xff1a;在申请工程设计资质时&#xff0c;人员的数量和专业配置是考核的重要指标之一。如果企业人员不足&#xff0c;尤其是缺乏关键岗位的专业技术人员&#xff0c;将直接影响资质的申请和审批。建设部门在核查企业主要人员信息时&#xff0c;如果发现人员…

24年前端面试 高频经典(答案版)

目录 1、函数式编程是什么简单说下&#xff1f; 2、打包工具代码管理 git svn 了解多少&#xff1f; 3、什么是Webpack&#xff1f;它的主要功能是什么&#xff1f; 4、Webpack的核心概念是什么&#xff1f; 5、如何获取到父节点dom 祖父节点呢&#xff1f; 6、登录流…

广义线性chirplet变换【附MATLAB代码】

文章来源&#xff1a;微信公众号&#xff1a;EW Frontier 摘要 时频分析方法是一种刻画信号时变特征的有效工具&#xff0c;在相当长的一段时间内受到了广泛的关注。随着TF算法的发展&#xff0c;许多先进的方法被提出&#xff0c;可以提供更精确的TF结果。但是&#xff0c;不…

【LabVIEW FPGA入门】使用事件发生函数同步FPGA循环

1.使用事件发生函数 使用 Occurrences 函数来控制单独的同步活动。特别是&#xff0c;当您希望程序框图的一部分等待程序框图的另一部分完成任务而不强制 LabVIEW 进行轮询时&#xff0c;请使用这些函数。 您可以使用全局变量执行类似于occurrences函数的功能&#xff0c;通过一…

Nginx 是一款高性能的开源 Web 服务器软件

文章推荐 1 作为程序员&#xff0c;开发用过最好用的AI工具有哪些&#xff1f; 2 Github Copilot正版的激活成功&#xff0c;终于可以chat了 3 idea,pycharm等的ai assistant已成功激活 4 新手如何拿捏 Github Copilot AI助手&#xff0c;帮助你提高写代码效率 5 Jetbrains的a…

SQL——DML对表中数据的操作

# 创建数据库 create database if not exists db_BigData default character set gb2312 default collate gb2312_chinese_ci; # 创建表 create table if not exists db_BigData.stu (id int auto_increment primary key comment 主键ID,name var…