MySQL教程|菜鸟教程系统复习的时候有一些知识点还没掌握透的或者思维方式还没完全跟上的地方,写了一个笔记,讲道理此笔记对除我之外的任何读者不具有任何实用价值,只针对我在复习MySQL基础过程中的查漏补缺。

MySQL查询:

MySQL不支持全连接,所以用左连接+union+右连接实现完全连接。

MySQL中union操作符用于连接两个以上的select语句的结果组合到一个查询结果中。

多个select语句union时会删除重复的数据。

NULL值处理:

MySQL中 NULL=NULL 返回false,所以用is null/is not null 来操作值为NULL的字段。

任何值=NULL 都返回false.

正则表达式:

给出正则模式用于REGEXP操作符

regexp操作符的使用实例:查询user表中字段name以wu开头的所有记录

select * from user where name regexp '^wu';

MySQL事务:

使用场景:处理操作量大、复杂度高的数据。操作量大是指关联较多的数据。

在MySQL中只有使用了Innodb数据库引擎的库、表才支持事务。

使用作用:维护数据完整性

事务满足4个特性(ACID):

原子性、一致性、隔离性、持久性

一致性:在事务开始之前及事务的结束之后,数据的完整性没有被破坏

隔离性:控制事务并发访问的级别

MySQL存储过程:

输入参数 in:

  存储过程可访问输入参数的初始值,可在存储过程内部修改,但不能将修改结果返回。

输出参数 out:

  存储过程不可访问输出参数的初始值,可在存储过程内部修改,并且可以将修改结果返回。

输入参数、输出参数的区别可以理解为java中参数传递的值传递和引用传递的区别。

输入输出参数 inout:

  存储过程既能访问 inout参数的初始值,也能在存储过程内部修改值并且将修改结果返回。

索引:

使用索引可快速访问表中特定的信息,索引是对表中一列或多列的值进行排序的一种结构,类似书籍的目录。

创建索引会提高查询效率,但会降低更新表的效率,因为更新数据不但要保存数据,还需要维护表中的索引文件,因此索引的使用场景是在数据量大且更新操作少的表中。

MySQL序列:

  可设置除主键之外的其他自增字段。

以上是对知识点的查漏补缺,下面是关于处理数据过程中思维方式的应用。

重复数据操作:

防止重复数据出现:表设计时可通过对不允许重复的一列或几列进行联合主键限制,或通过unique设置单列的唯一值属性来限制。

统计重复数据:统计person表中lastname、firstname都不重复并且记录数大于1条的数据

select count(*) as rep ,lastname,firstname from person

group by lastname,firstname

having on rep>1;

思维模式:

确定重复列 lastname firstname

在列选择列表(select 后的字段)列出重复列及count(*)

在group by 中列出重复列

Having 子句设置重复数限制

过滤重复数据的两种操作:

1.select distinct ...

2.select ... group by x,y

删除重复数据的两种操作:

1.通过临时表

过滤重复数据插入临时表

删除原表

将临时表重命名为原表

2.通过添加索引或主键来删除表中重复数据

alter ignore table person add primary key(lastname,firstname);--多列不重复

alter table person add unique(firstname);--单列不重复

