广告
返回顶部
首页 > 资讯 > 数据库 >Mysql中自定义函数的创建和执行方法是什么
  • 806
分享到

Mysql中自定义函数的创建和执行方法是什么

mysql 2023-03-13 11:03:43 806人浏览 安东尼
摘要

本文小编为大家详细介绍“Mysql中自定义函数的创建和执行方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql中自定义函数的创建和执行方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢

本文小编为大家详细介绍“Mysql中自定义函数的创建和执行方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql中自定义函数的创建和执行方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    Mysql自定义函数的创建和执行

    假设students表中包含id和name两个字段,创建一个函数,函数的作用是根据id查找name

    1.创建表,插入数据

    create table students(id int,name varchar(100));
    insert into students(id,name) values(1,'annie'),(2,'bell'),(3,'danny');

    2.创建函数

    DELIMITER //
    create function find_student(id int) returns varchar(100)
    READS SQL DATA
    begin
        declare sname varchar(100) default '';
        select students.name into sname from students where students.id=id;
        return sname;
    end //
    DELIMITER ;

    需要注意的事项:

    1)使用DELIMITER//修改分隔符

    mysql的默认语句结束符号是分号,当mysql遇到分号时就自动执行当前语句。因为函数定义时包含多条sql语句,所以使用DELIMITER //先将分隔符设置为//,等函数创建语句完成后,再将分隔符改回分号即可。

    2)READS SQL DATA

    之前我没写这句话,但是创建时mysql报错,提示Error Code: 1418. This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you might want to use the less safe log_bin_trust_function_creators variable)

    上网查了一下,意思是没有声明mysql函数的类型:

    mysql开启了bin-log, 我们就必须指定我们的函数是否是哪种类型:

    • 1 DETERMINISTIC 不确定的

    • 2 NO SQL 没有SQl语句,当然也不会修改数据

    • 3 READS SQL DATA 只是读取数据,当然也不会修改数据

    • 4 MODIFIES SQL DATA 要修改数据

    • 5 CONTaiNS SQL 包含了SQL语句

    • 所以我加上了READS SQL DATA

    3)使用局部变量

    变量定义:我这里使用declare sname varchar(100) default ‘’;定义了局部变量sname,

    变量使用:

    可以使用select students.name into sname from students where students.id=id;为变量赋值

    也可以直接使用set语句来赋值,如set sname=‘test’

    3.执行函数:select 函数名(参数值);

    select find_student(3);

    Mysql自定义函数创建失败问题

    案例

    目前在项目中,执行创建mysql的函数出错,

    mysql 创建函数出错信息如下:

    Caused by: java.sql.SQLException: This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)
        at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:965)
        at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3976)
        at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3912)
        at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:871)
        at com.mysql.jdbc.MysqlIO.readAllResults(MysqlIO.java:2373)
        at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2739)
        at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2482)
        at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2440)
        at com.mysql.jdbc.StatementImpl.executeInternal(StatementImpl.java:845)
        at com.mysql.jdbc.StatementImpl.execute(StatementImpl.java:745)
        ... 35 more

    这是因为有一个安全参数没有开启,log_bin_trust_function_creators 默认为0,是不允许function的同步的,开启这个参数,就可以创建成功了。

    查看是否开启:

    show variables like '%func%';
    +---------------------------------+-------+ 
    | Variable_name     | Value | 
    +---------------------------------+-------+ 
    | log_bin_trust_function_creators | ON | 
    +---------------------------------+-------+ 
    1 row in set (0.00 sec)

    为on则是开启了

    set global log_bin_trust_function_creators = 1;

    可以通过这个命令设置,但是MySQL重启后就失效了。

    所有最后是通过修改MySQL数据库的配置文件

    在配置文件/etc/my.cnf的[mysqld]配置log_bin_trust_function_creators=1

    Mysql中自定义函数的创建和执行方法是什么

    修改完后重启MySQL。

    读到这里,这篇“Mysql中自定义函数的创建和执行方法是什么”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网数据库频道。

    您可能感兴趣的文档:

    --结束END--

    本文标题: Mysql中自定义函数的创建和执行方法是什么

    本文链接: https://www.lsjlt.com/news/199533.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Mysql中自定义函数的创建和执行方法是什么
      本文小编为大家详细介绍“Mysql中自定义函数的创建和执行方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql中自定义函数的创建和执行方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢...
      99+
      2023-03-13
      mysql
    • Mysql中自定义函数的创建和执行方式
      目录mysql自定义函数的创建和执行1.创建表,插入数据2.创建函数3.执行函数:select 函数名(参数值);Mysql自定义函数创建失败问题案例总结Mysql自定义函数的创建和执行 假设students表...
      99+
      2023-03-10
      Mysql自定义函数 自定义函数创建 自定义函数执行
    • mysql自定义函数的方法是什么
      在MySQL中,可以使用以下步骤来创建自定义函数:1. 创建函数:使用`CREATE FUNCTION`语句来创建函数,并指定函数的...
      99+
      2023-09-11
      mysql
    • MySQL系统和自定义函数、触发器的使用方法是什么
      这篇文章主要讲解了“MySQL系统和自定义函数、触发器的使用方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL系统和自定义函数、触发器的使用...
      99+
      2022-10-18
    • python中函数的定义方法是什么
      在Python中,函数的定义方法如下:```pythondef function_name(parameters):# 函数体# 可...
      99+
      2023-09-13
      python
    • Python catplot函数自定义颜色的方法是什么
      一、catplot函数catplot() 函数是 Seaborn 中一个非常有用的函数,它可以绘制分类变量的图形,并可以根据另一个或多个变量进行分组。使用不同的图表类型,catplot() 函数可以创建适当的图表。默认情况下,catplot...
      99+
      2023-05-18
      Python
    • 在Linux中创建自定义脚本和创建systemd服务单元文件的方法是什么
      今天就跟大家聊聊有关在Linux中创建自定义脚本和创建systemd服务单元文件的方法是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。前言systemd是Linux操作系统的系统...
      99+
      2023-06-26
    • mysql自定义字段的方法是什么
      在MySQL中,可以通过以下两种方法来自定义字段:1. 使用计算字段:- 计算字段是使用表中已有字段计算出来的结果。可以使用算术运算...
      99+
      2023-09-25
      mysql
    • 微信小程序自定义函数的方法是什么
      在微信小程序中,可以通过以下方法自定义函数:1. 在`app.js`中定义全局函数:可以在`App`函数中定义全局函数,这样在整个小...
      99+
      2023-09-29
      微信小程序
    • Flutter构建自定义Widgets的方法是什么
      这篇文章主要讲解了“Flutter构建自定义Widgets的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Flutter构建自定义Widgets的方法是什么”吧!一.组合widge...
      99+
      2023-06-26
    • MySQL创建定时任务的方法是什么
      今天小编给大家分享一下MySQL创建定时任务的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来...
      99+
      2023-03-06
      mysql
    • c语言中函数的定义方法是什么
      在C语言中,函数的定义通常包含以下几个部分:1. 返回类型:函数可以有不同的返回类型,如int、float、void等,用来表示函数...
      99+
      2023-09-29
      c语言
    • mongodb外部执行创建用户的方法是什么
      在 MongoDB 中,可以使用以下方法来外部执行创建用户的操作:1. 使用 MongoDB 的官方 shell(mongo she...
      99+
      2023-08-23
      mongodb
    • mysql中创建数据库的方法是什么
      这篇文章给大家分享的是有关mysql中创建数据库的方法是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。 数据库可以看作是一个专门存储数据对象的容器,这里的数据对象包...
      99+
      2022-10-18
    • MySQL创建数据表的方法是什么
      MySQL创建数据表的方法有两种:手动创建和使用SQL语句创建。1. 手动创建:可以通过MySQL的图形界面工具,如phpMyAdm...
      99+
      2023-10-20
      MySQL
    • matlab定义函数并调用的方法是什么
      在MATLAB中,可以使用function关键字来定义函数,然后通过函数名来调用该函数。以下是定义和调用函数的一般方法:1. 定义函...
      99+
      2023-10-09
      matlab
    • shell函数定义与调用的方法是什么
      在Shell中,可以使用以下方法来定义和调用函数:1. 定义函数:```function_name() {# 函数体# 可以在函数体...
      99+
      2023-09-22
      shell
    • javascript中自定义函数方法的代码怎么写
      这篇文章主要介绍了javascript中自定义函数方法的代码怎么写的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇javascript中自定义函数方法的代码怎么写文章都会有所收获...
      99+
      2022-10-19
    • python计算函数执行时长的方法是什么
      本篇内容主要讲解“python计算函数执行时长的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python计算函数执行时长的方法是什么”吧!python开发,有时需要做性能分析及性能优...
      99+
      2023-07-06
    • C语言函数分类自定义参数及调用方法是什么
      本篇内容主要讲解“C语言函数分类自定义参数及调用方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言函数分类自定义参数及调用方法是什么”吧!1.  函数是什么?提到函数,我们...
      99+
      2023-06-21
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作