-
sql2005存储过程分页示例代码
复制代码代码如下:--分页存储过程示例AlterPROCEDURE[dbo].[JH_PageDemo]@pageSizeint=9000000000,@pageIndexint=1,@orderByNvarchar(200)=''--不加orderByASSETNOCOUNTON--声明变量DECLARE@selectVARCHAR(3048);DECLARE@fromVARCHAR(512);DECLARE@RowNumberVARCHAR(256);DECLARE@conditionnVARCHAR(3990);DECLARE@groupByvarchar(50);DECLARE@sqlVARCHAR(3998);DECLARE@RowStartIndexINT;DECLARE@RowEndIndexINT;BEGINSETNOCOUNTonIF@orderBy<>''Set@orderBy='ORDERBY'+@orderBy;elseSet@orderBy='ORDERBYUserid';SET@select='selectuserid,username,';--...
数据库操作教程 2022-09-23 16:52:11 -
一次SQL调优数据库性能问题后的过程(300W)
将绝大部分的SQL查询改为存储过程,这样的操作毫无疑问可以提高部分性能。凡是使用“select*fromxxx”的操作一律具体到所需字段...
数据库操作教程 2022-09-23 16:51:35 -
sqlserver存储过程带事务拼接id返回值
删除一条留言信息会级联删除回复信息,这时我们需要用到事务,如下SQL复制代码代码如下:ALTERPROCEDURE[dbo].[proc_tb_leaveword_delete] ( @leavewordIDINT, @recordTINYINTOUTPUT ) AS BEGIN BEGINTRY BEGINTRANSACTION DELETEFROMtb_leavewordIDWHEREleavewordID=@leavewordID &...
数据库操作教程 2022-09-23 16:50:04 -
SqlServer中存储过程中输入和输出参数(简单实例一看就懂)
[sql]--===================【创建存储过程】=====================USE[Message]GO/******Object:StoredProcedure[dbo].[读取外部数据库查询]ScriptDate:10/24/201205:39:16******/SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGO--=============================================Working没有变1,错误码没有测试,计划时间测试,企业名称createPROCEDURE[dbo]...
数据库操作教程 2022-09-23 16:49:55 -
sql存储过程批量删除数据的语句
复制代码代码如下:CreatePROCEDUREBatch_Delete@TableNamenvarchar(100),--表名@FieldNamenvarchar(100)...
数据库操作教程 2022-09-23 16:48:31 -
存储过程实现(可带查询条件/万能分页/通用)
假设数据库中有张表,表名是UserName,字段分别是ID(int),Name(nvarchar),Age(int)。如果不带查询条件存储过程是:复制代码代码如下:CREATEPROCEDURE[dbo].[UserName]@pageIndexint,@pageSizeintASdeclare@minint;declare@maxint;set@min=@pageSize*(@pageIndex-1)+1;set@max=@pageSize*@pageIndex;withmyTableas(selectID,Name,Age,Row_Number()over(orderbyID)asrownumfrom[UserName])selectID,Name,AgefrommyTablewhererownumbetween@minand@maxRETURN这个分页存储过程很不实用,并且表是固定的...
数据库操作教程 2022-09-23 16:47:56 -
sqlserver数据库使用存储过程和dbmail实现定时发送邮件
上文已讲过如何在数据库中配置数据库邮件发送(备注:数据库邮件功能是基于SMTP实现的,首先在系统中配置SMTP功能。即在“添加/删除程序”面板中“增加/删除WINDOWS组件”,选中并双击打开"IIS"或“应用程序”,勾选"SMTPSERVICE"然后一路点“下一步”即可...
数据库操作教程 2022-09-23 16:47:34 -
浅析SQL存储过程和事务处理
在数据库编程中,事务是经常需要用到的技术,在.net平台上,事务处理是非常好用的,但是在SqlServer数据库的存储过程中如何使用事务来完成数据的批量操作呢?解决方案如下:大概都是这样处理的:复制代码代码如下:CREATEPROCRegisterUser(@usrNamevarchar(30),@usrPasswdvarchar(30),@ageint,@PhoneNumvarchar(20),@Addressvarchar(50))ASBEGINBEGINTRAN--显示定义并开始一个事务SETXACT_ABORTON--表示遇到错误立即回滚INSERTINTOUSER(userName,userPasswd)values(@usrName,@usrPasswd)IF@@error<>0 --发生错误BEGIN ROLLBACKTRANSACTION RETURN0ENDELSEBEGIN COMMITTRANSACTION RETURN1  ...
数据库操作教程 2022-09-23 16:47:04 -
SQLServer常用存储过程及示例
分页:复制代码代码如下:/*分页查找数据*/CREATEPROCEDURE[dbo].[GetRecordSet]@strSqlvarchar(8000),--查询sql,如select*from[user]@PageIndexint,--查询当页号@PageSizeint--每页显示记录ASsetnocountondeclare@p1intdeclare@currentPageintset@currentPage=0declare@RowCountintset@RowCount=0declare@PageCountintset@PageCount=0execsp_cursoropen@p1output,@strSql,@scrollopt=1,@ccopt=1,@rowcount=@rowCountoutput--得到总记录数select@PageCount=ceiling(1.0*@rowCount/@pagesize)--得到总页数,@currentPage=(@PageIndex-1)*@PageSize+1select@RowCount,@PageCountexecsp_cu...
数据库操作教程 2022-09-23 16:46:51 -
查询存储过程中特定字符的方法
把xx替换成具体字符,如“深圳”,sql语句如下:复制代码代码如下:select*fromuser_sourcetwhereinstr(lower(t.text),'xx')>0;select*fromall_sourcetwheret...
数据库操作教程 2022-09-23 16:46:32 -
SQL实现递归及存储过程中In()参数传递解决方案详解
1.SQL递归在SQLServer中,我们可以利用表表达式来实现递归算法,一般用于阻止机构的加载及相关性处理。-->实现:假设OrganiseUnit(组织机构表)中主要的三个字段为OrganiseUnitID(组织机构主键ID)、ParentOrganiseUnitID(组织机构父ID)、OrganiseName(组织机构名称)复制代码代码如下:withorganiseas(select*fromOrganiseUnitwhereOrganiseUnit.OrganiseUnitID=@OrganiseUnitIDunionallselectOrganiseUnit.*fromorganise,OrganiseUnitwhereorganise.OrganiseUnitID=OrganiseUnit.ParentOrganiseUnitID)selectOrganiseNamefromorganise上述sql语句实现了,传入组织机构主键ID,查询出其对应组织机构名称和其全部下级组织机构名称...
数据库操作教程 2022-09-23 16:46:20 -
使用sqlserver存储过程sp_send_dbmail发送邮件配置方法(图文)
1)创建配置文件和帐户(创建一个配置文件和配置数据库邮件向导,用以访问配置数据库邮件管理节点中的数据库邮件节点及其上下文菜单中使用的帐户。) 打开数据库服务器------管理-------数据库邮件------右键---配置数据库邮件(同时也可以看到管理已经配置好的邮件账户和配置文件) 这里的配置文件名,在使用sp_send_dbmail时会作为参数使用点“添加” 其中,账户名可以任意指定(描述功能即可),重点是邮件发送服务器(SMTP)的配置:电子邮件地址为发送方邮件地址,显示名称为发送方名称,答复电子邮件(可以同电子邮件地址相同),服务器名称为服务器发送服务器(eg:QQ的为smtp.exmail.qq.com)端口号不变;SMTP身份验证:基本身份验证(配置自己的邮件发送方地址和密码)...
数据库操作教程 2022-09-23 16:45:51