`

浅谈数据库中的存储过程

sql 
阅读更多

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

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

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

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

二、存储过程的优点:

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

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

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

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

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

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

create proc 存储过程名

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

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

  ...

  as

四、简单的一个例子

  定义存储过程:

 

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
 ```
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)

 

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

 

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代码:

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

  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代码:

private void button1_Click(object sender, EventArgs e) 
  {
  string connStr = @"server=.\sqlexpress;database=MyDB;integrated security=true";
  using (SqlConnection conn = new SqlConnection(connStr))
  {
    //打开数据库连接
    conn.Open();
    //用存储过程名作为Command处理的对象
    string usp = "usp_page";
    using (SqlCommand cmd = new SqlCommand(usp, conn))
    {
      //执行的是存储过程语句
      cmd.CommandType = CommandType.StoredProcedure;
        //textBox1.Text是指显示多少条记录
      cmd.Parameters.AddWithValue("@page", textBox1.Text.Trim());
      //textBox.Text是指用户选择了第几页
      cmd.Parameters.AddWithValue("@number", textBox2.Text.Trim());
      //用list作为数据源来实现
      List<Person> p = new List<Person>();
      using (SqlDataReader reader = cmd.ExecuteReader())
      {
        if (reader.HasRows)
        {
          while (reader.Read())
          {
            Person p1 = new Person();
            p1.FName = reader.GetString(1);
            p1.FAge = reader.GetInt32(2);
            p1.FGender = reader.GetString(3);
            p1.FMath = reader.GetInt32(4);
            p1.FEnglish = reader.GetInt32(5);
            p.Add(p1);
          }
        }
      }
      dataGridView1.DataSource = p;
    }
  }
}
分享到:
评论

