返回顶部
首页 > 资讯 > 数据库 >sql通用存储过程的语法
  • 395
分享到

sql通用存储过程的语法

2024-04-02 19:04:59 395人浏览 泡泡鱼
摘要

本篇内容主要讲解“sql通用存储过程的语法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sql通用存储过程的语法”吧!Transact-SQL中的存储过程,非常

本篇内容主要讲解“sql通用存储过程的语法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sql通用存储过程的语法”吧!

Transact-SQL中的存储过程,非常类似于Java语言中的方法,它可以重复调用。当存储过程执行一次后,可以将语句缓存中,这样下次执行的时候直接使用缓存中的语句。这样就可以提高存储过程的性能。

Ø 存储过程的概念

    存储过程Procedure是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中,用户通过指定存储过程的名称并给出参数来执行。

    存储过程中可以包含逻辑控制语句和数据操纵语句,它可以接受参数、输出参数、返回单个或多个结果集以及返回值。

    由于存储过程在创建时即在数据库服务器上进行了编译并存储在数据库中,所以存储过程运行要比单个的SQL语句块要快。同时由于在调用时只需用提供存储过程名和必要的参数信息,所以在一定程度上也可以减少网络流量、简单网络负担。

    1、 存储过程的优点

        A、 存储过程允许标准组件式编程

        存储过程创建后可以在程序中被多次调用执行,而不必重新编写该存储过程的SQL语句。而且数据库专业人员可以随时对存储过程进行修改,但对应用程序源代码却毫无影响,从而极大的提高了程序的可移植性。

        B、 存储过程能够实现较快的执行速度

        如果某一操作包含大量的T-SQL语句代码,分别被多次执行,那么存储过程要比批处理的执行速度快得多。因为存储过程是预编译的,在首次运行一个存储过程时,查询优化器对其进行分析、优化,并给出最终被存在系统表中的存储计划。而批处理的T-SQL语句每次运行都需要预编译和优化,所以速度就要慢一些。

        C、 存储过程减轻网络流量

        对于同一个针对数据库对象的操作,如果这一操作所涉及到的T-SQL语句被组织成一存储过程,那么当在客户机上调用该存储过程时,网络中传递的只是该调用语句,否则将会是多条SQL语句。从而减轻了网络流量,降低了网络负载。

        D、 存储过程可被作为一种安全机制来充分利用

        系统管理员可以对执行的某一个存储过程进行权限限制,从而能够实现对某些数据访问的限制,避免非授权用户对数据的访问,保证数据的安全。

Ø 系统存储过程

    系统存储过程是系统创建的存储过程,目的在于能够方便的从系统表中查询信息或完成与更新数据库表相关的管理任务或其他的系统管理任务。系统存储过程主要存储在master数据库中,以“sp”下划线开头的存储过程。尽管这些系统存储过程在master数据库中,但我们在其他数据库还是可以调用系统存储过程。有一些系统存储过程会在创建新的数据库的时候被自动创建在当前数据库中。

    常用系统存储过程有:

exec sp_databases; --查看数据库exec sp_tables;        --查看表exec sp_columns student;--查看列exec sp_helpIndex student;--查看索引exec sp_helpConstraint student;--约束exec sp_stored_procedures;exec sp_helptext 'sp_stored_procedures';--查看存储过程创建、定义语句exec sp_rename student, stuInfo;--修改表、索引、列的名称exec sp_renamedb myTempDB, myDB;--更改数据库名称exec sp_defaultdb 'master', 'myDB';--更改登录名的默认数据库exec sp_helpdb;--数据库帮助,查询数据库信息exec sp_helpdb master;


    系统存储过程示例:

--表重命名exec sp_rename 'stu', 'stud';select * from stud;
--列重命名exec sp_rename 'stud.name', 'sName', 'column';exec sp_help 'stud';
--重命名索引exec sp_rename N'student.idx_cid', N'idx_cidd', N'index';exec sp_help 'student';

--查询所有存储过程select * from sys.objects where type = 'P';select * from sys.objects where type_desc like '%pro%' and name like 'sp%';

Ø 用户自定义存储过程

   1、 创建语法

create proc | procedure pro_name
    [{@参数数据类型} [=默认值] [output],
     {@参数数据类型} [=默认值] [output],
     ....
    ]asSQL_statements

   2、 创建不带参数存储过程

--创建存储过程if (exists (select * from sys.objects where name = 'proc_get_student'))drop proc proc_get_studentGocreate proc proc_get_studentasselect * from student;

--调用、执行存储过程exec proc_get_student;

   3、 修改存储过程

--修改存储过程alter proc proc_get_studentasselect * from student;

   4、 带参存储过程

--带参存储过程if (object_id('proc_find_stu', 'P') is not null)drop proc proc_find_stugocreate proc proc_find_stu(@startId int, @endId int)asselect * from student where id between @startId and @endIdgoexec proc_find_stu 2, 4;

   5、 带通配符参数存储过程

