一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Mysql - 深入mysql創(chuàng)建自定義函數(shù)與存儲(chǔ)過程的詳解

深入mysql創(chuàng)建自定義函數(shù)與存儲(chǔ)過程的詳解

2019-12-27 16:46MYSQL教程網(wǎng) Mysql

本篇文章是對(duì)mysql創(chuàng)建自定義函數(shù)與存儲(chǔ)過程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下

一 創(chuàng)建自定義函數(shù)
在使用mysql的過程中,mysql自帶的函數(shù)可能不能完成我們的業(yè)務(wù)需求,這時(shí)就需要自定義函數(shù),例如筆者在開發(fā)過程中遇到下面這個(gè)問題:
mysql表結(jié)構(gòu)如下

復(fù)制代碼代碼如下:


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進(jìn)制編碼字符串,長(zhǎng)度固定16位),用戶輸入一個(gè)hashcode,怎么從數(shù)據(jù)庫中找出滿足字符串對(duì)應(yīng)位置的字符不同的個(gè)數(shù)小于5的記錄呢?就像“11001”和“11101”對(duì)應(yīng)位置不同字符不同的個(gè)數(shù)為1,比如 用戶輸入"7f7f004f7f7f00af",那么第三條和第四條記錄是滿足的,怎么實(shí)現(xiàn)呢?如果單純的依靠mysql自帶的函數(shù)很難完成,這時(shí)就需要建立自定義函數(shù)解決。這個(gè)問題的解決在此非常感謝csdn的acmain_chm,acmain_chm以及oschina的@梁小剛,還有@淘寶丁奇

 

建立自定義函數(shù)的過程如下:
1.進(jìn)入mysql命令行

mysql>
2.用delimiter命令來把語句定界符從 ;變?yōu)?/。這樣就允許在程序體用;定界符傳遞到服務(wù)器,而不是被mysql自己來解釋。
mysql> delimiter //
3.創(chuàng)建自定義函數(shù)

復(fù)制代碼代碼如下:

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)建存儲(chǔ)過程
1.進(jìn)入mysql命令行

mysql>
2.用delimiter命令來把語句定界符從 ;變?yōu)?/。這樣就允許在程序體用;定界符傳遞到服務(wù)器,而不是被mysql自己來解釋。
mysql> delimiter //
3.創(chuàng)建存儲(chǔ)過程

復(fù)制代碼代碼如下:


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)

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 99re5精品视频在线观看 | 精品日韩一区二区三区 | 欧美日韩看看2015永久免费 | 美女的让男人桶爽30分钟的 | 国产卡一卡二卡3卡乱码免费 | 2022国产麻豆剧果冻传媒入口 | 亚洲va久久久久 | 国产丰满美女做爰 | bl高h荡肉古代np | 我把校花黑色蕾丝胸罩脱了 | 免费岛国| 国产靠逼视频 | 视频免费 | 美女用手扒自己下部 | 蜜桃影像传媒推广 | 大胆国模一区二区三区伊人 | 91九色国产porny | 久久综合狠狠综合狠狠 | 大桥未久一区二区 | 办公室强行丝袜秘书啪啪 | 国产亚洲99影院 | 500福利第一导航 | 娇妻在床上迎合男人 | 四虎影院新地址 | 91影视在线看免费观看 | 男人午夜禁片在线观看 | 国产欧美久久一区二区 | 亚洲国产综合久久久无码色伦 | 范冰冰好紧好滑好湿 | 亚洲国产精品一区二区久久 | 亚洲国产情侣一区二区三区 | 大叔在线观看 | 人人澡 人人澡碰人人看软件 | 亚洲免费视频在线 | 四虎精品永久免费 | 青青草原国产视频 | 久久久久嫩草影院精品 | 四虎影院永久在线 | 非洲特级特黄aa大片 | 日本老妇和子乱视频 | 亚洲视频在线一区二区 |