相关推荐

    浅谈数据库设计技巧经验

    在设计过程中,不仅要关注当前的需求,还要考虑到未来的变化和发展,这样才能构建出既实用又灵活的数据库系统。 通过对不同类型设计者的分析和具体案例的探讨,我们可以看到,优秀的数据库设计不仅能够提高系统的...

    浅谈数据库设计技巧-程序员应该读的

    数据库设计是软件开发过程中的关键环节,尤其是在大数据和云计算时代,高效、稳定、灵活的数据库设计对于系统的性能、可扩展性和数据安全性具有决定性影响。本文将深入探讨数据库设计的一些重要技巧,帮助程序员提升...

    浅谈数据库之存储过程

     通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全。  通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。  在运行存储过程前,数据库已对其进行了语法...

    浅谈SQL Server数据库中存储过程的应用——以电子交易系统为例.pdf

    本文以大宗商品现货电子交易系统为例,探讨了SQL Server数据库存储过程的应用,以及触发器技术在电子交易系统中的运用。 首先,介绍SQL Server数据库系统。Microsoft SQL Server是一款可扩展、高性能的关系型数据库...

    浅谈分布式数据库在地理信息系统中的应用.pdf

    例如在Geoway软件中,空间数据和属性数据分别存储在不同的文件格式中,这种管理方式也促进了分布式数据库在GIS系统中的快速发展。 5. 分布式数据库的特点及其在GIS中的作用 分布式数据库由于其数据存储、管理和应用...

    浅谈SQL Server数据库应用技巧.pdf

    SQL Server作为一款成熟的关系型数据库管理系统,被广泛应用于各种企业级应用中,它为企业信息管理提供了高效稳定的解决方案。随着信息技术的快速发展和企业信息化需求的不断增长,SQL Server数据库的性能优化越来越...

    浅谈数据库设计.doc

    在这个过程中,系统分析报告的编写至关重要,它不仅为数据库设计提供了依据,也为后续各阶段提供了标准。例如,对于一家企业而言,需求分析可能涉及人事档案的管理和使用效率,确定未来系统应支持的查询、统计和更新...

    架构革新高效可控_浅谈数据库服务和架构演讲V7.pdf

    【标题】:“架构革新高效可控_浅谈数据库服务和架构演讲V7.pdf”主要探讨了数据库服务和架构的演进,以及如何通过技术创新解决开发者在实际工作中遇到的问题。该演讲内容涉及关系型数据库、分析型数据库、图数据库...

    浅谈数据库系统优化.docx

    数据库性能优化不仅涉及数据处理速度,还涵盖了存储、查询等多个方面,需要在整个系统生命周期内持续进行。 首先,数据库设计是优化的基础。数据库的物理设计包括数据对象在存储介质上的布局,如数据块的大小,这...

    浅谈数据库设计技巧 关于sql

    【数据库设计技巧】 数据库设计是IT领域中至关重要的一部分,它涉及到如何有效地组织和存储数据,以便于高效地访问...在设计过程中,需要结合具体业务场景,灵活运用各种设计原则和技术,以实现最佳的数据库解决方案。

    浅谈数据库与地理信息系统.doc

    GIS与数据库之间的关系体现在数据的转化和处理过程中。数据是GIS的基础,是未经处理的原始材料,可以是数字、文本、符号或图像等形式。GIS需要对这些数据进行收集、筛选、转换、存储、分析等一系列操作,使其转化为...

    浅谈Java程序员的存储过程.doc

    ### 浅谈Java程序员的存储过程 #### 一、存储过程概述 存储过程是一种预先编写的、被存储在数据库服务器中的程序,可以在数据库端执行。它们可以被看作是数据库的功能扩展,允许开发者利用数据库的强大功能来处理...

    浅谈SQL数据库备份.pdf

    "浅谈SQL数据库备份.pdf" 本文将对SQL Server数据库备份进行详细介绍,包括根据数据库向导备份数据库、脚本备份数据库、通过数据库代 理服务器自动备份数据库及通过导出数据库结构和数据脚本备份数据库四种方法。 ...

    网络安全:浅谈数据库加密技术.pdf

    动态加密是指数据在使用过程中自动对数据进行加密或解密操作,无需用户的干预。 (2)文件级动态加解密技术 文件系统层可以研制出功能非常强大的文档安全产品。支持动态加密的文件系统可以提供和磁盘级加密技术相...

    浅谈SQL Server中存储过程的一点用法.pdf

    SQL Server作为一种流行的数据库系统,其存储过程功能得到了广泛应用,尤其是在广播节目数据库的维护和优化中。本文将详细探讨SQL Server中存储过程的应用,包括其优点、分类、创建和使用方法,以及在广播节目数据库...

    架构革新高效可控_浅谈数据库服务和架构演讲V7.zip

    在“架构革新高效可控_浅谈数据库服务和架构演讲V7.zip”这个压缩包中,包含了一份关于数据库服务和架构的演讲稿,标题为“架构革新高效可控”。这份文档可能详细探讨了如何通过架构的创新来提升数据库服务的效率和...

    浅谈大数据处理中的数据库I_O问题.pdf

    【大数据处理中的数据库I/O问题】是信息技术领域中一个关键的话题。随着大数据时代的到来,对高性能数据库的需求日益增长。然而,传统的基于文件的数据库系统在处理海量数据时,经常遇到性能瓶颈,如长时间的响应...

    浅谈分布式数据库跨库操作的安全设计.pdf

    在此过程中,涉及到的技术点包括数据库链接(Database Link)、同义词(Synonym)和存储过程(Stored Procedure),它们在提供便利的同时也引入了潜在的安全风险。 数据库链接是跨库操作的基础,它允许用户通过本地...

    浅谈分布式数据库架构.pdf

    语法验证通过后,进一步进行语义验证,确保所有涉及的数据库对象(如表名、列名、存储过程等)真实存在,如果存在错误同样返回信息并结束查询。之后,服务器会获取对象的解析锁以保证数据的一致性,并对请求用户的...

Global site tag (gtag.js) - Google Analytics