mysql 存储过程
发布时间:2025-05-13 20:34:43 发布人:远客网络
一、mysql 存储过程
1、使用default关键字设置时间的默认值,
2、建立一个存储过程向表中插入数据,这个需要用到参数,起始和一般的SQL语句是一样的,只不过进行了编译,并且使用了变量参数
3、create procedure insertIntoTable1(@name char(20),@pass char(40))
4、然后执行excecute insertIntoTable1'姓名1','密码1'
5、就可以了,因为id是自动增长的,regtime有了默认值,可以不为其指定具体的值,
二、为什么MySQL不建议使用存储过程mysql不建议存储过程
为什么MySQL不建议使用存储过程?
存储过程是一段可以被调用的SQL语句集合,可以实现复杂的业务逻辑和数据操作。然而,在MySQL中,存储过程并不是一种被广泛使用的数据处理方式,反而被建议避免使用。那么,为什么MySQL不建议使用存储过程呢?
存储过程需要在数据库中编写和存储,相比于应用程序的代码,存储过程的执行效率相对较低。这是因为存储过程的执行需要经过多次判断和查询,而且每次执行都需要从数据库中读取存储过程的定义。因此,如果存储过程的执行非常频繁,会给数据库带来较大的负担和性能瓶颈。
另外,存储过程的执行计划也可能得不到优化。数据库引擎在执行存储过程时,无法像对待普通SQL语句那样生成优化的查询计划,导致存储过程的执行效率较低。而且在存储过程中使用大量的代码也会导致性能降低。
存储过程的代码与应用程序代码不同,它们通常是在数据库端进行维护和升级。当业务逻辑发生变化时,需要修改存储过程的代码,并在数据库中重新定义。与应用程序相比,这种操作比较繁琐,可能导致维护困难。
此外,存储过程的修改也会对数据库的操作带来影响。新的存储过程可能需要重新编译和执行计划优化,这将占用数据库的大量资源,影响其它用户的操作。如果存储过程的代码出现严重的错误,可能会导致数据库服务的崩溃,影响应用程序的正常运行。
存储过程需要在数据库中定义和存储,这就意味着它们与数据库的权限和安全设置相关。如果存储过程的权限设置不当,可能会导致数据库的安全风险。例如,存储过程中可能包含敏感信息的读取和修改操作,如果存储过程的调用者权限设置不当,可能会发生数据泄露或操作不当的情况。
另外,存储过程也容易受到SQL注入的攻击。因为存储过程实际上是一种SQL语句集合,如果存储过程中存在SQL注入漏洞,攻击者可以直接调用存储过程获取或修改数据库中的数据,破坏数据库安全。
虽然存储过程具有一些优点,如能够减少网络传输、提高程序可重用性等,但在MySQL中,存储过程的使用并不被建议。除非应用场景需要使用存储过程,否则应该尽量避免使用。在实际开发过程中,可以通过其他方式来实现复杂的业务逻辑和数据操作,例如使用JOIN语句、视图等。这样既能保证程序的性能和可维护性,也能保障数据库的安全。
以下是一个简单的MySQL存储过程示例:
CREATE PROCEDURE GetCustomer(IN customerId INT, OUT customerName VARCHAR(50))
SELECT name INTO customerName FROM customers WHERE id= customerId;
三、mysql 存储过程总结(一)
存储过程是事先经过编译并存储在数据库中的一段 SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。存储过程思想上很简单,就是数据库 SQL语言层面的代码封装与重用。
封装,复用:可以把某一业务SQL封装在存储过程中,需要用到的时候直接调用即可。
可以接收参数,也可以返回数据:再存储过程中,可以传递参数,也可以接收返回值。
减少网络交互,效率提升:如果涉及到多条SQL,每执行一次都是一次网络传输。而如果封装在存储过程中,我们只需要网络交互一次可能就可以了。
注意:在命令行中,执行创建存储过程的SQL时,需要通过关键字 delimiter指定SQL语句的结束符。