国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-24 12:48:27
字體:
供稿:網(wǎng)友

一 創(chuàng)建自定義函數(shù)
在使用mysql的過程中,mysql自帶的函數(shù)可能不能完成我們的業(yè)務(wù)需求,這時就需要自定義函數(shù),例如筆者在開發(fā)過程中遇到下面這個問題:
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)制編碼字符串,長度固定16位),用戶輸入一個hashcode,怎么從數(shù)據(jù)庫中找出滿足字符串對應(yīng)位置的字符不同的個數(shù)小于5的記錄呢?就像“11001”和“11101”對應(yīng)位置不同字符不同的個數(shù)為1,比如 用戶輸入"7f7f004f7f7f00af",那么第三條和第四條記錄是滿足的,怎么實現(xiàn)呢?如果單純的依靠mysql自帶的函數(shù)很難完成,這時就需要建立自定義函數(shù)解決。這個問題的解決在此非常感謝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)建存儲過程
1.進(jìn)入mysql命令行
mysql>
2.用delimiter命令來把語句定界符從 ;變?yōu)?/。這樣就允許在程序體用;定界符傳遞到服務(wù)器,而不是被mysql自己來解釋。
mysql> delimiter //
3.創(chuàng)建存儲過程
復(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)
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 淅川县| 罗源县| 云南省| 吐鲁番市| 罗山县| 西乡县| 赤峰市| 阳原县| 长岛县| 任丘市| 佛山市| 锦州市| 岳池县| 高碑店市| 大竹县| 贵州省| 伊吾县| 千阳县| 秦安县| 天津市| 邮箱| 忻州市| 怀远县| 吴江市| 平定县| 潜江市| 宜黄县| 香格里拉县| 肇东市| 汉阴县| 准格尔旗| 随州市| 广元市| 额敏县| 无锡市| 江津市| 石门县| 额济纳旗| 藁城市| 鹿泉市| 扶沟县|