深入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 ->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')
二 建立儲存過程
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)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2001/viewspace-2804064/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL自定義函式與儲存過程MySql函式儲存過程
- mySql 儲存過程與函式MySql儲存過程函式
- 儲存過程與儲存函式儲存過程儲存函式
- MySQL儲存過程 (即函式)MySql儲存過程函式
- MySQL 儲存過程和函式MySql儲存過程函式
- MySQL儲存過程和函式MySql儲存過程函式
- mysql和orcale的儲存過程和儲存函式MySql儲存過程儲存函式
- MySQL使用之五_自定義函式和自定義過程MySql函式
- mysql儲存過程procedure、函式function的用法MySql儲存過程函式Function
- MySQL入門--儲存過程(PROCEDURE)和儲存函式(FUNCTION)MySql儲存過程儲存函式Function
- mysql儲存過程及日期函式實踐MySql儲存過程函式
- MySQL儲存過程的建立和使用MySql儲存過程
- Mysql中儲存過程、儲存函式、自定義函式、變數、流程控制語句、游標/遊標、定義條件和處理程式的使用示例MySql儲存過程儲存函式變數
- 瞭解使用mysql 的檢視、儲存過程、觸發器、函式....MySql儲存過程觸發器函式
- SqlServer儲存過程的建立與使用SQLServer儲存過程
- SQL server儲存過程函式SQLServer儲存過程函式
- mongo 儲存過程詳解Go儲存過程
- matlab自定義函式建立與使用Matlab函式
- 【MySQL】MySQL(三)儲存過程和函式、觸發器、事務MySql儲存過程函式觸發器
- openGauss 函式及儲存過程支援函式儲存過程
- 儲存過程vs.函式QM儲存過程函式
- mysql 儲存過程中變數的定義與賦值操作MySql儲存過程變數賦值
- mysql 儲存過程MySql儲存過程
- MySQL優化---儲存過程和儲存函式-1-轉自部落格園MySql優化儲存過程儲存函式
- MySQL建立隨機生成電話的儲存函式MySql隨機儲存函式
- 函式儲存過程併發控制-案例函式儲存過程
- 七、函式-儲存過程-觸發器函式儲存過程觸發器
- MySQL--儲存過程與檢視MySql儲存過程
- Mysql 儲存過程的使用MySql儲存過程
- 案例展示自定義C函式的實現過程函式
- 深入解讀MySQL InnoDB儲存引擎Update語句執行過程MySql儲存引擎
- MySQL之儲存過程MySql儲存過程
- MySQL---------儲存過程MySql儲存過程
- mysql儲存過程整理MySql儲存過程
- mysql儲存過程的引數MySql儲存過程
- Hive--->建立自定義的UDTF函式Hive函式
- mysql 匯入匯出資料庫以及函式、儲存過程的介紹MySql資料庫函式儲存過程
- mysql如何呼叫儲存過程MySql儲存過程