如何正确操作ADO数据库创建说明

开发 后端
如果没有更好的创建ADO数据库,你可以实现需求也不是没有办法,可以手动的把"[dbo]"前缀去掉,但是这毕竟不是根本上的解决方法。

在公司技术人员进行对ADO数据库操作时,特别是企业级的数据库应用,就不得不提一个多人操作时经常会产生的问题——并发冲突。本文首先来看一下什么是并发冲突,传统的并发冲突有现有的处理方式。 

一、要完成本文中的实例,您需要作如下准备:

将Visual Studio 2008及.NET Framework 3.5升级到SP1。点击转到升级地址。 安装SQL SERVER 2005,VS 2008中自带的EXPRESS版的SQL SERVER应该也可以用。 下载并附加数据库:点击下载DemoDbV2。 创建一个VB Console Application,并且取一个合适的名字(例如:Concurrency之类的)。注意,目标Framework要设置成3.5版。 

二、什么是并发冲突
  
让我们来看一个跟取款相关的例子:某年某月某日某时某分,ADO数据库老王在A取款机取钱,他儿子小王同时在B取款机取钱(不要问我为什么这么巧^_^),他俩从同一个账号上取。于是就发生了如下一序列的操作:
  
A取款机向中央数据库提问:这账上还有多少钱?
  
B取款机向中央数据库询问:这账上还有多少钱? 中央数据库回答A取款机:2W,中央数据库回答B取款机:2W,然后,ADO数据库老王对A取款机说:我要取出1.5W。 同时,小王对B取款机说:我要取出1.8W。 #t#

A取款机就算了一下,2W-1.5W=0.5W>0,于是就吐出1.5W现金给了老王,并且准备告诉中央数据库,现在还剩0.5W啦。但是,就在它告诉中央数据库之前,发生了以下的事情:
  
B取款机计算了一下,2W(此时,它还不知道余额已经成0.5W了,因为A取款机还没有告诉中央数据库)减去1.8W等于0.2W大于0,于是就吐出1.8W现金给了小王。然后,ADO数据库当然也要知会中央数据库。
  
中央数据库于是收到A取款机的消息,说,这个账号还剩0.5W,于是刷新余额为0.5W。然后又收到B取款机说还剩0.2W,于是,就刷新余额为0.2W。 呵呵,于是,小王+老王的账户里一共存有2W元,结果老王取了1.5W元,小王取了1.8W元,账户里却还剩了0.2W元。

这就是一种并发冲突,由于同一时间有两个或者多个端在对同一数据进行操作,ADO数据库从而导致数据发生了错误。如果取款机真的以这样的方式来处理并发,那么,我现在就不写这片文章了——赶紧发动全家对表,说好了在某一时刻同时取钱去。

责任编辑:chenqingxiang 来源: chinaunix
相关推荐

2009-12-24 10:37:03

ADO.NET访问数据

2009-12-31 10:00:32

ADO.NET数据库

2010-06-01 12:51:23

MySQL数据库

2009-12-25 17:28:01

ADO Data 控件

2009-12-21 15:07:41

ADO Access数

2009-11-11 15:24:35

ADO创建数据库

2010-02-22 18:17:48

Python数据库

2009-12-31 14:50:57

ADO组件

2010-01-04 09:51:52

ADO连接对象

2009-12-18 17:06:37

ADO.NET 数据库

2009-12-23 17:59:46

ADO.NET数据库

2009-11-12 11:23:35

ADO.NET SQL

2011-08-02 17:06:29

Oracle远程数据库创建DB Link

2009-12-29 11:15:45

ADO数据库

2009-12-21 16:07:52

ADO.NET数据库

2009-12-22 17:24:22

ADO.NET数据库

2009-12-28 10:09:10

ADO.NET连接

2009-12-22 13:34:48

ADO.Net Tea

2009-12-24 15:11:47

ADO.NET数据库连

2009-12-28 09:50:32

ADO数据库
点赞
收藏

51CTO技术栈公众号