SQL Server开发过程中的十种常见问题总结(2)

2008-8-4  选择字号:  | |
打印本文章

SQL Server 2005中的存储过程并发问题

我在SQL Server2005中遇到了并发问题。我持有车票的公共汽车上有一些空闲的座位。我在插入销售的查票之前,需要查看是否还有空闲的座位。我的存储过程做的事情如下所示:


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 <> 0 insert INTO tickets VALUES(…) — some other statements END TRANSACTION  


问题就是两个过程可以同时读取空闲票数,并且都可以预约一张票,即使是那里已经没有空余的了。我需要一种方法来防止一个过程在另一个过程运行add_ticket程序,但是还没有插入一张新票的时候读取空票的数量。

回答:

你是正确的;更高的隔离级别也不会保证多个读者去同时去读取同一个数据行。然而,还有几种方法你可以完成这项工作。例如,你可以给每个座位分配一个惟一的标识符(意思是,惟一键——不一定是GUID),并且创建一个描述哪些座位已经被预订了的表。在表上放一个 UNIQUE约束,你就可以确保同一个座位不会被插入两次了。

就是说,我认为一个更有趣的方法就是使用SQL Service Broker。你可以为每个公交建立一个会话,并且将这个会话的句柄存放在一个表中,读者在执行RECEIVE之前可以参考这个表。通过这种方式,读者就可以正确地过滤。公共汽车上的每个座位都插一个消息到队列中。读者就可以简单地RECEIVE到所需的消息(在这个过程中,预定公共汽车上的座位)。 Service Broker会确保没有消息会被接受两次,也就是说你不会再遇到并发问题了。

SQL Server 2005中取代了查询分析器

回答:

你是对的。查询分析器和企业管理器都从SQL Server中删除了。取代它们的是一个工具,SQL Server 管理套件(SQL Server Management Studio)。这个工具具有前任的大多数特性,但是拥有升级后的用户界面和很多经过改善的功能。我觉得大多数的数据库管理员都会发现这是一个很好的升级。

如果你想要了解更多有关SQL Server管理套件的新特性的信息,请阅读SearchSQLServer.com 上有关这个话题的文章。

SQL vs. T-SQL

回答:
SQL是结构化查询语言,是ANSI/ISO 认可的标准数据库语言。SQL Server的实现语言叫做Transact-SQL (T-SQL)。T-SQL基本上是根据1992年发表的ISO标准出现的,在1999年的标准上稍加修改。此外,微软还进行了各种私有的加强。

标准SQL和T-SQL之间有很多区别——太多了,这里就不说了。还有,如果你在SQL Server上工作,那么使用这些私有的扩展是有好处的。由于许多SQL Server的特性的本质,你不使用非标准的命令的话,将会有很多强大的功能无法实现。如果你想要看看你的SQL是否符合标准,你可以使用SET FIPS_FLAGGER命令。

SQL Server 2005中是否有新的索引类别了?

回答:

SQL Server 2005没有为关系表引入新的索引类型。基本上——聚簇和非聚簇索引是以B-trees的方式实现的——还仍然在应用。然而,SQL Server 2005确实包含了一些索引上的加强,不论是完全文本索引,还是对于XML数据,此外这些加强还可以改善一些与关系型索引有关的问题。

SQL Server 2005的完全文本索引特性是全新的,并且是重新编写的。要获得这个特性的信息,请阅读Nimish Khanolkar的MSDN广播文档,介绍SQL Server 2005中的全文本查找。

XML是SQL Server 2005中另外一个在方式上发生了巨大转变的内容。现在对于开发人员来说有第一流的XML数据类型可用了。这个类型支持XQuery查询语言,使用了这个类型的字段可以通过特殊格式的XML索引被索引到。要了解更多有关XML类型的信息,请查找MSDN 上的文章。

还有各种各样的有关T-SQL索引命令的加强。也许最令人感兴趣的就是新的“在线”索引类型,它允许数据库管理员在不需要把用户锁到表外面的情况下执行索引维护任务。这个很有可能标记着数据库管理员需要等到夜里3点才能打开维护窗口修正问题的状况的终结!要了解更多有关这个特性的信息,请查找SQL Server Worldwide Users Group 上的文章。

为行选择创建一个脚本

想象一下这个表:

prod_key item_key pack_key last_sale LM001 1029 AD100 2004/12/05 LM870 1029 AD100 2005/09/20 PE789 1030 BC400 2003/07/12 PE312 1030 BC400 2004/08/07      

我想要选出哪些在item_key 和pack_key相等的情况下,日期比较大的那一行。换句话说,我想要: LM870 1029 AD100 2005/09/20 PE312 1030 BC400 2004/08/07   
回答:

这个表有主键吗?那样的话查询可能会容易些。不管怎么样,我觉得你应该按照下面这样:


