淺談存儲過程

【1】什么是過程?過程與函數的區別?什么是存儲過程???

函數是帶返回值的過程
過程是沒有返回值的函數

存儲過程:存儲在數據庫中的封裝了若干條SQL語句的過程(MySql不支持不存儲的匿名過程)

【2】存儲過程的創建語法

MySQL:
create procedure procedureName()
    begin
        -- 存儲過程的編程 
        -- SQL statements
    end;

SQLServer:
create procedure  procedurename 
@參數1名 類型 , 
@參數2 類型
as
begin
    -- 存儲過程的編程 
    -- SQL statements   
end 

查看所有的procedure : show procedure status;

可給存儲過程傳遞參數

MySQL:
create procedure procedureName([in/out/inout] 參數名 參數類型.....)
                        其中的in/out/inout 是可選的,也就是說可有可無
        in  默認缺省是in類型,為了函數內部使用的,調用時傳值 call proName(參數值)
        out 外輸出參數,函數處理后,外部可調用(select @參數名)調用:call proName(@參數名)
SQLServer 無括號

inout 兼顧二者的特點

注意:函數調用時,

in類型給傳值,call proName(參數值)
out類型給傳變量名(函數內部手動初始化)call proName(@參數名)
inout類型 需要傳一個已經定義了的變量
set @變量名:=變量初始值;
call proName(@變量名)
如:

MySQL:
    create procedure p1(width int,height int)
    begin
        select concat('area is',width*height ) as area;
        if width>height then 
            select 'you fat';
        elseif width<height then
            select 'you small';
        else 
            select 'you ===';
        end if;
    end;

【3】存儲過程調用(MySQL) call procedureName()

【4】存儲過程的編程(MySQL)

  • 存儲過程是可以編程的( 在begin 和 end 之間 ),可以有 變量,表達式,控制結構

(1)變量:

  • 定義:用declare來聲明變量

  • 格式:
    declare 變量名 變量類型 default 默認初始值;
    也可以給變量賦默認值 如 declare gnum int;

  • 賦值:set 變量名=值(或表達式); 如set gnum=gnum+old.much;
    或者 set 變量名:=值,如 set gnum:=gunm+old.num;

  • 使用:直接使用

(2)表達式: +-*/%都可以正常的使用

(3)控制結構:

  • 1)分支機構

    ①if雙分支

            if search_condition then statement_list
                [elseif search_condition then statement_list] ...
                [else statement_list]
            end if;

②case多分支

            case 變量
                when 常量 then 表達式;
                when 常量 then 表達式;
                when 常量 then 表達式;
                else 表達式(都未中 相當于default);
            end case;

  • 2)循環結構
            ①while循環
                while search_condition DO
                    ...
                    statement_list
                end while;
            ②repeat循環(相當于 do while)
                repeat  statement_list
                    until search_condition
                end repeat; 



