Python学习日记(四十) Mysql数据库篇 八

时间:2021-12-04 04:43:23

Mysql存储过程

存储过程是保存在Mysql上的一个别名(就是一堆SQL语句),使用别名就可以查到结果不用再去写SQL语句。存储过程用于替代程序员写SQL语句。

创建存储过程

delimiter //
CREATE PROCEDURE p1()
BEGIN
    SELECT * FROM studenttable;
    INSERT INTO teachertable(tname) VALUES(陈晨);
END //
delimiter ;

当我们写完这段代码并执行,再去调用p1()就可以直接执行里面的查询

call p1();

执行结果:

Python学习日记(四十) Mysql数据库篇 八

这样的好处能让功能代码都整合到一块且不用再去写SQL语句,不好之处在于如果要改数据库中的资料,那不一定能从存储过程中能拿到数据。

在公司处理数据时选用的方式:

方式一:

  Mysql(DBA):存储过程

  程序(程序员):调用存储过程

方式二:

  Mysql:什么都不做

  程序:写SQL语句

方式三:

  Mysql:什么都不做

  程序:类和对象(本质就是SQL语句 )

通过Python中的pymysql模块拿到p1的数据:

import pymysql
conn = pymysql.connect(host = localhost,user = root,password = ‘‘,database = db2,charset = utf8)
cursor = conn.cursor()
cursor.callproc(p1)
conn.commit()
result = cursor.fetchall()
print(result)
cursor.close()
conn.close()

传参数的存储过程

参数(in,out,inout)

delimiter //
CREATE PROCEDURE p2(
    IN pid INT,
    IN pnumber INT
)
BEGIN
    SELECT * FROM scoretable WHERE student_id > pid AND number > pnumber;
END //
delimiter ;

呼叫执行过程p2并带入参数

call p2(15,90);

这样就能找到大于学生ID15并且分数大于90 的学生成绩

 

......