mysql存儲過程編碼
1、delimiter // ,聲明分隔符:DELIMITER是分割符的意思,因為MySQL默認以";"為分隔符,如果我們沒有聲明分割符,那麼編譯器會把存儲過程當成SQL語句進行處理,則存儲過程的編譯過程會報錯,所以要事先用DELIMITER關鍵字申明當前段分隔符,這樣MySQL才會將";"當做存儲過程中的代碼,不會執行這些代碼(這里如果不懂的話,你可以通過試錯的方法來理解)。
2、編寫存儲過程的格式:CREATE PROCEDURE([[IN |OUT |INOUT ]參數名數據類形...])
例子:
1)create procere proc1(out s int) // 只有輸出
2)create procere proc2(in p_in bigint) // 只有輸入
3)create procere proc15() // 沒有輸入與輸出
4)create procere demo_multi_param(in id bigint,in name varchar(32),out c int) //多輸入與輸出
3、過程體的開始與結束使用BEGIN與END進行標識。
4、select count (*) into s from student; // 過程體,一系列的邏輯語句,sql語句
5、delimiter ; 用完了之後要把分隔符還原。
⑵ Mysql存儲過程
不知道對不對 僅供參考(表名換成自己的)
CREATE PROCEDURE `getStuInfo`(IN `p_name` varchar(20))
BEGIN
DECLARE count int;
SET count=(select count(*) from xiao where `name`= p_name);
IF count THEN
select * from xiao where `name`= p_name;
ELSE
SELECT '查詢失敗' as result ;
END IF;
END
調用的時候是 call getStuInfo('張三')
⑶ MYsql存儲過程
抱錯:
you hava an error in your sql syntax;check the manual that corresponds to your mysql server version for the right syntax to use near 'curpage '盯輪;end 'at line 5
如果念猜把select artist_name ,title from jos_proct limit 0,curpage;換成
select artist_name ,title from jos_proct where proct_id=curpage;可以建立成凱高信功!!!
⑷ 關於mysql 的存儲過程
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 ; 這里把雙引號改回來
聲明參數要在說明是 輸入還是輸出函數 in\out
給函數變數賦值用
set @a=10;
例子:
drop procere if exists pr_param_in;
create procere pr_param_in
(
in id int -- in 類型的 MySQL 存儲過程參數
)
begin
if (id is not null) then
set id = id + 1;
end if;
select id as id_inner;
end;
set @id = 10;
call pr_param_in(@id);
select @id as id_out;
mysql> call pr_param_in(@id);
⑸ MySQL裡面sql語句調用存儲過程,該如何寫
這樣:
CREATEPROCEDUREsp_add(a int, b int,outc int)
begin
set c=a+ b;
end;
調用過程:
call sp_add (1,2,@a);
select @a;
(5)mysql存儲過程編碼擴展閱讀:
注意事項
存儲過程(stored procere)是一組為了完成特定功能的SQL語句集合,經編譯後存儲在伺服器端的資料庫中,利用存儲過程可以加速SQL語句的執行。
存儲過程分為系統存儲過程和自定義存儲過程。
系統存儲過程在master資料庫中,但是在其他的資料庫中可以直接調用,並且在調用時不必在存儲過程前加上資料庫名,因為在創建一個新資料庫時,系統存儲過程在新的資料庫中會自動創建。
自定義存儲過程,由用戶創建並能完成某一特定功能的存儲過程,存儲過程既可以有參數又有返回值,但是它與函數不同,存儲過程的返回值只是指明執行是否成功,並不能像函數那樣被直接調用,只能利用execute來執行存儲過程。
創建存儲過程
SQL Server創建存儲過程:
create procere 過程名
@parameter 參數類型
@parameter 參數類型
。。。
as
begin
end
執行存儲過程:execute 過程名
⑹ mysql 存儲過程總結(二)if語句、參數
1、if :用於做條件判斷,具體的語法結構為:
在if條件判斷的結構中,ELSE IF 結構可以有多個,也可以沒有。 ELSE結構可以有,也可以沒有。
案列:
根據定義的分數score變數,判定當前分數對應的分數等級。
score >= 90分,等級為優秀。
score >= 80分,等級為良好
score >= 60分,等級為及格
score < 60分,等級為不及格。
上述的需求我們雖然已經實現了,但是也存在一些問題,比如:score 分數我們是在存儲過程中定義 死的,而且最終計算出來的分數等級,我們也僅僅是最終查詢展示出來而已。
那麼我們能不能,把score分數動態的傳遞進來,計算出來的分數等級是否可以作為返回值返回呢? 答案是肯定的,我們可以通過接下來所講解的 參數 來解決上述的問題。
2、參數的類型
主要分為以下三種:IN、OUT、INOUT。 具體的含義如下:
(1)in :該類參數作為輸入,也就是需要調用時傳入值 默認
(2)out:該類參數作為輸出,也就是該參數可以作為返回值
(3)inout:既可以作為輸入參數,也可以作為輸出參數
用法:
案例一:
案列二:
⑺ Mysql存儲過程中文亂碼問題
如果你的資料庫編碼設置了gbk而且sql連接之後也mysql_query("set
names
gbk");之後還是亂碼的話那就看一下你的php文件的頁面編碼有沒有改,是不是還是它默認的utf8,如果是的話可以使用Dreamweaver這類工具在修改——頁面屬性——標題/編碼中將頁面編碼修改為gb2312再試試,,或是把資料庫和php的頁面編碼都改為gb2312的,一般sql亂碼都是資料庫編碼、頁面編碼等不統一的原因,這樣改一下再看看
⑻ mysql存儲過程
很明顯,你這個存儲過程是SQL Server的語法,不是MySQL的,兩者之間語法差異挺大。過程類似於如下:
create procere addUser(
username nvarchar(20),
password nvarchar(20),
OUT isSuccess int)
BEGIN
........
END
⑼ mysql的存儲過程打開為空
MySQL的存儲過程打開為空的原因可能是由於編胡棗碼錯誤導致不能正常讀取存儲過程中的內容,可以嘗試更改褲穗拆文本編碼重新打開來解決此問族芹題。
⑽ Mysql存儲過程中文亂碼問題
三處編碼一致,mysql數據編碼,欄位編碼
php程序編碼
mysql存儲過程編碼
這幾處的編碼都要一致才可以
查看下你的資料庫編碼,還有欄位編碼和存儲過程,php程序是否一致