【5】實例( C#調用SQL Server2008存儲過程,并封裝結果 )


需求
    1.查詢全部的學生信息
    2.插入一條學生的信息

1.創建學生表

為了方便演示,假設學生只有三個屬性 :學號,姓名,專業

/*
  *@function:學生表
  *@author:Stone6762  
  */
 create table student  
  (
  id char(9)  unique,
  name char(50),
  major char(64),
  primary key (id),
  );

2.創建存儲過程

-- =============================================
-- Author:      Stone6762
-- Create date: 2016-10-1 08:12:05
-- Description: 獲取全部的學生信息
-- 無參的存儲過程的創建
-- =============================================
CREATE PROCEDURE Stu_GetAll 
AS  
BEGIN
     SELECT id,name,major  FROM student ORDER BY id;
END

-- =============================================
-- Author:      Stone6762
-- Create date: 2016-10-1 09:31:08
-- Description: 學生表的插入
-- 有參的存儲過程的創建
-- =============================================
CREATE PROCEDURE Stu_Insert 
    @Nid varchar(9) , 
    @Nname varchar(50),
    @Nmajor varchar(7)
AS
BEGIN
    insert into student(id,name,major)values(@Nid,@Nname,@Nmajor);
END


3. C# 鏈接數據庫,調用存儲過程,并將數據封裝



    
    public class MySSDBSP
    {
       struct Student
        {
            public string id;    
            public string name;
            public string major;
        }
        //因為會多次調用SqlConnection,故此將其寫入構造函數里
        private SqlConnection myConnection = null;
        public  OFWZ3()
        {
            //讀取配置文件里的數據庫連接信息
            //server=服務器名;uid=賬號;pwd=密碼;database=要連接的數據庫;Trusted_Connection=no
            StreamReader sr = new StreamReader("文件名路徑\\Config.txt", Encoding.UTF8);
            string connInfor = sr.ReadLine().Trim();
            sr.Close();
            myConnection = new SqlConnection(connInfor);
        }
         #region 操作學生表
        /// 將學生的信息存儲到數據庫中
        protected bool MyStuSave2DB(Student s)
        {
            //1.獲取鏈接-->構造函數已經做了
            //2.建立可以執行SQL語句的SqlCommand
            SqlCommand MyCommand = new SqlCommand("Stu_Insert", myConnection); //定義一個數據庫操作指令

            //3.指明調用的是存儲過程
            MyCommand.CommandType = CommandType.StoredProcedure;//設置該語句是讀取存儲過程的

            //4.給存儲過程傳遞參數
            SqlParameter id = new SqlParameter("@Nid", s.id);
            SqlParameter name = new SqlParameter("@Nname", s.name);
            SqlParameter major = new SqlParameter("@Nmajor", s.major);
            MyCommand.Parameters.Add(id);
            MyCommand.Parameters.Add(name);
            MyCommand.Parameters.Add(major);
            //5.執行存儲過程
            try//異常處理
            {
                myConnection.Open();
                MyCommand.ExecuteNonQuery();
                myConnection.Close();
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            return true;
        }

        /// 讀取學生表中所有的數據
        protected Student[] getAllStuFromDB()
        {
            //1.獲取鏈接--->構造函數已經做了
            //2..建立可以執行SQL語句的SqlCommand
            SqlCommand MyCommand = new SqlCommand("Stu_GetAll", myConnection); //定義一個數據庫操作指令
            //3.指明調用的是存儲過程
            MyCommand.CommandType = CommandType.StoredProcedure;//設置該語句是讀取存儲過程的
            //4.設置數據適配器
            SqlDataAdapter SelectAdapter = new SqlDataAdapter();//定義一個數據適配器
            SelectAdapter.SelectCommand = MyCommand;//定義數據適配器的操作指令
            //5.執行存儲過程
            try
            {
                myConnection.Open();//打開數據庫連接
                SelectAdapter.SelectCommand.ExecuteNonQuery();//執行數據庫查詢指令
                myConnection.Close();//關閉數據庫
            }
            catch (Exception e)
            {
                throw new Exception(e.ToString());
            }
            //6.將結果存儲到DataSet里
            DataSet MyDataSet = new DataSet();//定義一個數據集
            SelectAdapter.Fill(MyDataSet);//填充數據集
            //7.解析DataSet中的數據,并將其封裝到Student數組里
            DataTable dt = MyDataSet.Tables[0];//獲取查詢的結果表(因為只有一個)
            return getStuFroTable(dt);//將DataTable里存儲的學生信息封裝到結構體數組里
        }

        /// 將DataTable里存儲的學生信息封裝到結構體數組里
        private Student[] getStuFroTable(DataTable dt)
        {
            Student[] students = new Student[dt.Rows.Count];
            for (int i = 0; i < dt.Rows.Count; i++)//遍歷行
            {
                students[i].id = dt.Rows[i]["id"].Trim();
                students[i].name = ((string)dt.Rows[i]["name"]).Trim();
                students[i].major = ((string)dt.Rows[i]["major"]).Trim();
            }
            return students;
        }
        #endregion
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,836評論 6 540
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,275評論 3 428
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,904評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,633評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,368評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,736評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,740評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,919評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,481評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,235評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,427評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,968評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,656評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,055評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,348評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,160評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,380評論 2 379

推薦閱讀更多精彩內容

  • 存儲過程和函數是事先經過編譯并存儲在數據庫中的一段 SQL 語句的集合,調用存儲過程和函數可以簡化應用開發人員的很...
    微日月閱讀 1,866評論 0 1
  • DDL 連接:mysql -uroot -p 顯示所有數據庫:show databases 創建數據庫:creat...
    微日月閱讀 557評論 0 1
  • 背景 一年多以前我在知乎上答了有關LeetCode的問題, 分享了一些自己做題目的經驗。 張土汪:刷leetcod...
    土汪閱讀 12,764評論 0 33
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,733評論 18 399
  • 月亮搖搖晃晃的爬上了柳梢,黃昏的余輝早已在冬日里藏起了尾巴。路燈昏黃如洗舊的照片,看不清腳下的遠方,可還是看得清那...
    因顧閱讀 289評論 4 1