select prod_key,item_key,pack_key,last_sale FROM (select item_key,pack_key,MAX(last_sale) AS last_sale FROM tablex GROUP BY item_key,pack_key) AS MaxDateTable where tablex.item_key = MaxDateTable.item_key AND tablex.pack_key = MaxDateTable.pack_key AND tablex.last_sale = MaxDateTable.last_sale     

列出没有记录的数据库表

我创建了一个动态的SQL Server查询来输出表中行的数量。我的目标是列出在数据库中没有记录的表。查询如下所示: declare @strsql varchar(100) declare @tablename varchar(50) @tablename=’table123′@strsql=’ select count(*) from ‘ + @tablename exec(@strsql)   
我得到了输出,但是我无法把这个值存储到变量中以备查看。

B<>我想要这样查看:


/* @countvariable=0 
print(@tablename)*/ 

还有其它的解决方法吗?

回答:

你可以让你的解决方案更加灵活一些,通过从sysobjects表中抓取表名:


declare @strsql varchar(256) create table #emptytables (tablename varchar(128), table_rowcount int)select @strsql=’select distinct o.name as TableName, .rowcnt as Table_Rowcount from sysobjects o inner join sysindexes x on o.id = x.id where x.rowcnt = 0 and o.type = ‘’U”’insert #emptytables (TableName, Table_rowcount) exec (@strsql) select * from #emptytables drop table #emptytables      


SQL Server开发过程中的的常见问题总结
 SQL Server开发过程中的十种常见问题总结(1)
 SQL Server开发过程中的十种常见问题总结(2)

原文出处:http://tech.ccidnet.com/art/1106/20080717/1510031_2.html
来源:赛迪网    作者:璞玉    
相关的专家答疑
SQL Server和T-SQL数据操纵包括哪些方面的内容?本文主要介绍了设计、存储过程、自定义函数、以及触发器等方面的内容。
很有可能你会碰到一位想用CLR的开发人员,或者你发现自己需要实施一个用标准SQL Server对象和T-SQL语言不容易实现的、复杂的事务规则,所以你就可以用CLR创建一个函数……
T-SQL的基本特征就是数据类型、谓词和函数。数据类型都是参照ANSI SQL92标准的数据类型。T-SQL支持一系列有用的系统函数。
在SQL Server开发中你可能会遇到以下10个问题:什么是常见的对表和字段的名字约束?有没有可能在不了解T-SQL的情况下编写存储过程?T-SQL 中如何比较CLR 存储过程和……
在SQL Server开发中你可能会遇到以下10个问题:什么是常见的对表和字段的名字约束?有没有可能在不了解T-SQL的情况下编写存储过程?T-SQL 中如何比较CLR 存储过程和……
笔者最近在使用正则表达式的时候发现:在忽略大小写的时候,匹配值从0xff 到0xffff之间的所有字符,正则表达式也能匹配两个ASCII字符:i和I,但不能匹配其他字母和数字。
SQL Server 2008 Integration Services都包含哪些新特征?在本章技巧中,我将着重讨论数据集成工具、SQL Server 2008 SSIS和它的三大特征。SSIS 2008中这些新特征为……
怎样在SQL Server中使用证书来创建用来在数据库中进行加密和解密的对称密钥?你可以使用CREATE SYMMETRIC KEY语句……
SQL Server 2005一个令人激动的特性是内置了加密的功能。在这个新版的SQL Server中,开发团队直接在T-SQL中加入了加密工具、证书创建和密钥管理的功能。
本专题主要介绍SQL Server 2008的新增特征:SQL Server 2008中的T-SQL基本对象和操作、T-SQL的函数类型和数据类型以及新的安全特性等等。
本篇文章主要介绍SQL Server数据存储的物理对象和原理,包括SQL Server 2005和2008里的物理数据存储、SQL Server 2008数据类型(即Datetime、字符串、自定义及等)、在SQL Server数据库中加强数据的完整性……
本文为SQL Server 2008初学者指南,主要介绍SQL Server2008 T-SQL支持的基本元素和基本操作。
最新更新
专家答疑
技巧
Phillip Bracken
我怎样在Oracle中增加SGA_MAX_SIZE?在计算机启动的时候出现了以下错误:"ORA-03113: end-of-file on communication channel"。请您告诉我增加SGA的一些步骤。
Rudy Limeback
我想用REPLACE语句替换AddressLine1域里面的数据,也就是想删除逗号、周期、连字符,并将 '3 South '替换成'3 S ' 然后……
Brian Peasland
设计备份方案时主要考虑哪些因素?什么是RTO、MTBF和MTTR?我不敢100%肯定RTO,但是我觉得就是Return to Operation的意思。换句话说就是将系统返回到正常操作时间……