知识大全 SQL Server开发问题前十名[3]
Posted 过程
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 SQL Server开发问题前十名[3]相关的知识,希望对你有一定的参考价值。
SQL Server开发问题前十名[3] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
我编写了一个存储过程在Crystal Report中使用 它工作得很好 我还想在另外一个存储过程中使用这个存储过程产生的结果 我该怎么做?
专家回答:
只要存储过程只产生了一个单个的结果 要在另外一个存储过程中使用这个存储过程产生的输出 这个技术是非常直接的 这个技术就是使用一个临时表来装载存储过程的巨额iguo 然后通过INSERT EXEC语句来执行这个过程并保存结果 一旦结果保留在临时表中了 他们就可以像使用其它表数据一样来使用它了
这里是我们可能会复用的一个过程例子: CREATE PROC usp_Demo_AllAuthors as select * from pubs authorsGO 现在有一个存储过程使用usp_Demo_AllAuthors的结果: CREATE proc usp_Demo_SPUser as CREATE TABLE #Authors ( au_id varchar( ) NOT NULL PRIMARY KEY CLUSTERED au_lname varchar ( ) NOT NULL au_fname varchar ( ) NOT NULL phone char ( ) NOT NULL address varchar ( ) NULL city varchar ( ) NULL state char ( ) NULL zip char ( ) NULL contract bit NOT NULL )– Execute usp_Demo_AllAuthors storing the – results in #Authors insert into #Authors exec usp_Demo_AllAuthors– Here we use the #Authors table This example only – only selects from the temp table but you could do much – more such as use a cursor on the table or join with – other data SELECT au_fName + + au_lname as [name] address+ +city+ +state+ +zip [Addr] from #AuthorsDROP TABLE #Authors GO
SQL Server 中的存储过程并发问题
问题提交于 年 月 日
我在SQL Server 中遇到了并发问题 我持有车票的公共汽车上有一些空闲的座位 我在插入销售的查票之前 需要查看是否还有空闲的座位 我的存储过程做的事情如下所示:
CREATE PROCEDURE add_ticket — parameters DECLARE free_seats int BEGIN TRANSACTION SELECT free_seats = COUNT(*) FROM tickets WHERE seat_is_not_taken IF free_seats <> INSERT INTO tickets VALUES(…) — some other statements END TRANSACTION
问题就是两个过程可以同时读取空闲票数 并且都可以预约一张票 即使是那里已经没有空余的了 我需要一种方法来防止一个过程在另一个过程运行add_ticket程序 但是还没有插入一张新票的时候读取空票的数量 在这种情况下 SET TRANSACTION ISOLATION LEVEL不管用了 我说的对吗?
专家回答:
你是正确的;更高的隔离级别也不会保证多个读者去同时去读取同一个数据行 然而 还有几种方法你可以完成这项工作 例如 你可以给每个座位分配一个惟一的标识符(意思是 惟一键——不一定是GUID) 并且创建一个描述哪些座位已经被预订了的表 在表上放一个 UNIQUE约束 你就可以确保同一个座位不会被插入两次了
就是说 我认为一个更有趣的方法就是使用SQL Service Broker 你可以为每个公交建立一个会话 并且将这个会话的句柄存放在一个表中 读者在执行RECEIVE之前可以参考这个表 通过这种方式 读者就可以正确地过滤 公共汽车上的每个座位都插一个消息到队列中 读者就可以简单地RECEIVE到所需的消息(在这个过程中 预定公共汽车上的座位) Service Broker会确保没有消息会被接受两次 也就是说你不会再遇到并发问题了
cha138/Article/program/SQLServer/201311/22462相关参考
SQLServer开发问题前十名[1] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在SQLS
SQLServer开发问题前十名[5] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 为行选择创
SQLServer开发问题前十名[2] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 接下来的字
详细讲解SQLServer索引的性能问题[3] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&nb
很多开发人员都想成为一名DBA也有很多人一开始就把自己定位成为一名DBADBA究竟需要掌握些什么知识和技能呢?以下是我做DBA工作和面试DBA时整理的一些DBA方面的三十个问题三十个大问题中还有许多小
MSSQLServer性能调整和优化开发人员指南第3部分:配置SQLServer 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容
SQLServer开发10个最重要特点 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! NET框架
知识大全 Delphi、MS SQL Server开发环境下存储过程的使用
Delphi、MSSQLServer开发环境下存储过程的使用 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看
知识大全 SQL Server2012对于开发人员用的上的新特性
SQLServer2012对于开发人员用的上的新特性 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
知识大全 SQL Server 7.0 函数及SQL语句相关问题
SQLServer7.0函数及SQL语句相关问题 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!