美文网首页数据库
浅谈数据库中的存储过程

浅谈数据库中的存储过程

作者: _王子_ | 来源:发表于2017-04-08 10:30 被阅读26次

一、存储过程与函数的区别:

  1.一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。

  2.对于存储过程来说可以返回参数(output),而函数只能返回值或者表对象。

  3.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。

二、存储过程的优点:

  1.执行速度更快 – 在数据库中保存的存储过程语句都是编译过的

  2.允许模块化程序设计 – 类似方法的复用

  3.提高系统安全性 – 防止SQL注入

  4.减少网络流通量 – 只要传输存储过程的名称

系统存储过程一般以sp开头,用户自定义的存储过程一般以usp开头

三、定义存储过程语法,"[" 里面的内容表示可选项

  create proc 存储过程名

  @参数1 数据类型 [=默认值] [output],

  @参数2 数据类型 [=默认值] [output],

  ...

  as

  SQL语句

四、简单的一个例子

  定义存储过程:

  create proc usp_StudentByGenderAge

  @gender nvarchar(10) [='男'],

  @age int [=30]

  as

  select * from MyStudent where FGender=@gender and FAge=@age

  执行存储过程:

Situation One(调用默认的参数):

  exec usp_StudentByGenderAge

Situation Two(调用自己指定的参数):

  exec usp_StudentByGenderAge '女',50

或者指定变量名 exec usp_StudentByGenderAge @age=50,@gender='女'

  对存储过程进行修改

  alter proc usp_StudentByGenderAge

  @gender nvarchar(10) [='男'],

  @age int [=30],

--加output表示该参数是需要在存储过程中赋值并返回的

  @recorderCount int output

  as

  select * from MyStudent where FGender=@gender and FAge=@age

  set @recorderCount=(select count(*) from MyStudent where FGender=@gender and FAge=@age)

--output参数的目的,就是调用者需要传递一个变量进来,然后在存储过程中为该变量完成赋值工作,存储过程执行完成以后,将执行的对应结果返回给传递进来的变量。(与C#中的out原理一模一样)

调用(记住这里的语法!)因为该存储过程前面还有其他参数,所以要把 @recorderCount写上,该存储过程执行后,相当与完成了以上的查询工作,同时将查询结果得到的条数赋值给了@count变量。(@count是当做参数传给usp_StudentByGenderAge,当存储过程执行完毕以后,将得到的条数返回给@count)

  declare @count int

  exec usp_StudentByGenderAge @recorderCount=@count output

  print @count

五、使用存储过程完成分页

1、存储过程代码

  create proc usp_page

  @page int,  ---一页显示多少条记录

  @number int, ---用户选择了第几页数据

as

  begin

  select * from

  --小括号里面内容是专门得到排列好的序号

  (

    select ROW_NUMBER() over(order by(Fid)) as number

    from MyStudent

  ) as t

  where t.number>= (@number-1)*@page+1 and t.number<=@number*@page

   end

2、实现分页效果对应的ADO.NET代码:

1privatevoid button1_Click(object sender, EventArgs e)

  {

2string connStr = @"server=.\sqlexpress;database=MyDB;integrated security=true";

3using (SqlConnection conn = new SqlConnection(connStr))

4   {

5//打开数据库连接

6     conn.Open();

7//用存储过程名作为Command处理的对象

8string usp = "usp_page";

9using (SqlCommand cmd = new SqlCommand(usp, conn))

10     {

11//执行的是存储过程语句

12       cmd.CommandType = CommandType.StoredProcedure;

 //textBox1.Text是指显示多少条记录

13       cmd.Parameters.AddWithValue("@page", textBox1.Text.Trim());

14//textBox.Text是指用户选择了第几页

15       cmd.Parameters.AddWithValue("@number", textBox2.Text.Trim());

16//用list作为数据源来实现

17       List p = new List();

18using (SqlDataReader reader = cmd.ExecuteReader())

19       {

20if (reader.HasRows)

21         {

22while (reader.Read())

24           {

25             Person p1 = new Person();

26             p1.FName = reader.GetString(1);

27             p1.FAge = reader.GetInt32(2);

28             p1.FGender = reader.GetString(3);

29             p1.FMath = reader.GetInt32(4);

30             p1.FEnglish = reader.GetInt32(5);

31             p.Add(p1);

32           }

33         }

34       }

35       dataGridView1.DataSource = p;

36     }

37   }

38 }

下面是自定义的Person类

转自浅谈数据库中的存储过程 - 秋恨雪 - 博客园

相关文章

  • 浅谈数据库中的存储过程

    一、存储过程与函数的区别: 1.一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。 2.对于...

  • SQL Server存储过程总结

    SQL Server存储过程总结 存储过程简介: 存储过程(Stored Procedure)是在大型数据库中,一...

  • SQL语言:存储过程

    前言 本章我们将学习数据库中的存储过程,了解什么是存储过程,以及在MySQL中创建和调用存储过程。 存储过程是什么...

  • 存储过程

    1.什么是存储过程: 存储过程与存储函数 存储过程是数据库预先编译好,放在数据库内存中的一个程序片段,所有具备性能...

  • 数据库:储存过程与触发器

    储存过程: 存储过程是存储在数据库目录中的一段声明性SQL语句。 存储过程是数据库中的一个重要对象,用户通过指定存...

  • MySQL 高级特性(六):存储过程的优缺点分析

    MySQL 5.0 版本开始支持存储过程。存储过程(Stored Procedure)是数据库中存储的复杂程序,以...

  • MySQL 高级特性(六):存储过程的优缺点分析

    MySQL 5.0 版本开始支持存储过程。存储过程(Stored Procedure)是数据库中存储的复杂程序,以...

  • 浅谈存储过程

    【1】什么是过程?过程与函数的区别?什么是存储过程??? 存储过程:存储在数据库中的封装了若干条SQL语句的过程(...

  • 浅谈数据库之存储过程

    什么是存储过程 如果你接触过其他的编程语言,那么就好理解了,存储过程就像是方法一样。 竟然他是方法那么他就有类...

  • PL/SQL之存储过程

    存储过程、存储函数和触发器 存储过程和存储函数定义:指存储在数据库中供所有用户程序调用的子程序叫存储过程或存储函数...

网友评论

    本文标题:浅谈数据库中的存储过程

    本文链接:https://www.haomeiwen.com/subject/qaclattx.html