創(chuàng)建存儲過程
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:國際域名空間、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、唐山網(wǎng)站維護、網(wǎng)站推廣。
mysql
delimiter
$
--
delimiter
$是設(shè)置
$為命令終止符號,代替默認的分號,因為分號有其他用處.
mysql
create
procedure
sp_test(IN
pi_id
int,
OUT
po_name
varchar(10))
-
begin
-
select
*
from
test.tb_test;
-
select
tb_test.name
into
po_name
from
test.tb_test
where
tb_test.id
=
pi_id;
-
end
-
$
Query
OK,
rows
affected
(0.00
sec)
mysql
delimiter
;
--
恢復(fù)分號作為分隔終止符號
5.調(diào)用存儲過程
mysql
set
@po_name='';
Query
OK,
rows
affected
(0.00
sec)
mysql
call
sp_test(1,@po_name);
1.字符串函數(shù)
char_lengt()
concat()
instr()
lcase()
left()
ltrim()
mid()
2.時間函數(shù)
now()
curdate()
curtime()
datediff()
date_add()
數(shù)學函數(shù)
abs()
ceiling()
floor()
pow()
rand()
round()
其他函數(shù)
md5()
version()
database()
UUID()
同一使用select 函數(shù)名(參數(shù)列表)
1)基本用戶定義函數(shù)是一類代碼,對MYSQL服務(wù)器功能進行擴充,通過添加新函數(shù),性質(zhì)就象使用本地MYSQL函數(shù)abs()或concat().UDF是用C(或C++)寫的。也許還可以用BASIC,.NET或其它什么雖然還沒見過有人這么做。
2)從字面上何以知道UDF是很有用的,尤其當需要擴展MYSQL服務(wù)器功能時。下表給出了最佳解決方法的比較:
Method Speed Language Development
方法 速度 語言 開發(fā)
Stored Procedures slow SQL ~minutes (for small functions)
存儲過程 慢 SQL ~分鐘(對于小函數(shù))
UDF fast C ~hour
UDF 快 C ~小時
Native Function fast C major pain in the ***
本地函數(shù) 快 C 未知
慢的意思是和其它比較時。存儲過程和一般SQL語句比仍然是很快的。
對本地函數(shù)的一點解釋:本質(zhì)上和UDF沒太大區(qū)別。但是必須用MYSQL的資源代碼來寫然后重新編譯全部。這將是很大的工作量,必須一邊又一邊的用最新版的MYSQL來完成這項工作。
3)這部分很簡單。當完成了一個UDF,只是使用它就可以了。例如:"SELECT MyFunction(data1, data2) FROM table"
4)編寫UDF
現(xiàn)在開發(fā)寫一個UDF:
建立一個新的shared-library項目(該例中用的VC++ 6.0建立一個標準的DLL)
首先需要一些頭文件。這些頭文件是標準的頭文件和MYSQL服務(wù)器的包含目錄里的文件
#ifdef STANDARD
/* STANDARD is defined, don't use any mysql functions */
#include
#include
#include
#ifdef __WIN__
typedef unsigned __int64 ulonglong; /* Microsofts 64 bit types */
typedef __int64 longlong;
#else
typedef unsigned long long ulonglong;
typedef long long longlong;
#endif /*__WIN__*/
#else
#include
#include
#endif
#include
#include
static pthread_mutex_t LOCK_hostname;
現(xiàn)在必須決定需要哪類函數(shù)。本質(zhì)上有兩種選擇:
該函數(shù)是聚合函數(shù)嗎?(后面將學習很多關(guān)于聚合函數(shù)的內(nèi)容)
返回類型是什么?有4個選擇:
類型 描述
STRING 一個合法的字符串,轉(zhuǎn)換成char*類型
INTEGER 一個普通的整型變量,轉(zhuǎn)換成64位的整型
REAL型 一個俘點數(shù),轉(zhuǎn)換成double型
DECIAML型 這個并沒真正的結(jié)束,MYSQL將做字符串對待
現(xiàn)在開始討論關(guān)于非聚合函數(shù)。必須聲明并執(zhí)行一些MYSQL使用UDF時用到的函數(shù),但首先一些必要的結(jié)構(gòu)必須并確:
UDF_INIT:
類型 名稱 描述
my_bool maybe_null 是1如果函數(shù)能返回NULL
unsigned int decimals 針對REAL函數(shù)
unsigned long max_length 針對字符串函數(shù)
char * ptr 自由指針針對函數(shù)的數(shù)據(jù)
my_bool const_item 0如果結(jié)果是獨立的
UDF_ARGS:
類型 名稱 描述
unsigned int arg_count 成員數(shù)量
enum Item_result * arg_type 成員類型的數(shù)組
char ** args 指向成員的指針的數(shù)組
unsigned long * lengths 成員長度的數(shù)組(針對字符串)
char * maybe_null "maybe_null"標記的數(shù)組
char ** attributes 指向成員屬性的指針的數(shù)組
unsigned long * attribute_lengths 屬性長度數(shù)組
現(xiàn)在看一下該函數(shù):
De-/Initialization:
Collapseextern "C" my_bool MyTest_init(UDF_INIT *initid, UDF_ARGS *args,
char *message)
{
//非常重要的一件事是建立內(nèi)存
//需要
//需要一個很長的變量來保存檢測數(shù)
//雖然該例中不需要
longlong* i = new longlong; // 建立變量
*i = 0; // 設(shè)初值
//指針變量中保存為一個字符指針
//確認不會遇到類型問題
initid-ptr = (char*)i;
//檢測成員的格式
if (args-arg_count != 1)
{
strcpy(message,"MyTest() requires one arguments");
return 1;
}
if (args-arg_type[0] != INT_RESULT)
{
strcpy(message,"MyTest() requires an integer");
return 1;
}
return 0;
}
extern "C" void MyTest_deinit(UDF_INIT *initid)
{
//這里必須清空所分配的內(nèi)存
//引入函數(shù)
delete (longlong*)initid-ptr;
}
The actual function:
extern "C" longlong MyTest(UDF_INIT *initid, UDF_ARGS *args,
char *is_null, char *error)
{
/*最后這是實際的工作部分。該函數(shù)為每個記錄調(diào)用,返回值或指向當前值的指針保存在UDF_ARGS變量中。必須獲得值,完成計算并返回值。注意可以通過UDF_INIT變量進入MyTest_init中分配的內(nèi)存,該例中將為每個值設(shè)置為5
*/
return *((longlong*)args-args[0])+5;
}
全部完成!現(xiàn)在必須編譯連接庫,然后將其拷貝到操作系統(tǒng)可以加載的目錄下。通常在WINDOWS里是系統(tǒng)變量的定義路徑。個人使用的是MYSQL服務(wù)器的bin目錄。必須確認該目錄是其它MYSQL不能訪問的。然后確認所有MYSQL需要的函數(shù)功能。
必須告訴MYSQL,這必須直接了當:執(zhí)行以下SQL指令:
CREATE [AGGREGATE] FUNCTION MyTest
RETURNS [INTEGER|STRING|REAL|DECIMAL] SONAME the_libraries_exact_name
現(xiàn)在可以想使用其他函數(shù)一樣使用它了。
5)成員函數(shù):
現(xiàn)在說一下成員函數(shù)。當?shù)腢DF是個成員函數(shù),必須增加一些函數(shù),一些函數(shù)在不同的方式中使用。調(diào)用次序是:
調(diào)用yTest_init來分配內(nèi)存(就象一般的UDF一樣)
MYSQL將表分類是通過GROUP BY
每組里的第一行調(diào)用MyTest_clear
每組里的第一列調(diào)用 MyTest_add
在組改變后或最后一列改變后調(diào)用MyTest得到結(jié)果
重復(fù)3到5直到所有列被處理。
調(diào)用MyTest_deinit清空內(nèi)存
現(xiàn)在讓看一下新的聚合函數(shù)所需的函數(shù)。該例中將簡單的添加所有的值。(就象本地SUM函數(shù))
void MyTest_clear(UDF_INIT *initid, char *is_null, char *error)
{
/*為每個新組重新將總數(shù)設(shè)置為0,當然必須分配一個longlong類型變量在在init函數(shù)中,并分配給指針
*/
*((longlong*)initid-ptr) = 0;
}
void MyTest_add(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)
{
//為每列將當前值添加到總數(shù)
*((longlong*)initid-ptr) = *((longlong*)initid-ptr) +
*((longlong*)args-args[0]);
}
longlong MyTest(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)
{
//最后返回總值
return *((longlong*)initid-ptr);
}
6)更進一步的問題:
在寫一些復(fù)雜的UDF時需要注意幾個問題:
一個字符串函數(shù)應(yīng)該返回一個指向結(jié)果的指針并且設(shè)置*result和*length作為目錄和返回值的長度值。例如:
memcpy(result, "result string", 13);
*length = 13;
MyTest建立的結(jié)果緩沖區(qū)是255字節(jié)。如果的結(jié)果保存在里面。不必擔心結(jié)果的內(nèi)存分配問題。
如果的字符串函數(shù)需要返回一個大于255字節(jié)長度的字符串。必須用malloc或新的MyTest_init或MyTest函數(shù)分配,然后用MyTest_deinit釋放它。能用UDF_INIT的指針保存分配的內(nèi)存地址,并在MyTest中重用。
在主函數(shù)中指定一個錯誤返回,設(shè)置 *error為1:如果MyTest()為任何列將*error設(shè)置為1,則函數(shù)的值是NULL針對于當前列,以及對任何的通過MyTest()被調(diào)用的聲明中并發(fā)的列請求。
想了解更多內(nèi)容看一下MYSQL在線幫助。
7)一些指導(dǎo)方針:
如果確實希望的UDF運行良好,這里有一些建議:)
不要在UDF中調(diào)用任何其他的程序或進程
不要保存任何的本地信息。(這些在普通的庫里已經(jīng)共享)
不要分配任何的全局或靜態(tài)的變量。
始終檢測成員的類型。就象MYSQL將所有類型都轉(zhuǎn)換為字符類型。如果將一個字符類型轉(zhuǎn)換成整型指針可能會出錯。
特別注意內(nèi)存的分配。如果有內(nèi)存泄漏問題會使服務(wù)器徹底崩潰!
8)調(diào)式UDF
調(diào)試UDF需要勇氣因為如果UDF有問題,每次都會使整個MYSQL服務(wù)器死掉。所以寫了一個命令行工具,來圍繞這個問題工作。僅僅運行它,它會模仿"SELECT"調(diào)用指令將結(jié)果保存到庫文件中,可以打印所有的結(jié)果行。所以當UDF存在一些錯誤只是該程序崩潰而不會是整個服務(wù)器。
create function 函數(shù)名稱(參數(shù)列表)
reurns 返回值類型
函數(shù)體
執(zhí)行的方法很簡單:
加載
** create function 函數(shù)名稱 returns {string|real|integer}
** soname 你定義的動態(tài)庫位置
釋放!
** drop function 函數(shù)名稱
本文題目:mysql中怎么調(diào)用函數(shù),mysql常用函數(shù)大全
文章源于:http://jinyejixie.com/article14/hsicge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司、電子商務(wù)、外貿(mào)建站、品牌網(wǎng)站建設(shè)、、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)