zoukankan      html  css  js  c++  java
  • mysql创建自定义函数与存储过程

    mysql创建自定义函数与存储过程

    一 创建自定义函数
      在使用mysql的过程中,mysql自带的函数可能不能完成我们的业务需求,这时就需要自定义函数,例如笔者在开发过程中遇到下面这个问题

    mysql表结构如下

     
    DROP TABLE IF EXISTS `test`;
    CREATE TABLE `test` (
      `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
      `pic` varchar(50) NOT NULL,
      `hashcode` varchar(16) NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
    -- ----------------------------
    -- Records of test
    -- ----------------------------
    INSERT INTO `test` VALUES ('1', '2012120910403250c3fa209bf48.jpg', 'bf8f83818080c0f1');
    INSERT INTO `test` VALUES ('2', '2012120620430750c092db26557.JPG', 'ff9880f0f680ceff');
    INSERT INTO `test` VALUES ('3', '2012120619582550c08861eb062.jpg', '7f7f004f7f7f7c7f');
    INSERT INTO `test` VALUES ('4', '2012112911072650b6d16e7f21f.jpg', '7f7f004f7f7f007f');

      其中

      pic字段为图片名称,

      hashcode是图片的感知哈希编码(16进制编码字符串,长度固定16位),

      用户输入一个hashcode,怎么从数据库中找出满足字符串对应位置的字符不同的个数小于5的记录呢?

      就像“11001”和“11101”对应位置不同字符不同的个数为1,

      比如 用户输入"7f7f004f7f7f00af",那么第三条和第四条记录是满足的,怎么实现呢?

      如果单纯的依靠mysql自带的函数很难完成,这时就需要建立自定义函数解决。

      这个问题的解决在此非常感谢csdn的acmain_chm,acmain_chm以及oschina的@梁小刚,还有@淘宝丁奇

    建立自定义函数的过程如下:
    1.进入mysql命令行

    mysql>

    2.用delimiter命令来把语句定界符从 ;变为//。这样就允许在程序体用;定界符传递到服务器,而不是被mysql自己来解释。

    mysql> delimiter //

    3.创建自定义函数

    CREATE FUNCTION hashDiff( s1 varchar(16), s2 varchar(16)) 
     RETURNS INT
     BEGIN
     DECLARE diff, x INT;
     SET diff =0;
     SET x = 0;
     WHILE (x  < 16 )  DO
        SET x = x+1;
        if SUBSTRING(s1, x,1)<>SUBSTRING(s2, x,1) then
            set diff=diff+ 1;
        end if;
     END WHILE;
     RETURN diff;
     END
     //

    二 创建存储过程

    1.进入mysql命令行

    mysql>

    2.用delimiter命令来把语句定界符从 ;变为//。这样就允许在程序体用;定界符传递到服务器,而不是被mysql自己来解释。

    mysql> delimiter //

    3.创建存储过程

    DELIMITER $$
        CREATE PROCEDURE `GetStocks`(int_stockcode  int)
        BEGIN
         SELECT COUNT(*) into  FROM  test;
        END $$
    DELIMITER ;
    
     
    CALL GetStocks(@a);
  • 相关阅读:
    YOLOV2相对于YOLOV1的改进
    在训练过程中loss出现NaN的原因以及可以采取的方法
    出现梯度消失和梯度爆炸的原因及解决方案
    Batch Normalization 原理
    几种激活函数的对比(二)
    几种激活函数对比(一)
    Leetcode 830. Positions of Large Groups
    Leetcode 985. Sum of Even Numbers After Queries
    python中的赋值与拷贝(浅拷贝与深拷贝)
    Leetcode 665. Non-decreasing Array
  • 原文地址:https://www.cnblogs.com/mjorcen/p/3825591.html
Copyright © 2011-2022 走看看