如何調用存儲過程資料庫
調用存儲過程demo(無參數的存儲)
進入查詢界面輸入以下內容
exec
demo----執行存儲過程
2. 如何調用另一個資料庫的存儲過程
首先需要知道「另一個存儲過程」的結果集的所有列的類型。
假設「另一個存儲過程」的名字是sp1,沒有參數,返回的結果集共3列,全部為int型,那麼「存儲過程」里添加一個與結果集列數相同的臨時表或表變數用於接收「另一個存儲過程」的結果集
如下
CREATE PROCEDURE sp2
AS
DECLARE @t table(a int,b int,c int)
INSERT INTO @t(a,b,c)
EXEC sp1
SELECT * FROM @t
使用SQLSERVER存儲過程可以很大的提高程序運行速度,簡化編程維護難度,現已得到廣泛應用。
創建存儲過程
和數據表一樣,在使用之前需要創建存儲過程,它的簡明語法是:
引用:
Create PROC 存儲過程名稱
[參數列表(多個以「,」分隔)]
AS
SQL 語句
3. C#調用夢資料庫存儲過程方法
//連接字元串
private string strConn = ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;
//連接對象
private SqlConnection conn;
private void Form1_Load(object sender, EventArgs e)
{
//實例化連接對象
conn = new SqlConnection(strConn);
}
private void button1_Click(object sender, EventArgs e)
{
//判斷是否資料庫連接成功
if (conn.State == System.Data.ConnectionState.Closed)
{
//連接資料庫
conn.Open();
}
//創建SQL命令對象,GetMaxPrice參數為存儲過程名
using (SqlCommand cmd = new SqlCommand("GetMaxPrice", conn))
{
//將命令類型設為存儲過程
cmd.CommandType = CommandType.StoredProcere;
//添加入參
cmd.Parameters.Add(new SqlParameter("@DTypeId",
SqlDbType.Int, 18, "DTypeId"));
//添加出參
cmd.Parameters.Add(new SqlParameter("@DPrice",
SqlDbType.Int, 18, ParameterDirection.Output, false, 0, 0,
"DPrice", DataRowVersion.Default, null));
//添加返回值
cmd.Parameters.Add(new SqlParameter("@return",
SqlDbType.Int,18,ParameterDirection.ReturnValue,true,0,0,
"return",DataRowVersion.Default,null));
//給入參賦值
cmd.Parameters["@DTypeId"].Value = int.Parse(txtEnter.Text);
//執行存儲過程
cmd.ExecuteNonQuery();
//獲取返回值
var ret = cmd.Parameters["@return"].Value;
//獲取出參
string price = cmd.Parameters["@DPrice"].Value.ToString();
if ((int)ret > 0)
{
textBox1.Text = price;
}
}
//關閉連接
conn.Close();
}
4. java中如何調用資料庫的存儲過程
Java調用存儲過程的方法是通過調用Connection的實例方法prepareCall,prepareCall方法返回CallableStatement對象用於填充存儲過程的參數。prepareCall方法形參是調用存儲過程的sql語句,此參數的語法格式如下:
{callstoredProcereName(parameter-list)}
其中,storedProcereName是存儲過程名稱,parameter-list是存儲過程參數列表。
例如,存儲過程名為usp_test,有兩個輸入參數a,b。則調用代碼看起來如下所示:
=connection.prepareCall("{callusp_test(?,?)}");
callableStatement.setObject("a","value-1");
callableStatement.setObject("b","value-2");
callableStatement.execute();
5. SQL存儲過程如何調用存儲過程
1、首先先創建一個存儲過程,代碼如圖,存儲過程主要的功能是為表JingYan插入新的數據。
6. oracle資料庫調用存儲過程
這個需要分情況的
如果是在應用程序(Java等)中調用存儲過程,需要根據相應語言的語法來進行。這個可以通過查找相應語言的幫助來找到。
如果是在Oracle的其他存儲過程中調用,直接寫存儲過程名就可以了。傳入相應的參數,即可執行。
如果在Oracle的命令行中,使用EXEC
存儲過程名(參數)
的方式即可調用。
如果存儲過程執行的語句寫在SQL文件中,則可以通過調用文件的方式執行,即
SQL>
@D:\SQL\example.sql的形式
7. 資料庫存儲過程怎麼調用存儲過程
在存儲過程里用exec執行另一存儲過程名及它需要的參數就可以了
如 exec abc '1', '2' (abc 是存儲過程的名字, '1','2' 是它的參數)
8. webservice怎麼調用資料庫存儲過程
代碼不記得寫了,過程如下:
1.
自己建一個
存儲過程
2..建一個
資料庫操作
類,並建一個public
方法,在方法里將command對象的CommadType屬性設置為存儲過程(StoreProcess);將
Command對象
的CommandText屬性設為存儲過程名,將傳入的參數加入Command對象的參數集合中,然後執行Command對象的ExecuteReader方法,
3.創建一個
WebService
,並引入上面創建的類,在WebService的方法裡面調用該類的方法,返回一個
DataReader
,將該DataReader轉換為
XML格式
輸出。
9. SQL 中存儲過程怎麼使用
一、簡單的儲存過程:
1、創建一個存儲過程
create procere GetUsers()
begin
select * from user;
end;12345
2、調用存儲過程
call GetUsers();12
3、刪除存儲過程
drop procere if exists GetUsers;
二、帶參數的存儲過程
1、MySql 支持 IN (傳遞給存儲過程) , OUT (從存儲過程傳出) 和 INOUT (對存儲過程傳入和傳出) 類型的參數 , 存儲過程的代碼位於 BEGIN 和 END 語句內 , 它們是一系列 SQL 語句 , 用來檢索值 , 然後保存到相應的變數 (通過指定INTO關鍵字) ;
2、下面的存儲過程接受三個參數 , 分別用於獲取用戶表的最小 , 平均 , 最大分數 , 每個參數必須具有指定的類型 , 這里使用十進制值(decimal(8,2)) , 關鍵字 OUT 指出相應的參數用來從存儲過程傳出
create procere GetScores(
out minScore decimal(8,2),
out avgScore decimal(8,2),
out maxScore decimal(8,2)
)
begin
select min(score) into minScore from user;
select avg(score) into avgScore from user;
select max(score) into maxScore from user;
end;1234567891011
3、調用此存儲過程 , 必須指定3個變數名(所有 MySql 變數都必須以@開始) , 如下所示 :
call GetScores(@minScore, @avgScore, @maxScore);12
4、該調用並沒有任何輸出 , 只是把調用的結果賦給了調用時傳入的變數@minScore, @avgScore, @maxScore, 然後即可調用顯示該變數的值 :
select @minScore, @avgScore, @maxScore;
5、使用 IN 參數 , 輸入一個用戶 id , 返回該用戶的名字 :
create procere GetNameByID(
in userID int,
out userName varchar(200)
)
begin
select name from user
where id = userID
into userName;
end;12345678910
6、調用存儲過程 :
call GetNameByID(1, @userName);
select @userName;123
10. 帆軟怎麼調用資料庫里的存儲過程
存儲過程,就是直接將存儲過程作為數據集,不需要在資料庫查詢處去調用存儲過程。FineReport支持全部資料庫的存儲過程作為數據集並且定義方法都相同。
1、點擊模板>模板數據集或者直接在數據集面板中,點擊「+」
2、在資料庫查詢窗口中輸入:
SET
NOCOUNT
ON
EXEC
dbo.jason
'${產品品號}'
其中
SET
NOCOUNT
ON
為固定格式,EXEC
dbo.jason(存儲過程名稱)'${產品品號}'
(產數子段),如果存儲過程中帶出多個欄位的話,可以帶出多個參數。
3、預覽數據
4、報表欄位設計
5、報表預覽
若存儲過程中返回的是多個結果集,在此也是支持同時返回多個結果集的。