收集的常用存储过程,都是一些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:有兴趣的朋友可以继续考虑有小数点以及添加单位(元/角/分)的情况

转载于:https://www.cnblogs.com/kevinGao/archive/2011/12/24/2305567.html

[置顶]常用存储过程集锦相关推荐

  1. sqlserver 常用存储过程集锦

    常用存储过程集锦,都是一些mssql常用的一些,大家可以根据需要选择使用. =================分页========================== /*分页查找数据*/ CREAT ...

  2. 置顶信息[置顶] 常用日常英语缩写

    查了好多资料,发现还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记录吧! i.e.*: that is(即)的缩写("We will do it by eo ...

  3. [置顶] 常用小片段指令集锦

    写道 检测是否是整数 还是这个好使啊 /** * 是否是 整数 */ function isint($value) { $filter = preg_replace('/[^0-9]+/', '', ...

  4. [置顶] Mysql存储过程入门知识

    Mysql存储过程入门知识 #1,查看数据库所有的存储过程名 #--这个语句被用来移除一个存储程序.不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程 #SELECT NAME FROM ...

  5. 置顶-常用资源直接跳转

    Pytorch: pytorch保存.载入模型,与state_dict()有关的操作 pytorch多GPU训练操作(单机多卡,多机多卡) NLP杂七杂八 正则表达式语句速查 正则表达式小括号的使用 ...

  6. 【QT学习】如何隐藏标题栏、任务栏图标及子窗口置顶?(附常用窗口标志)

    文章目录 前言 一.标题栏隐藏 二.子窗口置顶 三.任务栏图标隐藏 四.单击任务栏图标显示(隐藏)窗口 附:QT常用窗口标志 总结 前言    本篇,将介绍如何隐藏窗口标题栏.任务栏图标以及子窗口置顶 ...

  7. 【置顶】利用 NLP 技术做简单数据可视化分析教程(实战)

    置顶 本人决定将过去一段时间在公司以及日常生活中关于自然语言处理的相关技术积累,将在gitbook做一个简单分享,内容应该会很丰富,希望对你有所帮助,欢迎大家支持. 内容介绍如下 你是否曾经在租房时因 ...

  8. [置顶] 均衡音效

    [置顶] 均衡音效 1均衡的作用 均衡器是一种可以分别调节各种频率成分电信号放大量的电子设备,通过对各种不同频率的电信号的调节来补偿扬声器和声场的缺陷,补偿和修饰各种声源及其它特殊作用.具体来说,它的 ...

  9. wordpress置顶文章调用与设置

    文章来源: https://www.xuewangzhan.net/wpbbs/15737.html wordpress网站后台允许我们设置一些置顶文章,然后通过调用置顶文章的代码把它调用到自己的网站 ...

最新文章

  1. libcurl 客户端实例
  2. 定义自己的rm command
  3. 清晰易懂的Numpy入门教程
  4. python面试总结 博客园_python面试题总结
  5. Uva 507 - Jill Rides Again(最大子数组求和问题)
  6. How to solve random black screen on macOS Sierra
  7. pytorch中的CrossEntropyLoss
  8. 北京内推 | 微软亚洲互联网工程院招聘NLP方向研究实习生(可远程)
  9. MongoDB SpringBoot ObjectId序列化json为String
  10. dataguru北京线下沙龙-第二部 《Oracle 索引优化思路--案例分享 -- 刘盛》
  11. Bootstarp4 列表组
  12. 为什么php md5,为什么php md5()总是与python的不同哈希.md5()如果使用汉字?
  13. 利用 Conda 尝鲜 Python 3.10 不一样的特性 快来试试
  14. 微信小程序input安卓手机获取焦点时候上移
  15. error:cv_bridge---opencv和ros连接起来的桥
  16. GridView, DataGrid 中,DataFormatString语法汇总
  17. DbgView 无法开启Capture Kernel问题
  18. Drools教程(基础篇)——Eclipse下Drools运行时安装
  19. 物联网-云开发(Tlink云、机智云、百度云、阿里云等)
  20. 图像保边滤波算法集锦--非局部均值NLM滤波器

热门文章

  1. kotlin面试_Kotlin面试问题
  2. 如何在Java中获取系统属性?
  3. ubuntu ssh密钥_生成SSH密钥以在Ubuntu中进行无密码登录
  4. Akka的类库和模块《six》译
  5. 开课吧:Java开发学习路线-基础知识
  6. C++编程技术常见问题有哪些?
  7. Web前端开发要掌握的技能有哪些?
  8. (转载)python-hwdata
  9. FireFox 在新建标签页插入“片段”广告引社区争议
  10. PHP如何有效实现多视频同时上传功能