MySql基础补漏笔记的更多相关文章

  1. mysql基础知识笔记

    Mysql基础笔记 环境配置 基本概念 mysql命令行 进入 use show 查询 select order by where like 数据过滤regexp concat 文本函数 日期函数 数 ...

  2. mysql基础itcast笔记

    1. 课程回顾 mysql基础 1)mysql存储结构: 数据库 -> 表 -> 数据   sql语句 2)管理数据库: 增加: create database 数据库 default c ...

  3. 尚硅谷MySQL基础学习笔记

    目录 写在前面 MySQL引入 数据库的好处 数据库的相关概念 数据库存储数据的特点 MySQL服务的启动和停止 MySQL服务端的登录和退出 MySQL的常用命令 MySQL语法规范 DQL(Dat ...

  4. MYSQL基础--学习笔记

    最近一段时间,系统的学习了下mysql相关知识,当然都是比较基础的,现在贴出来,以供参考备忘--帅帅的小猪猪 创建用户:CREATE USER 'sampadm'@'localhost' IDENTI ...

  5. MySQL基础学习笔记

    一.数据库基本概念 1.1 数据库 - Database 从字面意思看,数据库就是一个存储数据的仓库.从计算机的角度来讲,数据库(Datebase)是按照数据结构来组织.存储和管理数据的仓库. 简单来 ...

  6. 初学MySQL基础知识笔记--01

    本人初入博客园,第一次写博客,在今后的时间里会一点点的提高自己博客的水平,以及博客的排版等. 在今天,我学习了一下MySQL数据库的基本知识,相信关于MySQL的资料网上会有很多,所以我就不在这里复制 ...

  7. Mysql基础篇(笔记)

    mysql数据库是由DB跟DBMS跟sql组成 DB 数据库仓库 DBMS 数据库管理系统 SQL 一门通用的数据库语言   数据库启动命令 : 关闭->net stop MySQL || 开启 ...

  8. MySQL基础原创笔记

    对表的增删改操作: 创建表: create table student (          id  int  primary key  auto_increment,          name   ...

  9. MySQL基础原创笔记(一)

    对表的增删改操作: 创建表: create table student (          id  int  primary key  auto_increment,          name   ...

随机推荐

  1. 神秘常量0x077CB531,德布莱英序列的恩赐

    本文发布于游戏程序员刘宇的个人博客, 转载请注明来源https://www.cnblogs.com/xiaohutu/p/10950011.html 某天我在优化游戏的算法,在将一个个关键数据结构优化 ...

  2. 国产CPU 申威1621 异数OS基础组件理论性能测试报告

    国产CPU 申威1621 异数OS基础组件理论性能测试报告 文章目录 国产CPU 申威1621 异数OS基础组件理论性能测试报告 前言 测试平台 测试项目 SW1621 异数OS 容器虚拟交换机模拟性 ...

  3. [洛谷P4097] [HEOI2013] Segment

    Description 要求在平面直角坐标系下维护两个操作: 1.在平面上加入一条线段.记第 \(i\) 条被插入的线段的标号为 \(i\) 2.给定一个数 \(k\) ,询问与直线 \(x = k\ ...

  4. [CCPC2019 ONLINE]E huntian oy

    题意 http://acm.hdu.edu.cn/showproblem.php?pid=6706 思考 打表出奇迹. 注意到这个式子有一大堆强条件限制,最后化为: $$\frac{1}{2}\sum ...

  5. mysql安装教程linux

    https://www.cnblogs.com/YangshengQuan/p/8431520.html 设置sql远程访问

  6. Docker基础内容之数据持久化

    数据卷的特性 数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS 数据卷可以在容器之间共享和重用,相当于将一个分区挂载到多个目录下面 数据卷内容的修改会立马生效 数据卷的更新,不会影响镜像: ...

  7. Typora常用快捷键

    目录 无序列表:输入-之后输入空格 有序列表:输入数字+"."之后输入空格 任务列表:-[空格]空格 文字 标题:ctrl+数字 表格:ctrl+t 生成目录:按回车 选中一整行: ...

  8. 【WPF学习】第三十章 元素绑定——绑定到非元素对象

    前面章节一直都在讨论如何添加链接两个各元素的绑定.但在数据驱动的应用程序中,更常见的情况是创建从不可见对象中提取数据的绑定表达式.唯一的要求是希望显示的信息必须存储在公有属性中.WPF数据绑定数据结构 ...

  9. .net core3.1 webapi + element-ui upload组件实现文件上传

    首先,先看我个人的的项目结构. 这个webapi项目是专门用来做图片上传,其中分为两个控制器:单图片上传和多图片上传.而我接下来主要讲的还是单文件上传,对于多文件的上传,我暂且尚未研究成功. 其中pi ...

  10. C++基类和派生类的构造函数

    派生类不能继承基类的构造函数,若想通过派生类来对基类的private的变量成员进行初始化则需要: 通过派生类的构造函数来调用基类的构造函数完成基类成员变量的初始化. 看下面的例子: #include ...