`
hududanyzd
  • 浏览: 815417 次
文章分类
社区版块
存档分类
最新评论

常用存储过程集锦

 
阅读更多
收集的常用存储过程,都是一些mssql常用的一些,大家可以根据需要选择使用。

  =================分页==========================


  /*分页查找数据*/
  CREATE PROCEDURE [dbo].[GetRecordSet]
  @strSql varchar(8000),--查询sql,如select * from [user]
  @PageIndex int,--查询当页号
  @PageSize int--每页显示记录
  AS
  set nocount on
  declare @p1 int
  declare @currentPage int
  set @currentPage = 0
  declare @RowCount int
  set @RowCount = 0
  declare @PageCount int
  set @PageCount = 0
  exec sp_cursoropen @p1 output,@strSql,@scrollopt=1,@ccopt=1,@rowcount=@rowCount output --得到总记录数
  select @PageCount=ceiling(1.0*@rowCount/@pagesize) --得到总页数
  ,@currentPage=(@PageIndex-1)*@PageSize+1
  select @RowCount,@PageCount
  exec sp_cursorfetch @p1,16,@currentPage,@PageSize
  exec sp_cursorclose @p1
  set nocount off
  GO



  =========================用户注册============================
  /*
  用户注册,也算是添加吧
  */
  Create proc [dbo].[UserAdd]
  (
  @loginID nvarchar(50),     --登录帐号
  @password nvarchar(50), --密码
  @email nvarchar(200) --电子信箱
  )
  as
  declare @userID int --用户编号
  --登录账号已经被注册
  if exists(select loginID from tableName where loginID = @loginID)
  begin
  return -1;
  end
  --邮箱已经被注册
  else if exists(select email from tableName where email = @email)
  begin
  return -2;
  end
  --注册成功
  else
  begin
  select @userID = isnull(max(userID),100000)+1 from tableName
  insert into tableName
  (userID,loginID,[password],userName,linkNum,address,email,createTime,status)
  values
  (@userID,@loginID,@password,'','','',@email,getdate(),1)
  return @userID
  end


==========================sql server系统存储过程===================


  –1.给表中字段添加描述信息
  Create table T2 (id int , name char (20))
  GO
  EXEC sp_addextendedproperty 'MS_Description', 'Employee ID', 'user', dbo, 'table', T2, 'column', id
  EXEC sp_updateextendedproperty 'MS_Description', 'this is a test', 'user', dbo, 'table', T2, 'column', id
  –2.修改数据库名称
  EXEC sp_renamedb 'old_db_name', 'new_db_name'
  –3.修改数据表名称和字段名称
  EXEC sp_rename 'old_table_name', 'new_table_name'–修改数据表名称
  EXEC sp_rename 'table_name.[old_column_name]', 'new_column_name', 'COLUMN'–修改字段名称
  –4.给定存储过程名,获取存储过程内容
  exec sp_helptext sp_name
  /*以下是有关安全控制的系统存储过程或 SQL 语句,详细语法查阅《联机丛书》相关内容*/
  –创建新的 SQL Server 登录,使用户得以连接使用 SQL Server 身份验证的 SQL Server。
  EXEC sp_addlogin @loginame = '', @passwd = '', @defdb = '', @deflanguage = NULL, @sid = NULL, @encryptopt = NULL
  –使 Windows NT 用户或组帐户得以使用 Windows 身份验证连接到 SQL Server。
  EXEC sp_grantlogin @loginame = ''
  –删除 SQL Server 登录,以阻止使用该登录名访问 SQL Server。
  EXEC sp_droplogin @loginame = ''
  –阻止 Windows NT 用户或组连接到 SQL Server。
  EXEC sp_denylogin @loginame = ''
  –从 SQL Server 中删除用 sp_grantlogin 或 sp_denylogin 创建的 Windows NT 用户或组的登录项。
  EXEC sp_revokelogin @loginame = ''
  –更改登录的默认数据库。
  EXEC sp_defaultdb @loginame = '', @defdb = ''
  –更改登录的默认语言。
  EXEC sp_defaultlanguage @loginame = '', @language = ''
  –添加或更改 SQL Server 登录密码。
  EXEC sp_password @old = '', @new = '', @loginame = ''
  –添加服务器角色新成员。
  EXEC sp_addsrvrolemember @loginame = '', @rolename = ''
  –添加服务器角色某成员。
  EXEC sp_dropsrvrolemember @loginame = '' , @rolename = ''
  –为 SQL Server 登录或 Windows NT 用户或组在当前数据库中添加一个安全帐户,并使其能够被授予在数据库中执行活动的权限(授予默认的“public”数据库角色)。
  EXEC sp_grantdbaccess @loginame = '', @name_in_db = NULL
  –或
  EXEC sp_adduser @loginame = '', @name_in_db = NULL, @grpname = ''
  –从当前数据库中删除安全帐户。
  EXEC sp_revokedbaccess @name_in_db = ''
  –或
  EXEC sp_dropuser @name_in_db = ''
  –在当前数据库创建新数据库角色。
  EXEC sp_addrole @rolename = '', @ownername = ''
  –在当前数据库删除某数据库角色。
  EXEC sp_droprole @rolename = ''
  –在当前数据库中添加数据库角色新成员。
  EXEC sp_addrolemember @rolename = '', @membername = ''
  –在当前数据库中删除数据库角色某成员。
  EXEC sp_droprolemember @rolename = '', @membername = ''
  –权限分配给数据库角色、表、存储过程等对象
  –1、授权访问
  GRANT
  –2、拒绝访问
  DENY
  –3、取消授权或拒绝
  REVOKE
  –4、Sample(pubs):
  GRANT SELECT ON authors TO Limperator
  DENY SELECT ON authors TO Limperator
  REVOKE SELECT ON authors TO Limperator

SQL code
  create proc killspid (@dbname varchar(20))
  as
  begin
  declare @sql nvarchar(500)
  declare @spid int
  set @sql='declare getspid cursor for
  select spid
  from sysprocesses
  where dbid=db_id('''+@dbname+''')'
  exec (@sql)
  open getspid
  fetch next from getspid
  into @spid
  while @@fetch_status <>-1
  begin
  exec('kill '+@spid)
  fetch next from getspid
  into @spid
  end
  close getspid
  deallocate getspid
  end
  GO


  作用:杀掉传入数据库中的活动进程以进行备份还原等独占操作

  ===================阿拉伯数字转大写中文=============

  例:输入12345,程序给出:壹万贰仟叁佰肆拾伍

  例:输入10023040,程序给出:壹仟零贰万叁仟另肆拾

  解决方案之一(在SqlServer2000中测试通过):


  SQL code
  CREATE FUNCTION fun_cgnum
  (@num INT)
  RETURNS VARCHAR(100)
  AS
  BEGIN
  DECLARE @temp INT,@res INT,@i TINYINT
  DECLARE @str VARCHAR(100),@no VARCHAR(20),@unit VARCHAR(16)
  SELECT @str='',@no='零壹贰叁肆伍陆柒捌玖',@unit='拾佰仟万拾佰仟亿'
  SET @temp=@num

SELECT @i=0,@res=@temp%10,@temp=@temp/10
  WHILE @temp>0
  BEGIN
  IF @i=0
  SET @str=SUBSTRING(@no,@res+1,1)
  ELSE
  SET @str=SUBSTRING(@no,@res+1,1)+SUBSTRING(@unit,@i,1)+@str
  SELECT @res=@temp%10,@temp=@temp/10
  SET @i=@i+1
  END
  SET @str=SUBSTRING(@no,@res+1,1)+SUBSTRING(@unit,@i,1)+@str
  SET @str=REPLACE(@str,'零拾','零')
  SET @str=REPLACE(@str,'零佰','零')
  SET @str=REPLACE(@str,'零仟','零')
  SET @str=REPLACE(@str,'零拾','零')
  SET @str=REPLACE(@str,'零万','零')
  WHILE @i>0
  BEGIN
  SET @str=REPLACE(@str,'零零','零')
  SET @i=CHARINDEX('零零',@str)
  END
  SET @str=REPLACE(@str,'零万','万')
  SET @str=REPLACE(@str,'亿万','亿')
  IF RIGHT(@str,1)='另'
  SET @str=LEFT(@str,LEN(@str)-1)
  RETURN @str
  END
  GO


  --测试:有0和没有0的情况

  SELECT dbo.fun_cgnum(900000000),dbo.fun_cgnum(903002051),dbo.fun_cgnum(903002050)

  PS:有兴趣的朋友可以继续考虑有小数点以及添加单位(元/角/分)的情况


分享到:
评论

相关推荐

    123常用存储过程集锦.pdf

    从提供的文件内容中,我们可以梳理出有关SQL Server存储过程、系统过程以及SQL语句的知识点。以下是一些详细的知识点总结: ### SQL Server存储过程 #### GetRecordSet存储过程 - **参数说明**: - `@strSql`:...

    sqlserver 常用存储过程集锦

    本篇将详细讲解文中提到的几个常用存储过程,以及一些与之相关的SQL Server存储过程知识。 1. 分页查找数据:存储过程`[dbo].[GetRecordSet]` 这个存储过程用于实现分页查询,它是数据库应用中常见的需求。通过...

    oracle存储过程常用技巧

    Oracle存储过程常用技巧 Oracle存储过程是一种强大的数据库对象,它可以帮助开发者简化复杂的业务逻辑,并提高数据库的安全性和性能。在 Oracle 中,存储过程是一种特殊的 PL/SQL 程序,它可以接受输入参数,执行...

    SQLServer 常用存储过程

    ### SQL Server 常用存储过程详解 #### 一、分页存储过程 GetRecordSet 在 SQL Server 中,实现分页功能是常见的需求之一。下面详细介绍一个常用的分页存储过程 `GetRecordSet`。 **存储过程定义:** ```sql ...

    Mysql存储过程常用语句模板

    Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三种循环等等) Mysql存储过程常用语句模板(含变量,if,三...

    net常用排序存储过程合集

    总结起来,"net常用排序存储过程合集"是一个综合了.NET中的排序机制和数据库存储过程应用的知识资源,对于提升开发效率和优化系统性能具有重要的参考价值。理解和掌握这些知识点,有助于开发者更好地应对各种数据...

    SQL Server常用的系统存储过程应用实例

    本篇文章将深入探讨一些常用的系统存储过程,并通过实例介绍它们的应用。 首先,我们来看`sp_attach_db`这个存储过程。它的主要作用是将已经分离的数据库重新附加到SQL Server实例上。在使用`sp_attach_db`时,我们...

    sqlserver常用的存储过程

    本文介绍了 SQL Server 中几种常用存储过程的应用场景及其实现方式。通过这些存储过程,不仅可以提高应用程序的性能,还可以简化复杂的数据库操作,使得数据库的管理和维护更加便捷高效。在实际项目开发中,合理运用...

    Informatica调用存储过程图文流程

    调用存储过程是 Informatica 中的一种常用功能,下面将详细介绍 Informatica 调用存储过程的图文流程。 什么是存储过程 存储过程(Stored Procedure)是一组为了完成特定功能的 SQL 语句集合,存储在数据库中,...

    存储过程文档--mysql

    存储过程是 MySQL 中的一个强大功能,它允许用户预先将常用的或复杂的工作写入 SQL 语句,并将其存储起来,以便在以后的数据库操作中可以快速调用和执行。存储过程可以提高数据库的执行速度,减少数据库开发人员的...

    SQL Server中存储过程比直接运行SQL语句慢的原因

    用户自定义的存储过程是我们所指的存储过程,常用格式为 Create procedure procedue_name [@parameter data_type][output] [with]{recompile|encryption} as sql_statement。 在优化存储过程时,需要注意 Parameter...

    Oracle学习开发常用的SQL和存储过程学习(内含SQL面试题目和存储过程,函数面试题目).zip

    本资源“Oracle学习开发常用的SQL和存储过程学习(内含SQL面试题目和存储过程,函数面试题目).zip”提供了全面的学习材料,旨在帮助初学者和求职者提升在Oracle数据库中的SQL查询和存储过程编写技能。 SQL...

    存储过程-02.03.存储过程常用操作

    本篇将深入探讨存储过程的常用操作,旨在帮助你更好地理解和运用这一强大的数据库工具。 一、创建存储过程 创建存储过程是其所有操作的起点。在SQL中,我们可以使用`CREATE PROCEDURE`语句定义一个存储过程。例如,...

    sqlserver 存储过程 函数 常用知识点

    以下是关于SQL Server存储过程和函数的一些常用知识点: 1. **存储过程(Stored Procedures)**: - **定义**:存储过程是一组预编译的SQL语句,可以接受参数,执行特定任务,如数据查询、更新或插入等。 - **...

    常用的存储过程

    在给出的例子中,我们看到了一些常用的系统存储过程: 1. `sp_databases`:显示所有数据库的信息。 2. `sp_tables`:列出指定数据库中的所有表。 3. `sp_columns`:查看指定表的列信息。 4. `sp_helpIndex`:展示表...

    常用SQL工具存储过程与函数.rar

    本压缩包“常用SQL工具存储过程与函数.rar”可能包含了一些常见SQL工具中用于管理和操作数据库存储过程与函数的相关资料,如日志文件(spTool_Log.LDF)和数据文件(spTool_Data.MDF)。 存储过程是预编译的SQL语句...

    数据库的存储过程

    数据库的存储过程是数据库管理系统提供的一种预编译的SQL语句集合,它是数据库中的一个对象,可以被多次调用,从而提高数据访问的效率。在本文中,我们将深入探讨存储过程的基本理念、语法以及常见的实现方式,特别...

Global site tag (gtag.js) - Google Analytics