国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - 深入mysql創建自定義函數與存儲過程的詳解

深入mysql創建自定義函數與存儲過程的詳解

2019-12-27 16:46MYSQL教程網 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.創建自定義函數

復制代碼代碼如下:

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;


二 創建存儲過程
1.進入mysql命令行

mysql>
2.用delimiter命令來把語句定界符從 ;變為//。這樣就允許在程序體用;定界符傳遞到服務器,而不是被mysql自己來解釋。
mysql> delimiter //
3.創建存儲過程

復制代碼代碼如下:


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)

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天天干狠狠干 | 欧美另类视频 | 不卡一区在线观看 | 亚州精品天堂中文字幕 | 国产成人自拍视频在线 | 成人免费大片黄在线播放 | 精品一区二区三区视频 | 精品国产免费久久久久久尖叫 | 中文字幕日韩欧美 | 亚洲欧美在线观看 | 国产精品爱久久久久久久 | 九九九九国产 | 亚洲欧美一区二区三区久久 | 久久精品国产99国产 | 性色国产| 国产综合精品一区二区三区 | 久久精品xx老女人老配少 | 欧美成人专区 | 国产精品综合 | 成人午夜电影网 | 一区二区三区在线视频播放 | 色综合天天综合网国产成人网 | 亚洲国产高清在线 | 美女视频一区二区三区 | 国产精品美女久久久久久久久久久 | 欧美色综合天天久久综合精品 | 日本久久精品视频 | 国产精品久久久久久久久大全 | 亚洲精品久久久久久一区二区 | av中文字幕在线播放 | av亚洲在线 | 成人精品视频一区二区三区 | 午夜色播| 一区二区三区回区在观看免费视频 | 伊人色爱 | 国产精品毛片a√一区 | 久久中文字幕网 | 国产人成精品一区二区三 | 日韩成人一区二区 | 日韩精品在线一区 | 成人片免费看 |