create function 函數(shù)名稱(參數(shù)列表)

浮山ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書(shū)銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書(shū)合作)期待與您的合作!
reurns 返回值類型
函數(shù)體
執(zhí)行的方法很簡(jiǎn)單:
加載
** create function 函數(shù)名稱 returns {string|real|integer}
** soname 你定義的動(dòng)態(tài)庫(kù)位置
釋放!
** drop function 函數(shù)名稱
1)基本用戶定義函數(shù)是一類代碼,對(duì)MYSQL服務(wù)器功能進(jìn)行擴(kuò)充,通過(guò)添加新函數(shù),性質(zhì)就象使用本地MYSQL函數(shù)abs()或concat().UDF是用C(或C++)寫(xiě)的。也許還可以用BASIC,.NET或其它什么雖然還沒(méi)見(jiàn)過(guò)有人這么做。
2)從字面上何以知道UDF是很有用的,尤其當(dāng)需要擴(kuò)展MYSQL服務(wù)器功能時(shí)。下表給出了最佳解決方法的比較:
Method Speed Language Development
方法 速度 語(yǔ)言 開(kāi)發(fā)
Stored Procedures slow SQL ~minutes (for small functions)
存儲(chǔ)過(guò)程 慢 SQL ~分鐘(對(duì)于小函數(shù))
UDF fast C ~hour
UDF 快 C ~小時(shí)
Native Function fast C major pain in the ***
本地函數(shù) 快 C 未知
慢的意思是和其它比較時(shí)。存儲(chǔ)過(guò)程和一般SQL語(yǔ)句比仍然是很快的。
對(duì)本地函數(shù)的一點(diǎn)解釋:本質(zhì)上和UDF沒(méi)太大區(qū)別。但是必須用MYSQL的資源代碼來(lái)寫(xiě)然后重新編譯全部。這將是很大的工作量,必須一邊又一邊的用最新版的MYSQL來(lái)完成這項(xiàng)工作。
3)這部分很簡(jiǎn)單。當(dāng)完成了一個(gè)UDF,只是使用它就可以了。例如:"SELECT MyFunction(data1, data2) FROM table"
4)編寫(xiě)UDF
現(xiàn)在開(kāi)發(fā)寫(xiě)一個(gè)UDF:
建立一個(gè)新的shared-library項(xiàng)目(該例中用的VC++ 6.0建立一個(gè)標(biāo)準(zhǔn)的DLL)
首先需要一些頭文件。這些頭文件是標(biāo)準(zhǔn)的頭文件和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ù)嗎?(后面將學(xué)習(xí)很多關(guān)于聚合函數(shù)的內(nèi)容)
返回類型是什么?有4個(gè)選擇:
類型 描述
STRING 一個(gè)合法的字符串,轉(zhuǎn)換成char*類型
INTEGER 一個(gè)普通的整型變量,轉(zhuǎn)換成64位的整型
REAL型 一個(gè)俘點(diǎn)數(shù),轉(zhuǎn)換成double型
DECIAML型 這個(gè)并沒(méi)真正的結(jié)束,MYSQL將做字符串對(duì)待
現(xiàn)在開(kāi)始討論關(guān)于非聚合函數(shù)。必須聲明并執(zhí)行一些MYSQL使用UDF時(shí)用到的函數(shù),但首先一些必要的結(jié)構(gòu)必須并確:
UDF_INIT:
類型 名稱 描述
my_bool maybe_null 是1如果函數(shù)能返回NULL
unsigned int decimals 針對(duì)REAL函數(shù)
unsigned long max_length 針對(duì)字符串函數(shù)
char * ptr 自由指針針對(duì)函數(shù)的數(shù)據(jù)
my_bool const_item 0如果結(jié)果是獨(dú)立的
UDF_ARGS:
類型 名稱 描述
unsigned int arg_count 成員數(shù)量
enum Item_result * arg_type 成員類型的數(shù)組
char ** args 指向成員的指針的數(shù)組
unsigned long * lengths 成員長(zhǎng)度的數(shù)組(針對(duì)字符串)
char * maybe_null "maybe_null"標(biāo)記的數(shù)組
char ** attributes 指向成員屬性的指針的數(shù)組
unsigned long * attribute_lengths 屬性長(zhǎng)度數(shù)組
現(xiàn)在看一下該函數(shù):
De-/Initialization:
Collapseextern "C" my_bool MyTest_init(UDF_INIT *initid, UDF_ARGS *args,
char *message)
{
//非常重要的一件事是建立內(nèi)存
//需要
//需要一個(gè)很長(zhǎng)的變量來(lái)保存檢測(cè)數(shù)
//雖然該例中不需要
longlong* i = new longlong; // 建立變量
*i = 0; // 設(shè)初值
//指針變量中保存為一個(gè)字符指針
//確認(rèn)不會(huì)遇到類型問(wèn)題
initid-ptr = (char*)i;
//檢測(cè)成員的格式
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í)際的工作部分。該函數(shù)為每個(gè)記錄調(diào)用,返回值或指向當(dāng)前值的指針保存在UDF_ARGS變量中。必須獲得值,完成計(jì)算并返回值。注意可以通過(guò)UDF_INIT變量進(jìn)入MyTest_init中分配的內(nèi)存,該例中將為每個(gè)值設(shè)置為5
*/
return *((longlong*)args-args[0])+5;
}
全部完成!現(xiàn)在必須編譯連接庫(kù),然后將其拷貝到操作系統(tǒng)可以加載的目錄下。通常在WINDOWS里是系統(tǒng)變量的定義路徑。個(gè)人使用的是MYSQL服務(wù)器的bin目錄。必須確認(rèn)該目錄是其它MYSQL不能訪問(wèn)的。然后確認(rèn)所有MYSQL需要的函數(shù)功能。
必須告訴MYSQL,這必須直接了當(dāng):執(zhí)行以下SQL指令:
CREATE [AGGREGATE] FUNCTION MyTest
RETURNS [INTEGER|STRING|REAL|DECIMAL] SONAME the_libraries_exact_name
現(xiàn)在可以想使用其他函數(shù)一樣使用它了。
5)成員函數(shù):
現(xiàn)在說(shuō)一下成員函數(shù)。當(dāng)?shù)腢DF是個(gè)成員函數(shù),必須增加一些函數(shù),一些函數(shù)在不同的方式中使用。調(diào)用次序是:
調(diào)用yTest_init來(lái)分配內(nèi)存(就象一般的UDF一樣)
MYSQL將表分類是通過(guò)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ù)。該例中將簡(jiǎn)單的添加所有的值。(就象本地SUM函數(shù))
void MyTest_clear(UDF_INIT *initid, char *is_null, char *error)
{
/*為每個(gè)新組重新將總數(shù)設(shè)置為0,當(dāng)然必須分配一個(gè)longlong類型變量在在init函數(shù)中,并分配給指針
*/
*((longlong*)initid-ptr) = 0;
}
void MyTest_add(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)
{
//為每列將當(dāng)前值添加到總數(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)更進(jìn)一步的問(wèn)題:
在寫(xiě)一些復(fù)雜的UDF時(shí)需要注意幾個(gè)問(wèn)題:
一個(gè)字符串函數(shù)應(yīng)該返回一個(gè)指向結(jié)果的指針并且設(shè)置*result和*length作為目錄和返回值的長(zhǎng)度值。例如:
memcpy(result, "result string", 13);
*length = 13;
MyTest建立的結(jié)果緩沖區(qū)是255字節(jié)。如果的結(jié)果保存在里面。不必?fù)?dān)心結(jié)果的內(nèi)存分配問(wèn)題。
如果的字符串函數(shù)需要返回一個(gè)大于255字節(jié)長(zhǎng)度的字符串。必須用malloc或新的MyTest_init或MyTest函數(shù)分配,然后用MyTest_deinit釋放它。能用UDF_INIT的指針保存分配的內(nèi)存地址,并在MyTest中重用。
在主函數(shù)中指定一個(gè)錯(cuò)誤返回,設(shè)置 *error為1:如果MyTest()為任何列將*error設(shè)置為1,則函數(shù)的值是NULL針對(duì)于當(dāng)前列,以及對(duì)任何的通過(guò)MyTest()被調(diào)用的聲明中并發(fā)的列請(qǐng)求。
想了解更多內(nèi)容看一下MYSQL在線幫助。
7)一些指導(dǎo)方針:
如果確實(shí)希望的UDF運(yùn)行良好,這里有一些建議:)
不要在UDF中調(diào)用任何其他的程序或進(jìn)程
不要保存任何的本地信息。(這些在普通的庫(kù)里已經(jīng)共享)
不要分配任何的全局或靜態(tài)的變量。
始終檢測(cè)成員的類型。就象MYSQL將所有類型都轉(zhuǎn)換為字符類型。如果將一個(gè)字符類型轉(zhuǎn)換成整型指針可能會(huì)出錯(cuò)。
特別注意內(nèi)存的分配。如果有內(nèi)存泄漏問(wèn)題會(huì)使服務(wù)器徹底崩潰!
8)調(diào)式UDF
調(diào)試UDF需要勇氣因?yàn)槿绻鸘DF有問(wèn)題,每次都會(huì)使整個(gè)MYSQL服務(wù)器死掉。所以寫(xiě)了一個(gè)命令行工具,來(lái)圍繞這個(gè)問(wèn)題工作。僅僅運(yùn)行它,它會(huì)模仿"SELECT"調(diào)用指令將結(jié)果保存到庫(kù)文件中,可以打印所有的結(jié)果行。所以當(dāng)UDF存在一些錯(cuò)誤只是該程序崩潰而不會(huì)是整個(gè)服務(wù)器。
php調(diào)用mysql存儲(chǔ)過(guò)程和函數(shù)的方法
存儲(chǔ)過(guò)程和函數(shù)是MySql5.0剛剛引入的。關(guān)于這方面的操作在PHP里面沒(méi)有直接的支持。但是由于Mysql PHP API的設(shè)計(jì),使得我們可以在以前的PHP版本中的mysql php api中支持存儲(chǔ)過(guò)程和函數(shù)的調(diào)用。
在php中調(diào)用存儲(chǔ)過(guò)程和函數(shù)。
1。調(diào)用存儲(chǔ)過(guò)程的方法。
a。如果存儲(chǔ)過(guò)程有 IN/INOUT參數(shù),聲明一個(gè)變量,輸入?yún)?shù)給存儲(chǔ)過(guò)程,該變量是一對(duì),
一個(gè)php變量(也可以不必,只是沒(méi)有php變量時(shí),沒(méi)有辦法進(jìn)行動(dòng)態(tài)輸入),一個(gè)Mysql
變量。
b。如果存儲(chǔ)過(guò)程有OUT變量,聲明一個(gè)Mysql變量。
mysql變量的聲明比較特殊,必須讓mysql服務(wù)器知道此變量的存在,其實(shí)也就是執(zhí)行一條mysql語(yǔ)句。
入set @mysqlvar=$phpvar ;
c。使用mysql_query()/mysql_db_query()執(zhí)行mysql 變量聲明語(yǔ)句。
mysql_query("set @mysqlvar=$pbpvar");
這樣,在mysql服務(wù)器里面就有一個(gè)變量,@mysqlar。如果是IN參數(shù),那么其值可以由phpar傳入。
d。 如果是存儲(chǔ)過(guò)程。
1。執(zhí)行 call procedure()語(yǔ)句。
也就是mysql_query("call proceduer([var1]...)");
2. 如果有返回值,執(zhí)行select @ar,返回執(zhí)行結(jié)果。
mysql_query("select @var)"
接下來(lái)的操作就和php執(zhí)行一般的mysql語(yǔ)句一樣了。可以通過(guò)mydql_fetch_row()等函數(shù)獲得結(jié)果。
如果時(shí)函數(shù)。 直接執(zhí)行 select function() 就可以了。
$host="localhost";
$user="root";
$password="11212";
$db="samp_db";
$dblink=mysql_connect($host,$user,$password)
or die("can't connect to mysql");
mysql_select_db($db,$dblink)
or die("can't select samp_db");
$res=mysql_query("set @a=$password",$dblink);
$res=mysql_query("call aa(@a)",$dblink);
$res=mysql_query("select @a",$dblink);
$row=mysql_fetch_row($res);
echo $row[0];
創(chuàng)建存儲(chǔ)過(guò)程
mysql
delimiter
$
--
delimiter
$是設(shè)置
$為命令終止符號(hào),代替默認(rèn)的分號(hào),因?yàn)榉痔?hào)有其他用處.
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ù)分號(hào)作為分隔終止符號(hào)
5.調(diào)用存儲(chǔ)過(guò)程
mysql
set
@po_name='';
Query
OK,
rows
affected
(0.00
sec)
mysql
call
sp_test(1,@po_name);
1. 建立MySQL 連接:mysql_connect
resource mysql_connect([string $server[, string $username [, string $password [, bool $new_link [, int $client flags]]]]])
打開(kāi)或重復(fù)使用一個(gè)到MySQL服務(wù)器的連接。其中,server代表MySQL服務(wù)器,可以包括端口號(hào),例如“hostname:port”。username和password分別代表登錄MySQL服務(wù)器使用的用戶名和密碼。
2. 選擇 MySQL 數(shù)據(jù)庫(kù):mysql_select_db
bool mysql_select_db(string $database_name[, resource $link_identifier])
設(shè)定與指定的連接標(biāo)識(shí)符所關(guān)聯(lián)的服務(wù)器上的當(dāng)前數(shù)據(jù)庫(kù)。如果沒(méi)有指定連接標(biāo)識(shí)符,則使用上一個(gè)打開(kāi)的連接。如果沒(méi)有打開(kāi)的連接,本函數(shù)將無(wú)參數(shù)地調(diào)用mysql_connect()來(lái)嘗試打開(kāi)一個(gè)數(shù)據(jù)庫(kù)連接。如果成功則返回true,失敗則返回false。每個(gè)其后的mysgl_query()調(diào)用都會(huì)作用于活動(dòng)數(shù)據(jù)庫(kù)。
3. 執(zhí)行查詢:mysql_query
resource mysql_query(string $query[, resource $link_identifier])
向與指定的連接標(biāo)識(shí)的關(guān)聯(lián)的服務(wù)器中的當(dāng)前活動(dòng)數(shù)據(jù)庫(kù)發(fā)送一條查詢。如果沒(méi)有指定 link_identifier,則使用上一個(gè)打開(kāi)的連接。如果沒(méi)有打開(kāi)的連接,本函數(shù)會(huì)嘗試無(wú)參數(shù)地調(diào)用mysql_connect()函數(shù)來(lái)建立一個(gè)連接,查詢結(jié)果會(huì)被緩存。mysql_query()僅對(duì)SELECT、SHOW、EXPLAIN或DESCRIBE語(yǔ)句返回一個(gè)資源標(biāo)識(shí)符,如果查詢執(zhí)行不正確則返回false。對(duì)于其他類型的SQL語(yǔ)句,mysgl_query()在執(zhí)行成功時(shí)返回true,出錯(cuò)時(shí)返回false。非false的返回值意味著查詢是合法的并能夠被服務(wù)器執(zhí)行但是并不說(shuō)明任何影響到的或返回的行數(shù)。因?yàn)橐粭l查詢執(zhí)行成功了但并未影響到或并未返回任何行的情況是可能發(fā)生的。
4. 從結(jié)果集中取得一行作為枚舉數(shù)組:mysql_fetch_row
array mysql_fetch_row(resource $result)
從和指定的結(jié)果標(biāo)識(shí)關(guān)聯(lián)的結(jié)果集中取得一行數(shù)據(jù)并作為數(shù)組返回。每個(gè)結(jié)果的列儲(chǔ)存在一個(gè)索引數(shù)組的單元中,偏移量從0開(kāi)始。依次調(diào)用mysql_fetch_row()將返回結(jié)果集中的下一行,如果沒(méi)有更多行則返回false。
5. 從結(jié)果集中取得一行作為關(guān)聯(lián)數(shù)組,或數(shù)字?jǐn)?shù)組,或二者兼有:mysql_fetch_array
array mysql_fetch_array(resource $result[, int $result_type])
mysql_fetch_row()的擴(kuò)展版本。除了將數(shù)據(jù)以數(shù)字索引方式儲(chǔ)存在數(shù)組中之外,還可以將數(shù)據(jù)作為關(guān)聯(lián)索引儲(chǔ)存,用字段名作為鍵名。如果結(jié)果中出現(xiàn)字段名重名的現(xiàn)象,最后一列將優(yōu)先。要訪問(wèn)同名的其他列,必須用該列的數(shù)字索引或給該列起個(gè)別名。對(duì)有別名的列,用別名來(lái)訪問(wèn)其內(nèi)容。
6. 關(guān)閉 MySQL 連接:mysql_close
bool mysql_close([resource $link_identifier])
mysql_close()關(guān)閉指定的連接標(biāo)識(shí)所關(guān)聯(lián)的到MySQL服務(wù)器的非持久連接。如果沒(méi)有指定link_identifier,則關(guān)閉上一個(gè)打開(kāi)的連接。
例PHP中使用MySQL數(shù)據(jù)庫(kù)(mysql.php)
?php//連接MySQL數(shù)據(jù)庫(kù)
mysql_connect('localhost', 'root', '123');
//選擇當(dāng)前數(shù)據(jù)庫(kù)
//等效為執(zhí)行USE test
mysql_select_db('test');
//在當(dāng)前數(shù)據(jù)庫(kù)執(zhí)行SQL語(yǔ)句
$query = "SELECT * FROM students";
$result = mysql_query($query);
//操作上次查詢返回的結(jié)果集,注意$result變量一般是需要的
while($student = mysql_fetch_array($result)) {
echo 'pre';
print_r($student);
echo '/pre';
}
?
網(wǎng)頁(yè)題目:mysql怎么函數(shù)調(diào)用,MySQL函數(shù)調(diào)用
路徑分享:http://www.chinadenli.net/article18/heddgp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、靜態(tài)網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)公司、電子商務(wù)、網(wǎng)站設(shè)計(jì)、虛擬主機(jī)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)