深入mysql創(chuàng)建自定義函數(shù)與存儲過程的詳解
一 創(chuàng)建自定義函數(shù)
在使用mysql的過程中,mysql自帶的函數(shù)可能不能完成我們的業(yè)務需求,這時就需要自定義函數(shù),例如筆者在開發(fā)過程中遇到下面這個問題:
mysql表結(jié)構(gòu)如下
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,怎么從數(shù)據(jù)庫中找出滿足字符串對應位置的字符不同的個數(shù)小于5的記錄呢?就像“11001”和“11101”對應位置不同字符不同的個數(shù)為1,比如 用戶輸入"7f7f004f7f7f00af",那么第三條和第四條記錄是滿足的,怎么實現(xiàn)呢?如果單純的依靠mysql自帶的函數(shù)很難完成,這時就需要建立自定義函數(shù)解決。這個問題的解決在此非常感謝csdn的acmain_chm,acmain_chm以及oschina的@梁小剛,還有@淘寶丁奇
建立自定義函數(shù)的過程如下:
1.進入mysql命令行
mysql>
2.用delimiter命令來把語句定界符從 ;變?yōu)?/。這樣就允許在程序體用;定界符傳遞到服務器,而不是被mysql自己來解釋。
mysql> delimiter //
3.創(chuàng)建自定義函數(shù)
mysql>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
->//
mysql>select * from test t where hashDiff(t.hashcode,'ff9880f0f680ceff') < 5;
二 創(chuàng)建存儲過程
1.進入mysql命令行
mysql>
2.用delimiter命令來把語句定界符從 ;變?yōu)?/。這樣就允許在程序體用;定界符傳遞到服務器,而不是被mysql自己來解釋。
mysql> delimiter //
3.創(chuàng)建存儲過程
mysql> delimiter //
mysql> CREATE PROCEDURE simpleproc (OUT param1 INT)
-> BEGIN
-> SELECT COUNT(*) INTO param1 FROM t;
-> END
-> //
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ;
mysql> CALL simpleproc(@a);
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT @a;
+------+
| @a |
+------+
| 3 |
+------+
1 row in set (0.00 sec)
- 詳解MySQL存儲過程的創(chuàng)建和調(diào)用
- mysql創(chuàng)建存儲過程及函數(shù)詳解
- MySQL之存儲過程按月創(chuàng)建表的方法步驟
- mysql創(chuàng)建存儲過程實現(xiàn)往數(shù)據(jù)表中新增字段的方法分析
- MySQL實現(xiàn)創(chuàng)建存儲過程并循環(huán)添加記錄的方法
- 在MySQL中創(chuàng)建帶有IN和OUT參數(shù)的存儲過程的方法
- MySQL動態(tài)創(chuàng)建表,數(shù)據(jù)分表的存儲過程
- MySQL5創(chuàng)建存儲過程的示例
- 查看MySQL中已經(jīng)創(chuàng)建的存儲過程及其定義
相關文章
MySQL同步數(shù)據(jù)Replication的實現(xiàn)步驟
本文主要介紹了MySQL同步數(shù)據(jù)Replication的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03MySQL中有哪些情況下數(shù)據(jù)庫索引會失效詳析
這篇文章主要給大家介紹了關于MySQL中有哪些情況下數(shù)據(jù)庫索引會失效的相關資料,文中通過圖文介紹的非常詳細,對大家學習或者使用mysql具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-07-07MySQL安裝時一直卡在starting?server的問題及解決方法
這篇文章主要介紹了MySQL安裝時一直卡在starting?server的問題及解決方法,出現(xiàn)這種情況大概有兩個原因,文中對每種原因給大家詳細介紹,需要的朋友可以參考下2022-06-06mysql下mysqladmin日常管理命令總結(jié)(必看篇)
下面小編就為大家?guī)硪黄猰ysql下mysqladmin日常管理命令總結(jié)(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03