MySql基础补漏笔记
在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基础补漏笔记的更多相关文章
- mysql基础知识笔记
Mysql基础笔记 环境配置 基本概念 mysql命令行 进入 use show 查询 select order by where like 数据过滤regexp concat 文本函数 日期函数 数 ...
- mysql基础itcast笔记
1. 课程回顾 mysql基础 1)mysql存储结构: 数据库 -> 表 -> 数据 sql语句 2)管理数据库: 增加: create database 数据库 default c ...
- 尚硅谷MySQL基础学习笔记
目录 写在前面 MySQL引入 数据库的好处 数据库的相关概念 数据库存储数据的特点 MySQL服务的启动和停止 MySQL服务端的登录和退出 MySQL的常用命令 MySQL语法规范 DQL(Dat ...
- MYSQL基础--学习笔记
最近一段时间,系统的学习了下mysql相关知识,当然都是比较基础的,现在贴出来,以供参考备忘--帅帅的小猪猪 创建用户:CREATE USER 'sampadm'@'localhost' IDENTI ...
- MySQL基础学习笔记
一.数据库基本概念 1.1 数据库 - Database 从字面意思看,数据库就是一个存储数据的仓库.从计算机的角度来讲,数据库(Datebase)是按照数据结构来组织.存储和管理数据的仓库. 简单来 ...
- 初学MySQL基础知识笔记--01
本人初入博客园,第一次写博客,在今后的时间里会一点点的提高自己博客的水平,以及博客的排版等. 在今天,我学习了一下MySQL数据库的基本知识,相信关于MySQL的资料网上会有很多,所以我就不在这里复制 ...
- Mysql基础篇(笔记)
mysql数据库是由DB跟DBMS跟sql组成 DB 数据库仓库 DBMS 数据库管理系统 SQL 一门通用的数据库语言 数据库启动命令 : 关闭->net stop MySQL || 开启 ...
- MySQL基础原创笔记
对表的增删改操作: 创建表: create table student ( id int primary key auto_increment, name ...
- MySQL基础原创笔记(一)
对表的增删改操作: 创建表: create table student ( id int primary key auto_increment, name ...
随机推荐
- Java 中的等待唤醒机制透彻讲解
线程的状态 首先了解一下什么是线程的状态,线程状态就是当线程被创建(new),并且启动(start)后,它不是一启动就进入了执行状态(run),也不是一直都处于执行状态. 这里说一下Java 的Thr ...
- arima.predict()参数选择以及相关的一些问题
在使用a ri ma进行模型建立时,需要注意以下几点 1.参数选择上predict必须起始时间在原始的数据及当中的,在下例中就是说2017必须在数据集里面,而2019不受限制,只哟在2017后面就好了 ...
- scrapy在存储数据到json文件中时,中文变成为\u开头的字符串的处理方法
在settings.py文件中添加 FEED_EXPORT_ENCODING = 'utf-8'
- [bzoj4815] [洛谷P3700] [Cqoi2017] 小Q的表格
Description 小Q是个程序员. 作为一个年轻的程序员,小Q总是被老C欺负,老C经常把一些麻烦的任务交给小Q来处理. 每当小Q不知道如何解决时,就只好向你求助.为了完成任务,小Q需要列一个表格 ...
- Myeclipse 2017 下载+安装+激活+集成配置【JRE 8+Tomcat 9+MySQL 5.7.29】
Myeclipse 2017 的下载 Myeclipse 2017 下载地址:https://www.jianguoyun.com/p/DTEBo1cQ6LnsBxj9984C Myeclipse 2 ...
- 【Oracle】分区表详解
此文从以下几个方面来整理关于分区表的概念及操作: 1.表空间及分区表的概念 2.表分区的具体作用 3.表分区的优缺点 4.表分区的几种类型及操作方法 5.对表分区的维护 ...
- Python学习,第五课 - 列表、字典、元组操作
本篇主要详细讲解Python中常用的列表.字典.元组相关的操作 一.列表 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 通过下标获取元素 #先定义一个列表 le ...
- Vertx使用EventBus发送接受自定义对象
先看官方文档步骤: 需要一个编解码器,看源码: 可见内置了需要数据类型的实现,所以发送其他消息可以发送,但是如果发送自定义对象就需要自己实现编解码逻辑了 一 自定义编解码器 /** * 自定义对象编解 ...
- docker学习笔记1认识docker
简介 Docker是一个开源的应用容器,开发者可以打包其应用以及依赖到一个可移植的容器当中.当然容器与容器之间不存在任何接口,完全独立.最大程度的解决了我的软件只能不能在你的电脑上运行的尴尬局面.开发 ...
- gulp的简单打包示例(一)
引言 前端开发,打包工具是必不可少的,虽然有很多别人帮你封装好的打包工具,但自己配置一个,自身的实力也会大增呀.这篇博文主要讲的是使用gulp对html.js.less.css.图片的压缩合并等配置. ...