mysql 存储过程 执行报错 我创建了一个简单的存储过程,成功了,但是在call执行调用的时候怎么老是报错呢?

mysql 存储过程 执行报错 我创建了一个简单的存储过程,成功了,但是在call执行调用的时候怎么老是报错呢?,第1张

create procedure proprice() is

begin

select avg(price) as average from products

end

以上就是规范的格式,请不要添加额外的东西,执行之后调用即可。

如果有其他问题,你可以先百度一下存储过程的规范应用

1. 准备工作

在开始之前,请确保已经安装好了MySQL数据库并保证它能正常运行,而且需要安装好PyMySQL库。

2. 连接数据库

这里,首先尝试连接一下数据库。假设当前的MySQL运行在本地,用户名为root,密码为123456,运行端口为3306。这里利用PyMySQL先连接MySQL,然后创建一个新的数据库,名字叫作spiders,代码如下:

import pymysql

db = pymysql.connect(host='localhost',user='root', password='123456', port=3306)

cursor = db.cursor()

cursor.execute('SELECT VERSION()')

data = cursor.fetchone()

print('Database version:', data)

cursor.execute("CREATE DATABASE spiders DEFAULT CHARACTER SET utf8")

db.close()

运行结果如下:

Database version: ('5.6.22',)

这里通过PyMySQL的connect()方法声明一个MySQL连接对象db,此时需要传入MySQL运行的host(即IP)。由于MySQL在本地运行,所以传入的是localhost。如果MySQL在远程运行,则传入其公网IP地址。后续的参数user即用户名,password即密码,port即端口(默认为3306)。

连接成功后,需要再调用cursor()方法获得MySQL的 *** 作游标,利用游标来执行SQL语句。这里我们执行了两句SQL,直接用execute()方法执行即可。第一句SQL用于获得MySQL的当前版本,然后调用fetchone()方法获得第一条数据,也就得到了版本号。第二句SQL执行创建数据库的 *** 作,数据库名叫作spiders,默认编码为UTF-8。由于该语句不是查询语句,所以直接执行后就成功创建了数据库spiders。接着,再利用这个数据库进行后续的 *** 作。

3. 创建表

一般来说,创建数据库的 *** 作只需要执行一次就好了。当然,我们也可以手动创建数据库。以后,我们的 *** 作都在spiders数据库上执行。

创建数据库后,在连接时需要额外指定一个参数db。

这个写一个触发器不更好么?

create trigger 触发器名 after insert on 表A for each row

begin

update 表B set 字段=XXX where 条件

end


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7675439.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-08
下一篇 2023-04-08

发表评论

登录后才能评论

评论列表(0条)

保存