视图:某个查询语句设置别名,日后方便使用
CREATE VIEW v1 as SELECT * FROM student WHERE sid >10
-创建:
create view 视图名称 as SQL
视图是虚拟的
-修改
alter view 视图名称 as SQL
-删除
drop view 视图名称
触发器:当对某张表做:增删改操作的时候,可以使用触发器自定义关联行为
# 插入前
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 t1 BEFORE INSERT on student for each ROW
BEGIN
INSERT into teacher(tname) VALUES('tim');
END //
delimiter ;
-- INSERT INTO student(gender,class_id,sname) VALUES('女',2,'多长'); # NEW 代指新数据,在两张表中插入同样的数据
# OLD 代指老数据 在两张表中删除和更新同样的数据
-- delimiter //
-- create TRIGGER t1 BEFORE INSERT on student for each ROW
-- BEGIN
-- INSERT into teacher(tname) VALUES(NEW.sname);
-- END //
-- delimiter ;
内置函数:
执行函数
-- SELECT CURDATE() #日期
-- SELECT CHAR_LENGTH('st') #字符串长度
-- SELECT CONCAT('tim','ttutu','ssl') #拼接
时间格式化:
SELECT DATE_FORMAT(date,format)
SELECT DATE_FORMAT('2009-10-04', '%W %M %Y');
自定义函数:
delimiter \\
create function f1(
i1 int,
i2 int)
returns int
BEGIN
declare num int;
set num = i1 + i2;
return(num);
END \\
delimiter ;
# 存储过程是一个SQL语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。
# 保存在MySQL上的一个别名---》一坨SQL语句 方式一:
Mysql:存储过程
程序:调用存储过程
方式二:
mysql:
程序:sql语句
方式三:
mysql
程序:类和对象(sql语句)
delimiter //
CREATE PROCEDURE p1()
BEGIN
SELECT * FROM student;
INSERT into teacher(tname) VALUES("ct");
END //
delimiter ;
call p1()
import pymysql
conn = pymysql.connect(host='127.0.0.1',user='root',password='',database='homework666',charset='utf8')
cursor = conn.cursor()
cursor.callproc('p1',(12,2))
conn.commit()
result = cursor.fetchall()
print(result)
cursor.close()
conn.close()
 1. 简单
create procedure p1()
BEGIN
select * from student;
INSERT into teacher(tname) values("ct");
END call p1()
cursor.callproc('p1')
2. 传参数(in,out,inout)
delimiter //
create procedure p2(
in n1 int,
in n2 int
)
BEGIN select * from student where sid > n1;
END //
delimiter ; call p2(12,2)
cursor.callproc('p2',(12,2))
3.参数out
delimiter //
create procedure p3(
in n1 int,
out n2 int
)
BEGIN set n2 = 123123;
select * from student where sid > n1;
END //
delimiter ;
set @v1=123;
call p3(12,@v1);
SELECT @v1;
import pymysql
conn = pymysql.connect(host='127.0.0.1',user='root',password='',database='homework666',charset='utf8')
cursor = conn.cursor()
cursor.callproc('p3',(12,2))
r1 = cursor.fetchall()
print(r1)
cursor.execute('select @_p3_0,@_p3_1')
r2 = cursor.fetchall()
print(r2)
cursor.close()
conn.close()
# 事务:
'''
delimiter \\
create PROCEDURE p5(
OUT p_return_code tinyint
)
BEGIN
DECLARE exit handler for sqlexception
BEGIN
-- ERROR
set p_return_code = 1;
rollback;
END; START TRANSACTION;
DELETE from tb1;
insert into tb2(name)values('seven');
COMMIT; -- SUCCESS
set p_return_code =2; END\\
delimiter ;
'''
# 游标
# 1、声明游标
# 2、获取A表中数据
# my_cursor select id,num form A
# 3、for row_id,row_num in my_cursor:
# 检测循环是否还有数据,如果无数据
# break
# insert into B(num) values(row_id+row_num)
'''
delimiter //
create procedure p6()
begin
declare row_id int; -- 自定义变量1
declare row_num int; -- 自定义变量2
DECLARE done INT DEFAULT FALSE;
declare temp int; DECLARE my_cursor CURSOR FOR select id,num from A;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE; open my_cursor;
xxoo: LOOP
fetch my_cursor into row_id,row_num;
if done then
leave xxoo;
END IF;
set temp = row_id+row_num;
insert into B(number) values(temp);
end loop xxoo;
close my_cursor;
end //
delimter; 执行:
call p6()
'''
# 动态执行SQL(防SQL注入)
'''伪代码
delimiter //
create procedure p7(
in tp1 varchar(225),
in arg int
)
begin
1.预检测某个东西 sql语句的合法性
2.格式化tpl + arg
3.执行SQL语句
set @xo =arg
PREPARE xxx FROM 'select * from student where sid > ?';
EXECUTE xxx USING @xo;
DEALLOCATE prepare prod;
end //
delimter;
call p7("select * from tb where id >?",9)
'''
'''真实代码
delimiter \\
CREATE PROCEDURE p8 (
in nid int
)
BEGIN
set @nid = nid;
PREPARE prod FROM 'select * from student where sid > ?';
EXECUTE prod USING @nid;
DEALLOCATE prepare prod;
END\\
delimiter ; '''