--带通配符参数存储过程if (object_id('proc_findStudentByName', 'P') is not null)drop proc proc_findStudentByNamegocreate proc proc_findStudentByName(@name varchar(20) = '%j%', @nextName varchar(20) = '%')asselect * from student where name like @name and name like @nextName;goexec proc_findStudentByName;exec proc_findStudentByName '%o%', 't%';

   6、 带输出参数存储过程

if (object_id('proc_getStudentRecord', 'P') is not null)drop proc proc_getStudentRecordgocreate proc proc_getStudentRecord(
    @id int, --默认输入参数
    @name varchar(20) out, --输出参数
    @age varchar(20) output--输入输出参数
)asselect @name = name, @age = age  from student where id = @id and sex = @age;go-- declare @id int,
        @name varchar(20),
        @temp varchar(20);set @id = 7; 
set @temp = 1;exec proc_getStudentRecord @id, @name out, @temp output;select @name, @temp;print @name + '#' + @temp;

   7、 不缓存存储过程

--WITH RECOMPILE 不缓存if (object_id('proc_temp', 'P') is not null)drop proc proc_tempgocreate proc proc_tempwith recompileasselect * from student;goexec proc_temp;

   8、 加密存储过程

--加密WITH ENCRYPTioN 
if (object_id('proc_temp_encryption', 'P') is not null)drop proc proc_temp_encryptiongocreate proc proc_temp_encryptionwith encryptionasselect * from student;goexec proc_temp_encryption;exec sp_helptext 'proc_temp';exec sp_helptext 'proc_temp_encryption';

   9、 带游标参数存储过程

if (object_id('proc_cursor', 'P') is not null)drop proc proc_cursorgocreate proc proc_cursor
    @cur cursor varying outputasset @cur = cursor forward_only static forselect id, name, age from student;open @cur;go--调用declare @exec_cur cursor;declare @id int,
        @name varchar(20),
        @age int;exec proc_cursor @cur = @exec_cur output;--调用存储过程fetch next from @exec_cur into @id, @name, @age;while (@@fetch_status = 0)beginfetch next from @exec_cur into @id, @name, @age;print 'id: ' + convert(varchar, @id) + ', name: ' + @name + ', age: ' + convert(char, @age);endclose @exec_cur;deallocate @exec_cur;--删除游标

   10、 分页存储过程

---存储过程、row_number完成分页if (object_id('pro_page', 'P') is not null)drop proc proc_cursorgocreate proc pro_page
    @startIndex int,
    @endIndex intasselect count(*) from product
;    select * from (select row_number() over(order by pid) as rowId, * from product 
    ) tempwhere temp.rowId between @startIndex and @endIndexgo--drop proc pro_pageexec pro_page 1, 4----分页存储过程if (object_id('pro_page', 'P') is not null)drop proc pro_stugocreate procedure pro_stu(
    @pageIndex int,
    @pageSize int)asdeclare @startRow int, @endRow intset @startRow = (@pageIndex - 1) * @pageSize +1set @endRow = @startRow + @pageSize -1select * from (select *, row_number() over (order by id asc) as number from student 
    ) twhere t.number between @startRow and @endRow;exec pro_stu 2, 2;

Ø Raiserror

Raiserror返回用户定义的错误信息,可以指定严重级别,设置系统变量记录所发生的错误。

   语法如下:

Raiserror({msg_id | msg_str | @local_variable}
  {, severity, state}
  [,argument[,…n]]
  [with option[,…n]]
)

   # msg_id:在sysmessages系统表中指定的用户定义错误信息

   # msg_str:用户定义的信息,信息最大长度在2047个字符。

   # severity:用户定义与该消息关联的严重级别。当使用msg_id引发使用sp_addmessage创建的用户定义消息时,raiserror上指定严重性将覆盖sp_addmessage中定义的严重性。

    任何用户可以指定0-18直接的严重级别。只有sysadmin固定服务器角色常用或具有alter trace权限的用户才能指定19-25直接的严重级别。19-25之间的安全级别需要使用with log选项。

   # state:介于1至127直接的任何整数。State默认值是1。

raiserror('is error', 16, 1);select * from sys.messages;
--使用sysmessages中定义的消息raiserror(33003, 16, 1);raiserror(33006, 16, 1);

到此,相信大家对“sql通用存储过程的语法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

您可能感兴趣的文档:

--结束END--

本文标题: sql通用存储过程的语法

