mysql数据库进阶
一、索引
索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构。类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获取即可。
分类:
- 普通索引
- 唯一索引
- 全文索引
- 组合索引
- 主键索引
1、普通索引
普通索引仅有一个功能:加速查询
#创建表时创建索引
CREATE TABLE user (
id INT,
username VARCHAR(30) ,
password VARCHAR(50),
INDEX index_username (username)
);
注意:创建索引时如果是blob 和 text 类型,必须指定length。
2、唯一索引
唯一索引有两个功能:加速查询 和 唯一约束(可含null)
#创建表时创建唯一索引
CREATE TABLE user (
id INT,
username VARCHAR(30) ,
password VARCHAR(50),
UNIQUE index_username (username)
); #在存在的表上创建唯一索引
create unique index 索引名 on 表名(列名) #删除存在表上的索引
drop unique index 索引名 on 表名
3、全文索引
全文索引(FULLTEXT)仅可以适用于MyISAM引擎的数据表;作用于CHAR、VARCHAR、TEXT数据类型的列。
#创建表时创建唯一索引
CREATE TABLE user (
id INT,
username VARCHAR(30) ,
password VARCHAR(50),
FULLTEXT index_username (username)
);
4、组合索引
将几个列作为一条索引进行检索,使用最左匹配原则,比如频繁的使用多列进行查询,where username='bright' and password='123456'
#创建组合索引
CREATE TABLE user (
id INT,
username VARCHAR(30) ,
password VARCHAR(50),
INDEX index_info (username, password)
);
5、主键索引
主键有两个功能:加速查询 和 唯一约束(不可含null),当一张表把某个列设为主键的时候,则该列就是主键索引。
#创建主键索引
CREATE TABLE user (
nid int not null auto_increment primary key, #主键索引
username VARCHAR(30) ,
password VARCHAR(50),
INDEX index_info (username, password)
); #创建主键
alter table 表名 add primary key(列名); #删除主键
alter table 表名 drop primary key;
6、索引的添加与删除
(1)添加索引
#在已存在的表上创建索引
CREATE [UNIQUE | FULLTEXT | SPATIAL ] INDEX 索引名
ON 表名 (字段名[(长度)] [ASC |DESC]) ; #如:
CREEATE INDEX index_name ON table_name(column_name)
(2)删除索引
#删除存在表上的索引
DROP INDEX 索引名 ON 表名 #如:
drop index_name on table_name;
(3)查看索引
#查看存在表上的索引
SHOW INDEX FROM 表名 #如:
show index from table_name;
二、事务
1、概念
事务是一个最小的不可再分的工作单元或者一组原子性的sql命令,一旦在执行命令过程中出现错误就会回滚到最初状态,从而保证数据的完整性。事务必须满足四个条件:
- 原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。
- 一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏。
- 隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。
- 持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失
2、事务相关命令
--开启事务:Start Transaction
--事务结束:End Transaction
--提交事务:Commit Transaction
--回滚事务:Rollback Transaction
3、实例
- 事务操作成功
mysql> start transaction; --开始事务
Query OK, 0 rows affected (0.00 sec) mysql> insert into class(caption) values('四年一班');
Query OK, 1 row affected (0.00 sec) mysql> commit; --提交,数据库内部已经改变
Query OK, 0 rows affected (0.00 sec) mysql> select * from class;
+-----+----------+
| cid | caption |
+-----+----------+
| 1 | 三年二班 |
| 2 | 一年三班 |
| 3 | 三年一班 |
| 5 | 四年一班 |
+-----+----------+
4 rows in set (0.00 sec)
- 事务操作失败
mysql> start transaction; --开启事务
Query OK, 0 rows affected (0.00 sec) mysql> insert into class(caption) values('四年一班');
Query OK, 1 row affected (0.00 sec) mysql> select * from class;
+-----+----------+
| cid | caption |
+-----+----------+
| 1 | 三年二班 |
| 2 | 一年三班 |
| 3 | 三年一班 |
| 4 | 四年一班 |
+-----+----------+
4 rows in set (0.00 sec) mysql> rollback; --回滚,事务操作失败
Query OK, 0 rows affected (0.00 sec) mysql> select * from class;
+-----+----------+
| cid | caption |
+-----+----------+
| 1 | 三年二班 |
| 2 | 一年三班 |
| 3 | 三年一班 |
+-----+----------+
3 rows in set (0.00 sec)
三、视图
视图可以理解为存储的查询语句,当调用的时候,产生结果集,视图充当的是虚拟表的角色(不是真实存在的)。
1、创建视图
#格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v AS SELECT * FROM userinfo;
2、删除视图
#格式:DROP VIEW 视图名称 DROP VIEW v
3、修改视图
格式:ALTER VIEW 视图名称 AS SQL语句 ALTER VIEW v AS
SELET username,password FROM userinfo;
4、使用视图
由于视图是虚拟表,因此无法使用其对真实表进行创建、更新和删除操作,仅能做查询用。
SELECT * FROM v;
四、存储过程
存储过程是一个SQL语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。
1、创建存储过程
mysql> delimiter $$ --将语句的结束符号从分号;临时改为两个$$(可以是自定义)
mysql> create procedure p2()
-> select * from usertabl
-> end $$
Query OK, 0 rows affected (0.0) mysql> delimiter ; --#将语句的结束符号恢复为分号
2、执行存储过程
mysql> call p2();
3、删除存储过程
mysql> drop procedure p2;
参考:https://www.cnblogs.com/wupeiqi/articles/5713323.html
mysql数据库进阶的更多相关文章
- Mysql数据库进阶之(分表分库,主从分离)
前言:数据库的优化是一个程序员的分水岭,作为小白我也得去提前学习这方面的数据的 (一) 三范式和逆范式 听起范式这个迟非常专业我来举个简单的栗子: 第一范式就是: 把能够关联的每条数据都拆分成一个 ...
- Python操作Mysql数据库进阶篇——查询操作详解(一)
前面我们已经介绍了在Python3.x中如何连接一个Mysql数据库,以及怎么样对这个数据库创建一个表,增删改查表里的数据.想必大家对Mysql数据库和简单的sql语句有了一定的了解,其实sql语句博 ...
- mysql数据库-进阶-长期维护
############### 视图 ############## """ 1.视图 视图:是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有 ...
- 数据库学习笔记(二)MySQL数据库进阶
MySQL 进阶 关于连表 左右连表: join 上下连表: union #自动去重 (当两张表里的数据,有重复的才会自动去重) union all #不去重 #上下连表示例: select sid, ...
- mysql数据库进阶篇
一.连表操作 1)为何需要连表操作 .把所有数据都存放于一张表的弊端 .表的组织结构复杂不清晰 .浪费空间 .扩展性极差 2)表设计,分析表与表之间的关系 寻找表与表之间的关系的套路 举例:emp表 ...
- MySQL第二讲 一一一一 MySQL语句进阶
通过命令来备份数据库: 通过数据库软件里面的,mysqldump模块来操作,如下: mysqldump -u root db1 > db1.sql -p; //没有-d就是备份的时候:数据表结构 ...
- nodejs进阶(6)—连接MySQL数据库
1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...
- Java进阶(二十五)Java连接mysql数据库(底层实现)
Java进阶(二十五)Java连接mysql数据库(底层实现) 前言 很长时间没有系统的使用java做项目了.现在需要使用java完成一个实验,其中涉及到java连接数据库.让自己来写,记忆中已无从搜 ...
- Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁
Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...
随机推荐
- Flink 实战:如何解决生产环境中的技术难题?
大数据作为未来技术的基石已成为国家基础性战略资源,挖掘数据无穷潜力,将算力推至极致是整个社会面临的挑战与难题. Apache Flink 作为业界公认为最好的流计算引擎,不仅仅局限于做流处理,而是一套 ...
- 108天南京银行完成不可能完成的新金融DevOps转型
在2018云栖大会南京峰会企业研发云专场,由南京银行研发管理负责人吴攀带来了“云效助力新金融DevOps转型——南京银行实践之路”的主题分享.首先对南京银行的研发规模与成长做了介绍,对“鑫云+”的诞生 ...
- 批量搞机(一):ansible简介、ansible安装
一.ansible简介 Ansible是2013年推出的一款IT自动化和DevOps软件,目前由Redhat已签署Ansible收购协议.其是基于Python研发,糅合了很多老运维工具的优点实现了批量 ...
- qt qsplashscreen 启动画面 延时
intdelayTime=3; QElapsedTimer timer; timer.start(); while(timer.elapsed()<(delayTime*1000)) { app ...
- 20180823-Java包
Java 包(package) 为了更好地组织类,Java提供了包机制,用于区别类名的命名空间. 包的作用 1 把功能相似或相关的类或接口组织在同一个包中,方便类的查找和使用. 2 如同文件夹一样,包 ...
- Nginx负载均衡与反向代理—《亿级流量网站架构核心技术》
当我们的应用单实例不能支撑用户请求时,此时就需要扩容,从一台服务器扩容到两台.几十台.几百台.然而,用户访问时是通过如http://www.XX.com的方式访问,在请求时,浏览器首先会查询DNS服务 ...
- [CSP-S模拟测试]:题(DP)
题目描述 由于出题人赶时间所以没办法编故事来作为背景.一开始有$n$个苹果,$m$个人依次来吃苹果,第$i$个人会尝试吃$u_i$或$v_i$号苹果,具体来说分三种情况.$\bullet 1.$两个苹 ...
- html5: postMessage解决跨域通信的问题
效果图 postmessage解析 HTML5提供了新型机制PostMessage实现安全的跨源通信. 语法 otherWindow.postMessage(message, targetOrigin ...
- python3入门之基础语法
Python 是一个高层次的结合了解释性.编译性.互动性和面向对象的脚本语言.Python 的设计具有很强的可读性,相比其他语言经常使用英文关键字,其他语言的一些标点符号,它具有比其他语言更有特色语法 ...
- 机器学习实战_基于Scikit-Learn和Tensorflow读书笔记
第一部分 机器学习基础 第二部分 神经网络和深度学习 第9章 运行Tensorflow 分布式系统:分布式系统的定义是这个系统建立在网络的操作系统,具有高度的内聚性和透明性,它与网络的区别在于高层软件 ...