一、索引

索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构。类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获取即可。

分类:

  • 普通索引
  • 唯一索引
  • 全文索引
  • 组合索引
  • 主键索引

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数据库进阶的更多相关文章

  1. Mysql数据库进阶之(分表分库,主从分离)

    前言:数据库的优化是一个程序员的分水岭,作为小白我也得去提前学习这方面的数据的 (一)  三范式和逆范式 听起范式这个迟非常专业我来举个简单的栗子: 第一范式就是:  把能够关联的每条数据都拆分成一个 ...

  2. Python操作Mysql数据库进阶篇——查询操作详解(一)

    前面我们已经介绍了在Python3.x中如何连接一个Mysql数据库,以及怎么样对这个数据库创建一个表,增删改查表里的数据.想必大家对Mysql数据库和简单的sql语句有了一定的了解,其实sql语句博 ...

  3. mysql数据库-进阶-长期维护

    ###############    视图    ############## """ 1.视图 视图:是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有 ...

  4. 数据库学习笔记(二)MySQL数据库进阶

    MySQL 进阶 关于连表 左右连表: join 上下连表: union #自动去重 (当两张表里的数据,有重复的才会自动去重) union all #不去重 #上下连表示例: select sid, ...

  5. mysql数据库进阶篇

    一.连表操作 1)为何需要连表操作 .把所有数据都存放于一张表的弊端 .表的组织结构复杂不清晰 .浪费空间 .扩展性极差 2)表设计,分析表与表之间的关系 寻找表与表之间的关系的套路 举例:emp表 ...

  6. MySQL第二讲 一一一一 MySQL语句进阶

    通过命令来备份数据库: 通过数据库软件里面的,mysqldump模块来操作,如下: mysqldump -u root db1 > db1.sql -p; //没有-d就是备份的时候:数据表结构 ...

  7. nodejs进阶(6)—连接MySQL数据库

    1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...

  8. Java进阶(二十五)Java连接mysql数据库(底层实现)

    Java进阶(二十五)Java连接mysql数据库(底层实现) 前言 很长时间没有系统的使用java做项目了.现在需要使用java完成一个实验,其中涉及到java连接数据库.让自己来写,记忆中已无从搜 ...

  9. Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁

    Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: ...

随机推荐

  1. php stripos()函数 语法

    php stripos()函数 语法 作用:寻找字符串中某字符最先出现的位置,不区分大小写.直线电参数 语法:stripos(string,find,start) 参数: 参数 描述 string  ...

  2. luoguP4721 【模板】分治 FFT (分治NTT)

    给定 $g[1....n-1]$,求 $f[0],f[1],...,f[n-1]$,其中   $f[i]=\sum_{j=1}^{i}f[i-j]g[j]$    变界为 $f[0]=1$ 答案模 9 ...

  3. jstl学习资料

    jstl印象中叫标准标签库,是apache的一个项目,网址为: Apache Taglibs - Apache Standard Taglib: JSP[tm] Standard Tag Librar ...

  4. VBox 启动虚拟机失败 - NtCreateFile(\Device\VBoxDrvStub)

    在Vbox(5.0.8 版本)启动Ubuntu的虚拟机时,遇到错误信息: NtCreateFile(\Device\VBoxDrvStub) failed: 0xc000000034 STATUS_O ...

  5. How to pass values across the pages in ASP.net without using Session

    https://stackoverflow.com/questions/14956027/how-to-pass-values-across-the-pages-in-asp-net-without- ...

  6. MySQL备份之XtraBackup工具使用

    数据库的完整备份 [root@vhost1 ~]# innobackupex --defaults-file=/mysqldata/3306/my.cnf  --user=root   --passw ...

  7. Log4j Threshold、Append

    报错ERROR日志单独存放 Threshold属性可以指定日志level Log4j根据日志信息的重要程度,分OFF.FATAL.ERROR.WARN.INFO.DEBUG.ALL 比如我们指定某个a ...

  8. HTML 浅层漫谈

    讲到HTML最主要的就是如何给这个网页搭架子给他大致的把这个人物样子先慢慢画出来,然后我们后面去学习这个CSS还有JS的时候给这个雏形慢慢的去加一些东西,让你的网页变得越来越好看 1.标签的使用 a: ...

  9. 127、TensorFlow 计算图执行(二)

    import tensorflow as tf # Define a placeholder that expects a vector of three floating-point values ...

  10. JS基础(下)

    事件DOM Event 更多事件请查询h3c  htmldom参考手册  event onclick() :当点击时 onfocus() :获得焦点时 :当点击某个区域时触发,如点击输入框 onblu ...