本文链接: https://lsjlt.com/news/59782.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • sql通用存储过程的语法
    本篇内容主要讲解“sql通用存储过程的语法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“sql通用存储过程的语法”吧!Transact-SQL中的存储过程,非常...
    99+
    2024-04-02
  • sql存储过程语法是什么
    SQL存储过程是一段预编译的SQL代码块,可以在数据库中存储和执行。它可以包含SQL语句、控制结构和变量声明等,用于执行特定的操作而...
    99+
    2023-10-07
    sql
  • 通过sql存储过程发送邮件的方法步骤
    这篇文章主要介绍“通过sql存储过程发送邮件的方法步骤”,在日常操作中,相信很多人在通过sql存储过程发送邮件的方法步骤问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”通过sq...
    99+
    2024-04-02
  • SQL SERVER存储过程用法详解
    目录一、存储过程的概念存储过程的优点二、存储过程的分类1、系统存储过程2、临时存储过程3、用户自定义存储过程二、存储过程的用法1、不带参数的存储过程,获取MyStudentInfo表...
    99+
    2024-04-02
  • mysql存储过程中各种动态sql语句的用法
    本文主要给大家简单讲讲mysql存储过程中各种动态sql语句的用法,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望mysql存储过程中各种动态sql语句的用法...
    99+
    2024-04-02
  • SQL Server的存储过程
    本篇内容主要讲解“SQL Server的存储过程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SQL Server的存储过程”吧! 首先介绍一下什么是存储过程...
    99+
    2024-04-02
  • SQL Server存储过程
    理论知识:开始一、TRUNCATE    快速地从一堆表中删除所有行。它和在每个表上进行无条件的 DELETE 有同样的效果,不过因为它不做表扫描,因而快得多。 在大表...
    99+
    2024-04-02
  • SQL之存储过程
    文章目录 一、介绍二、基本语法三、变量系统变量自定义变量局部变量 四、条件、循环判断if语法:参数casewhilerepeatloop 五、游标条件处理程序 一、介绍 存储...
    99+
    2023-08-31
    sql 数据库 mysql
  • 3. SQL -- 存储过程
    存储过程在Sql Server中,可以定义子程序存放在数据库中,这样的子程序称为存储过程,它是数据库对象之一.一存储过程的优点:1: 存储过程在服务器端运行,执行速度快2: 存储过程只执行一次,然后把编译的二进制代码保存在调整缓存中,以后可...
    99+
    2023-01-31
    存储过程 SQL
  • 存储过程定义语法
    CREATE  PROCEDURE `addTicket`(in vipsql VARCHAR(255),in ordersql VARCHAR(255),in detailkey...
    99+
    2024-04-02
  • MySQL 存储过程CASE语句用法
    MySQL提供了一个替代的条件语句CASE。 MySQL CASE语句使代码更加可读和高效。 CASE语句有两种形式:简单的搜索CASE语句。下面讲讲MySQL 存储过程CASE语句用法。 1,CASE语法...
    99+
    2024-04-02
  • SQL中怎么用语句查看存储过程
    在SQL中,可以使用以下语句来查看存储过程:sqlSHOW PROCEDURE STATUS;这条语句将显示数据库中所有存储过程的信...
    99+
    2023-10-18
    SQL
  • sqlserver通用分页的存储过程
    这篇文章主要讲解了“sqlserver通用分页的存储过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“sqlserver通用分页的存储过程”吧! ...
    99+
    2024-04-02
  • VB.NET调用SQL Server的存储过程
    VB.NET调用SQL Server的存储过程,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。VB.NET编程语言对于数据库的操作,我们51CTO以前也介绍了不少。比如VB....
    99+
    2023-06-17
  • 存储过程用法
    创建无参存储过程 1 create procedure proc_test01 2 as 3 begin 4 select * from myrptdetail 5 end 执行无参存储过程 exec proc_tes...
    99+
    2017-09-20
    存储过程用法
  • oracle存储过程的基本语法
    本篇内容介绍了“oracle存储过程的基本语法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! orac...
    99+
    2024-04-02
  • SQL存储过程简介
    存储过程概述 存储过程是完成特定功能的一组SQL语句,它是数据库的一种可编程对象,类似于函数 其快速、灵活、安全 系统存储过程 SQL sever 内置的存储过程,存储在master库中,主要用于执行SQL sever的某些功能、...
    99+
    2020-01-05
    SQL存储过程简介
  • sql存储过程有什么用
    小编给大家分享一下sql存储过程有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!sql存储过程是可编程函数,在数据库中创建...
    99+
    2024-04-02
  • sql怎么调用存储过程
    在SQL中调用存储过程可以通过以下步骤实现: 创建存储过程: 首先在数据库中创建存储过程,可以使用CREATE PROCEDURE...
    99+
    2024-04-02
  • SQL Server的存储过程详解
    目录存储过程的概念存储过程的优点系统存储过程用户自定义存储过程1、 创建语法2、 创建不带参数存储过程3、 修改存储过程4、 带参存储过程5、 带通配符参数存储过程6、 带输出参数存...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作