SqlServer通用存储过程】的更多相关文章

1.增删改—通用存储过程 --增删改 存储过程create proc Infos_InsertUpdateDelete( @Id int, @Name varchar(50), @DataTable_Action_ varchar(10) = '' --操作方法:Insert:增加 Update:修改 Delete:删除)AS declare @ReturnValue varchar(18) -- 返回操作结果set @ReturnValue = -1 --开启事务 begin tran --错…
最近在面试的时候,遇到个奇葩的秃顶老头面试官. 问:写过存储过程分页吗? 答:没写过,但是我知道分页存储的原理,我自己也写过,只是在工作中没写过. 问:那你这么多年工作中就没写过吗? 答:的确没写过,因为项目数据量都特别小. 然后,这奇葩就起身就要走人了,连个招呼都没有.想我面试了这么多公司,这种奇葩面试官,还是头回见到,一点职业素质,礼貌都木有.气死我了! 明天要去入职新公司了,今天闲来无事,试着写了写这个存储过程分页.只在SQLSERVER2008上测试过,不过我想,2000以上版本应该都会…
一:解释      SQL Server提供了一种方法:可以将一些预先编译的SQL语句集中起来由SQL Server数据库服务器来完成以实现某个任务,这就是存储过程.存储过程常驻在SQL Server数据库服务器的内存中. 二:优点   1.运行的熟读快,比SQL语句执行速度快2~10倍   2.可以接受参数,输出参数返回单个或多个结果集以及返回值.可以向程序返回错误的原因   3.运行稳定错误较少   4.主要是在服务器上运行,减少对客户机的压力   5.可以包含程序流.逻辑以及对数据库的查询…
Sqlserver中存储过程,触发器,自定义函数: 自定义函数:1.函数类型:2.函数的参数和返回值: 1.函数类型:标量值函数,返回的是一个标量值表值函数:内联表值函数:多语句表值函数. 标量值函数: go ))--指定参数名,和返回类型 stuNo returns int --指定返回类型 begin declare @订单总数 int --学生人数sumstudent select @订单总数=count(订单.订单号) from 订单 join 职工 on 订单.职工号=职工.职工号 w…
Sqlserver中存储过程,触发器,自定义函数 1.存储过程有关内容存储过程的定义:存储过程的分类:存储过程的创建,修改,执行:存储过程中参数的传递,返回与接收:存储过程的返回值:存储过程使用游标. 1.1存储过程的定义:存放在服务器上预先编译好的sql语句,可以给存储过程传递参数,也可以从存储过程返回值. 优点:提供了安全访问机制,比如可以将不同的存储过程的执行权限赋予权限不同的用户:改进了执行性能,因为存储过程是预编译的:减少了网络流量,因为在调用存储过程时,传递的字符串很短,没有很长的s…
Sqlserver中存储过程,触发器,自定义函数: 1. 触发器:是针对数据库表或数据库的特殊存储过程,在某些行为发生的时候就会被激活 触发器的分类: DML触发器:发生在数据操作语言执行时触发执行的存储过程,Insert,Update,Delete After触发器:记录被改变之后激活执行 Instead of触发器:记录被改变之前激活执行. DDL触发器:响应数据定义语言执行时触发执行的存储过程,一般用于执行数据库中的管理任务 审核和规范数据库的操作: 防止数据表结构被更改或删除 2. ht…
JSON序列化 http://www.cnblogs.com/yubaolee/p/json_serialize.html 利用SqlServer系统存储过程sp_send_dbmail发送邮件(一) http://blog.itpub.net/28699126/viewspace-1074595/ http://zhangkui.blog.51cto.com/1796259/340557/…
上次写了通用存储过程.感觉还是有很大的BUG.就是条件不能参数画化.这个BUG可以说是致命的.但是我一直想在用什么方法能解决这个东西.其实我只是想写少量的代码来做更多的事情.我想能不能传集合给存储过程但是好像这个是行不通没办法只能写死. 上代码吧 IF (SELECT COUNT(*) FROM sysobjects s WHERE s.[type]='P' AND s.name='SP_PAGE_PRACTICAL')>0 DROP PROC SP_PAGE_PRACTICAL; GO CRE…
原文 SqlServer中存储过程中将Exec的执行结果赋值给变量输出 背景: 遇到这样一种情况:动态向存储过程中传入表名和表的某些属性(这里用到的是主键ID),然后利用这两个变量查出一条数据的某些字段值,然后再利用这些值进行逻辑运算(自己的逻辑),最后将结果输出.话不多说,直接上图,看是否是你想要的结果: 说明:[区域1为要用来测试的表][ 区域2 为表中数据][区域3 为表中数据jan+feb+mar列值的和5] 存储过程代码如下: 从上图可以看出既然可以拿到jan .feb.mar列的值,…
SqlServer复杂存储过程 CREATE PROCEDURE FETCH_GOOUT_INFO AS BEGIN WITH l as(SELECT A.ZJHM, O.KSQR, O.JSRQ, o.PK_ID FROM t_go_out o, T_CORRECT_ARCHIVE a WHERE o.A_PK = a.PK_ID AND a.DR = 0 AND O.DR = 0) UPDATE t SET t.startqjrq = l.KSQR, t.endqjrq = l.JSRQ,…