mysql数据库第三弹
mysql数据库知识拓展
视图
视图是一个虚拟表(非真实存在),其本质是【根据SQL语句获取动态的数据集,并为其命名】,用户使用时只需使用【名称】即可获取结果集,并可以将其当作表来使用。
- SELECT
- *
- FROM
- (
- SELECT
- nid,
- NAME
- FROM
- tb1
- WHERE
- nid > 2
- ) AS A
- WHERE
- A. NAME > 'alex';
临时表搜索
1、创建视图
- --格式:CREATE VIEW 视图名称 AS SQL语句
- CREATE VIEW v1 AS
- SELET nid,
- name
- FROM
- A
- WHERE
- nid > 4
2、删除视图
- --格式:DROP VIEW 视图名称
- DROP VIEW v1
3、修改视图
- -- 格式:ALTER VIEW 视图名称 AS SQL语句
- ALTER VIEW v1 AS
- SELET A.nid,
- B. NAME
- FROM
- A
- LEFT JOIN B ON A.id = B.nid
- LEFT JOIN C ON A.id = C.nid
- WHERE
- A.id > 2
- AND C.nid < 5
4、使用视图
使用视图时,将其当作表进行操作即可,由于视图是虚拟表,所以无法使用其对真实表进行创建、更新和删除操作,仅能做查询用。
- select * from v1
触发器
对某个表进行【增/删/改】操作的前后如果希望触发某个特定的行为时,可以使用触发器,触发器用于定制用户对表的行进行【增/删/改】前后的行为。
1、创建基本语法
- # 插入前
- CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROW
- BEGIN
- ...
- END
- # 插入后
- CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROW
- BEGIN
- ...
- END
- # 删除前
- CREATE TRIGGER tri_before_delete_tb1 BEFORE DELETE ON tb1 FOR EACH ROW
- BEGIN
- ...
- END
- # 删除后
- CREATE TRIGGER tri_after_delete_tb1 AFTER DELETE ON tb1 FOR EACH ROW
- BEGIN
- ...
- END
- # 更新前
- CREATE TRIGGER tri_before_update_tb1 BEFORE UPDATE ON tb1 FOR EACH ROW
- BEGIN
- ...
- END
- # 更新后
- CREATE TRIGGER tri_after_update_tb1 AFTER UPDATE ON tb1 FOR EACH ROW
- BEGIN
- ...
- END
- delimiter //
- CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROW
- BEGIN
- IF NEW. NAME == 'alex' THEN
- INSERT INTO tb2 (NAME)
- VALUES
- ('aa')
- END
- END//
- delimiter ;
插入前触发器
- delimiter //
- CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROW
- BEGIN
- IF NEW. num = 666 THEN
- INSERT INTO tb2 (NAME)
- VALUES
- (''),
- ('') ;
- ELSEIF NEW. num = 555 THEN
- INSERT INTO tb2 (NAME)
- VALUES
- (''),
- ('') ;
- END IF;
- END//
- delimiter ;
插入后触发器
特别的:NEW表示即将插入的数据行,OLD表示即将删除的数据行。
2、删除触发器
- DROP TRIGGER tri_after_insert_tb1;
3、使用触发器
触发器无法由用户直接调用,而知由于对表的【增/删/改】操作被动引发的。
- insert into tb1(num) values(666)
存储过程
存储过程是一个SQL语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。
1、创建存储过程
- -- 创建存储过程
- delimiter //
- create procedure p1()
- BEGIN
- select * from t1;
- END//
- delimiter ;
- -- 执行存储过程
- call p1()
无参数存储过程
对于存储过程,可以接收参数,其参数有三类:
- in 仅用于传入参数用
- out 仅用于返回值用
- inout 既可以传入又可以当作返回值
- -- 创建存储过程
- delimiter \\
- create procedure p1(
- in i1 int,
- in i2 int,
- inout i3 int,
- out r1 int
- )
- BEGIN
- DECLARE temp1 int;
- DECLARE temp2 int default 0;
- set temp1 = 1;
- set r1 = i1 + i2 + temp1 + temp2;
- set i3 = i3 + 100;
- end\\
- delimiter ;
- -- 执行存储过程
- DECLARE @t1 INT default 3;
- DECLARE @t2 INT;
- CALL p1 (1, 2 ,@t1, @t2);
- SELECT @t1,@t2;
有参数存储过程
2、删除存储过程
- drop procedure proc_name;
3、执行存储过程
- -- 无参数
- call proc_name()
- -- 有参数,全in
- call proc_name(1,2)
- -- 有参数,有in,out,inout
- DECLARE @t1 INT;
- DECLARE @t2 INT default 3;
- call proc_name(1,2,@t1,@t2)
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import pymysql
- conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='', db='t1')
- cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
- # 执行存储过程
- cursor.callproc('p1', args=(1, 22, 3, 4))
- # 获取执行完存储的参数
- cursor.execute("select @_p1_0,@_p1_1,@_p1_2,@_p1_3")
- result = cursor.fetchall()
- conn.commit()
- cursor.close()
- conn.close()
- print(result)
pymysql执行存储过程
函数
MySQL中提供了许多内置函数,例如:
- CHAR_LENGTH(str)
- 返回值为字符串str 的长度,长度的单位为字符。一个多字节字符算作一个单字符。
- 对于一个包含五个二字节字符集, LENGTH()返回值为 10, 而CHAR_LENGTH()的返回值为5。
- CONCAT(str1,str2,...)
- 字符串拼接
- 如有任何一个参数为NULL ,则返回值为 NULL。
- CONCAT_WS(separator,str1,str2,...)
- 字符串拼接(自定义连接符)
- CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。
- CONV(N,from_base,to_base)
- 进制转换
- 例如:
- SELECT CONV('a',16,2); 表示将 a 由16进制转换为2进制字符串表示
- FORMAT(X,D)
- 将数字X 的格式写为'#,###,###.##',以四舍五入的方式保留小数点后 D 位, 并将结果以字符串的形式返回。若 D 为 0, 则返回结果不带有小数点,或不含小数部分。
- 例如:
- SELECT FORMAT(12332.1,4); 结果为: '12,332.1000'
- INSERT(str,pos,len,newstr)
- 在str的指定位置插入字符串
- pos:要替换位置其实位置
- len:替换的长度
- newstr:新字符串
- 特别的:
- 如果pos超过原字符串长度,则返回原字符串
- 如果len超过原字符串长度,则由新字符串完全替换
- INSTR(str,substr)
- 返回字符串 str 中子字符串的第一个出现位置。
- LEFT(str,len)
- 返回字符串str 从开始的len位置的子序列字符。
- LOWER(str)
- 变小写
- UPPER(str)
- 变大写
- LTRIM(str)
- 返回字符串 str ,其引导空格字符被删除。
- RTRIM(str)
- 返回字符串 str ,结尾空格字符被删去。
- SUBSTRING(str,pos,len)
- 获取字符串子序列
- LOCATE(substr,str,pos)
- 获取子序列索引位置
- REPEAT(str,count)
- 返回一个由重复的字符串str 组成的字符串,字符串str的数目等于count 。
- 若 count <= 0,则返回一个空字符串。
- 若str 或 count 为 NULL,则返回 NULL 。
- REPLACE(str,from_str,to_str)
- 返回字符串str 以及所有被字符串to_str替代的字符串from_str 。
- REVERSE(str)
- 返回字符串 str ,顺序和字符顺序相反。
- RIGHT(str,len)
- 从字符串str 开始,返回从后边开始len个字符组成的子序列
- SPACE(N)
- 返回一个由N空格组成的字符串。
- SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)
- 不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式为标准 SQL 语法。也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。在以下格式的函数中可以对pos 使用一个负值。
- mysql> SELECT SUBSTRING('Quadratically',5);
- -> 'ratically'
- mysql> SELECT SUBSTRING('foobarbar' FROM 4);
- -> 'barbar'
- mysql> SELECT SUBSTRING('Quadratically',5,6);
- -> 'ratica'
- mysql> SELECT SUBSTRING('Sakila', -3);
- -> 'ila'
- mysql> SELECT SUBSTRING('Sakila', -5, 3);
- -> 'aki'
- mysql> SELECT SUBSTRING('Sakila' FROM -4 FOR 2);
- -> 'ki'
- TRIM([{BOTH | LEADING | TRAILING} [remstr] FROM] str) TRIM(remstr FROM] str)
- 返回字符串 str , 其中所有remstr 前缀和/或后缀都已被删除。若分类符BOTH、LEADIN或TRAILING中没有一个是给定的,则假设为BOTH 。 remstr 为可选项,在未指定情况下,可删除空格。
- mysql> SELECT TRIM(' bar ');
- -> 'bar'
- mysql> SELECT TRIM(LEADING 'x' FROM 'xxxbarxxx');
- -> 'barxxx'
- mysql> SELECT TRIM(BOTH 'x' FROM 'xxxbarxxx');
- -> 'bar'
- mysql> SELECT TRIM(TRAILING 'xyz' FROM 'barxxyz');
- -> 'barx'
部分内置函数
1、自定义函数
- delimiter \\
- create function f1(
- i1 int,
- i2 int)
- returns int
- BEGIN
- declare num int;
- set num = i1 + i2;
- return(num);
- END \\
- delimiter ;
2、删除函数
- drop function func_name;
3、执行函数
- # 获取返回值
- declare @i VARCHAR(32);
- select UPPER('alex') into @i;
- SELECT @i;
- # 在查询中使用
- select f1(11,nid) ,name from tb2;
事务
事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性。
- delimiter \\
- create PROCEDURE p1(
- OUT p_return_code tinyint
- )
- BEGIN
- DECLARE exit handler for sqlexception
- BEGIN
- -- ERROR
- set p_return_code = 1;
- rollback;
- END;
- DECLARE exit handler for sqlwarning
- BEGIN
- -- WARNING
- set p_return_code = 2;
- rollback;
- END;
- START TRANSACTION;
- DELETE from tb1;
- insert into tb2(name)values('seven');
- COMMIT;
- -- SUCCESS
- set p_return_code = 0;
- END\\
- delimiter ;
支持事务的存储过程
- DECLARE @i TINYINT;
- call p1(@i);
- select @i;
执行存储过程
索引
索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构。类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获取即可。
MySQL中常见索引有:
- 普通索引
- 唯一索引
- 主键索引
- 组合索引
1、普通索引
普通索引仅有一个功能:加速查询
- create table in1(
- nid int not null auto_increment primary key,
- name varchar(32) not null,
- email varchar(64) not null,
- extra text,
- index ix_name (name)
- )
创建表 + 索引
- create index index_name on table_name(column_name)
创建索引
- drop index_name on table_name;
删除索引
- show index from table_name;
查看索引
注意:对于创建索引时如果是BLOB 和 TEXT 类型,必须指定length。
- create index ix_extra on in1(extra(32));
2、唯一索引
唯一索引有两个功能:加速查询 和 唯一约束(可含null)
- create table in1(
- nid int not null auto_increment primary key,
- name varchar(32) not null,
- email varchar(64) not null,
- extra text,
- unique ix_name (name)
- )
创建表 + 唯一索引
- create unique index 索引名 on 表名(列名)
创建唯一索引
- drop unique index 索引名 on 表名
删除唯一索引
3、主键索引
主键有两个功能:加速查询 和 唯一约束(不可含null)
- create table in1(
- nid int not null auto_increment primary key,
- name varchar(32) not null,
- email varchar(64) not null,
- extra text,
- index ix_name (name)
- )
- OR
- create table in1(
- nid int not null auto_increment,
- name varchar(32) not null,
- email varchar(64) not null,
- extra text,
- primary key(ni1),
- index ix_name (name)
- )
创建表 + 创建主键
- alter table 表名 add primary key(列名);
创建主键
- alter table 表名 drop primary key;
- alter table 表名 modify 列名 int, drop primary key;
删除主键
4、组合索引
组合索引是将n个列组合成一个索引
其应用场景为:频繁的同时使用n列来进行查询,如:where n1 = 'alex' and n2 = 666。
- create table in3(
- nid int not null auto_increment primary key,
- name varchar(32) not null,
- email varchar(64) not null,
- extra text
- )
创建表
- create index ix_name_email on in3(name,email);
创建组合索引
如上创建组合索引之后,查询:
- name and email -- 使用索引
- name -- 使用索引
- email -- 不使用索引
注意:对于同时搜索n个条件时,组合索引的性能好于多个单一索引合并。
其他
1、条件语句
- delimiter \\
- CREATE PROCEDURE proc_if ()
- BEGIN
- declare i int default 0;
- if i = 1 THEN
- SELECT 1;
- ELSEIF i = 2 THEN
- SELECT 2;
- ELSE
- SELECT 7;
- END IF;
- END\\
- delimiter ;
if条件语句
2、循环语句
- delimiter \\
- CREATE PROCEDURE proc_while ()
- BEGIN
- DECLARE num INT ;
- SET num = 0 ;
- WHILE num < 10 DO
- SELECT
- num ;
- SET num = num + 1 ;
- END WHILE ;
- END\\
- delimiter ;
while循环
- delimiter \\
- CREATE PROCEDURE proc_repeat ()
- BEGIN
- DECLARE i INT ;
- SET i = 0 ;
- repeat
- select i;
- set i = i + 1;
- until i >= 5
- end repeat;
- END\\
- delimiter ;
repeat循环
- delimiter \\
- CREATE PROCEDURE proc_loop ()
- BEGIN
- declare i int default 0;
- loop_label: loop
- select i;
- set i=i+1;
- if i>=5 then
- leave loop_label;
- end if;
- end loop;
- END\\
- delimiter ;
loop
3、动态执行SQL语句
- delimiter \\
- DROP PROCEDURE IF EXISTS proc_sql \\
- CREATE PROCEDURE proc_sql ()
- BEGIN
- declare p1 int;
- set p1 = 11;
- set @p1 = p1;
- PREPARE prod FROM 'select * from tb2 where nid > ?';
- EXECUTE prod USING @p1;
- DEALLOCATE prepare prod;
- END\\
- delimiter ;
动态执行SQL
mysql数据库第三弹的更多相关文章
- PHP连接MySQL数据库的三种方式(mysql、mysqli、pdo)
PHP与MySQL的连接有三种API接口,分别是:PHP的MySQL扩展 .PHP的mysqli扩展 .PHP数据对象(PDO) ,下面针对以上三种连接方式做下总结,以备在不同场景下选出最优方案. P ...
- python操作MySQL数据库的三个模块
python使用MySQL主要有两个模块,pymysql(MySQLdb)和SQLAchemy. pymysql(MySQLdb)为原生模块,直接执行sql语句,其中pymysql模块支持python ...
- php连接MySQL数据库的三种方式(mysql/mysqli/pdo)
引言 PHP与MySQL的连接有三种API接口,分别是:PHP的MySQL扩展 .PHP的mysqli扩展 .PHP数据对象(PDO) ,下面针对以上三种连接方式做下总结,以备在不同场景下选出最优方案 ...
- Python操作MySQL数据库的三种方法
https://blog.csdn.net/Oscer2016/article/details/70257024 1. MySQLdb 的使用 (1) 什么是MySQLdb? MySQLdb 是用 ...
- Mysql数据库(三)Mysql表结构管理
一.MySQL数据类型 1.数字类型 (1)整数数据类型包括TINYINT/BIT/BOOL/SMALLINT/MEDIUMINT/INT/BIGINT (2)浮点数据类型包括FLOAT/DOUBLE ...
- MySQL数据库笔记三:数据查询语言(DQL)与事务控制语言(TCL)
五.数据查询语言(DQL) (重中之重) 完整语法格式: select 表达式1|字段,.... [from 表名 where 条件] [group by 列名] [having 条件] [order ...
- 【数据库】MySQL数据库(三)
一.MySQL当中的索引: 数组当中我们见过索引:它的好处就是能够快速的通过下标.索引将一个信息查到:或者说 能够快速的定位到一个信息: 1.MySQL中的索引是什么? 它是将我们表中具有索引的那个字 ...
- MySQL数据库学习三 数据库对象和基本操作
3.1 数据库和数据对象 1. 系统数据库 information_schema:主要存储系统中的一些数据库对象信息,如用户列表信息.列信息.权限信息.字符集信息和分区信息等. performance ...
- mysql数据库的三范式的设计与理解
一般的数据库设计都需要满足三范式,这是最基本的要求的,最高达到6NF,但是一般情况下3NF达到了就可以 一:1NF一范式的理解: 1NF是关系型数据库中的最基本要求,就是要求记录的属性是原子性,不可分 ...
随机推荐
- Levenshtein Distance + LCS 算法计算两个字符串的相似度
//LD最短编辑路径算法 public static int LevenshteinDistance(string source, string target) { int cell = source ...
- js系列教程1-数组操作全解
全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...
- cocos2dx - v2.3.3编辑器简单使用及不同分辨率适配
准备工具 Cocos 引擎当前最新版本:v2.3.3 官网下载地址: http://www.cocos.com/download/ 前述:cocos自带UI编辑器在最新的版本有了很大的改动 ...
- banner幻灯片
emmm本来想用js写的,但是感觉难就换了jquery. 1.把图片的位置.透明度.宽高.z-index信息用数组datas保存起来,移动的时候直接把位置等信息赋值给li. 2.点击next,即显示下 ...
- web前端开发初学者必看的学习路线(附思维导图)
很多同学想学习WEB前端开发,虽然互联网有很多的教程.网站.书籍,可是却又不知从何开始如何选取.看完网友高等游民白乌鸦无私分享的原标题为<写给同事的前端学习路线>这篇文章,相信你会有所收获 ...
- SpringMVC + Spring + Mybatis+ Redis +shiro以及MyBatis学习
SpringMVC + Spring + Mybatis+ Redis +shiro http://www.sojson.com/shiro MyBatis简介与配置MyBatis+Spring+My ...
- 使用bitset实现毫秒级查询
前言 因为业务要求api的一次请求响应时间在10ms以内,所以传统的数据库查询操作直接被排除(网络io和磁盘io).通过调研,最终使用了bieset,目前已经正常运行了很久 *** bitset介绍 ...
- js 短信倒计时60s
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JPA 映射单向多对一的关联关系
1.首先在多的一端加入一的一端的实体类 //映射单向n-1的关联关 //使用@ManyToOne 来映射多对一的关系 //使用@JoinColumn 来映射外键/可以使用@ManyToOne的fetc ...
- Selenium Grid分布式测试入门详解
本文对Selenium Grid进行了完整的介绍,从环境准备到使用Selenium Grid进行一次完整的多节点分布式测试. 运行环境为Windows 10,Selenium版本为 3.5.0,Chr ...