Python9-MySQL-MySQL存储过程-视图-触发器-函数-day45的更多相关文章

  1. MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称

    MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称   INFORMATION_SCHEMA.TABLES INFORMATION_SCHEMA. ...

  2. mysql 查询表,视图,触发器,函数,存储过程

    1. mysql查询所有表: SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '数据库名' AND  TAB ...

  3. MySQL笔记 存储过程 游标 触发器

    第二十三章 使用存储过程 MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成 存储过程简单来说,就 ...

  4. python 全栈开发,Day64(视图,触发器,函数,存储过程,事务)

    昨日内容回顾 pymysql:属于python的一个模块 pip3 install pymysql conn = pymysql.connect(...,charset = 'uft8') 创建游标 ...

  5. MySql的存储过程和触发器

    Mysql的存储过程是类似于其它编程语言中的函数的功能,存储过程内部可以使用顺序循环和转移三种基本程序结构,而且整个存储过程可以接受和返回参数. 创建存储过程(procedure)时,因为其内部有以; ...

  6. Mysql之存储过程与存储函数

    1 存储过程 1.1 什么是存储过程 存储过程是一组为了完成某项特定功能的sql语句集,其实质上就是一段存储在数据库中的代码,他可以由声明式的sql语句(如CREATE,UPDATE,SELECT等语 ...

  7. mysql 视图/触发器/函数

    一.视图 作用:简写代码,与临时表的作用差不多 .创建 create view 视图名 as SQL语句 .修改 alter view 视图名 as 新SQL语句 .删除 drop view 视图名 ...

  8. Database学习 - mysql 视图/触发器/函数

  9. 7.MySQL优化---存储过程和存储函数

    转自互联网. 当一个大型系统在建立时,会发现,很多的SQL操作是有重叠的,个别计算是相同的,比如:业务系统中,计算一张工单的计算方式.当遇到这些情况时,我们运用存储过程就是一个非常棒的优化啦.那么,什 ...

随机推荐

  1. pat1034. Head of a Gang (30)

    1034. Head of a Gang (30) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue One wa ...

  2. 《C#高效编程》读书笔记07-理解GetHashCode()的陷阱

    GetHashCode()函数仅会在一个地方用到,即为基于散列(hash)的集合定义的散列键时,此类集合包括HashSet和Dictionary<K,V>容器等. 但object基类提供的 ...

  3. 邓俊辉数据结构学习-8-2-B树

    B树 概述 动机: B树实现高速I/O 640K如何"满足"任何实际需求了-- 源自比尔·盖茨的一个笑话 前提知识 高速缓存 为什么高速缓存有效? 不同容量的存储器,访问速度差异悬 ...

  4. [Freemarker] Getting Start

    Freemarker是一个模板引擎,在.NET中有类似的T4模板,FreeMarker对ASP.NET MVC也很友好,链接地址,引用官方的一幅图 模板+数据=视图 Following are the ...

  5. OAuth相关知识

    什么是OAuth认证 1.一种安全认证的协议;2.协议为用户资源的授权提供了一个安全的.开放又简易的标准;3.OAuth的授权不会使第三方触及到用户的账户信息(例如用户名和密码) 网址:www.oau ...

  6. VUE打包发布后无法访问js、css资源

    在vue开发中,本地测试以及测试环境中都没有遇到问题,当发布生产,有虚拟路径时,便出现js.css均报错404: 首先在config的index.js文件中,将assetsPublicPath修改为' ...

  7. 零基础逆向工程29_Win32_03_ESP寻址_定位回调函数_子窗口_消息处理函数

    1 Win32应用程序入口识别 思路:根据WinMain的四个参数,由调用顺序,知道最后压栈的是hInstance句柄(也就是WinMain函数的第一个参数,其值等于ImageBase),根据反汇编, ...

  8. Winform 读取 指定\另一个\其他\任意 配置文件

    ExeConfigurationFileMap map = new ExeConfigurationFileMap();            map.ExeConfigFilename = @&qu ...

  9. windows安装ipython

    一.安装python2.71.下载地址https://www.python.org/downloads/2.安装后修改本地变量-右击电脑-属性-高级系统设置-环境变量-用户变量-新建-变量名:path ...

  10. es6 随笔

    记录一些学习es6中学习的新特性,挺有用,作为日后复习es6用,便于记忆. 1.变量定义let和const es6用let.const代替,let是定义块级作用域中的变量,const声明之后必须赋值, ...