外文翻譯--關(guān)于數(shù)據(jù)庫(kù)死鎖的知識(shí)_第1頁(yè)
已閱讀1頁(yè),還剩5頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  外文翻譯</b></p><p>  About the database of the knowledge of the deadlock</p><p>  Database itself provides lock management mechanism, but from a hand, database is the clie

2、nt applications "puppet", this is mainly because the client to the server has complete control of the gain of locks ability. The client in enquiries in the request and the way to query processing tend to have d

3、irect control, so, if we application design reasonable enough, then appear database is normal phenomenon dead lock.</p><p>  Below are listed some easy to have locked application examples:</p><p&g

4、t;  A, the client cancel inquires no roll back after practice.</p><p>  Most of the application is inquires often happens homework. However, users through the front desk the client application inquires the b

5、ackend database, sometimes will cancel inquires for any variety of reasons. If the user to open the window after mouth query, because users find reflect crash or slow compelled to cancel the query. But, when the client w

6、hen cancel inquires, if not add rollback transaction statement, then at this time, because the user has to the server sends the inquiry's request</p><p>  Second, the client not to get all the results of

7、 my query.</p><p>  Usually, the user will be sent to the server after queries, foreground application must be done at once extraction all the results do. If the application did not extract all the results t

8、rip, it produces a problem. For as long as the application did not withdraw promptly all the results, the lock may stay at table and block other users. Since the application has been submitted to the server will SQ state

9、ments, the application must be extracted all results do. If the application does not follow t</p><p>  Three, inquires the execution time too long.</p><p>  Some inquires a relatively long time

10、will cost. As for the query design is not reasonable or query design to watch and record it is, will make inquires the execution time lengthen. If sometimes need to Update on users record or Delete operation, if the line

11、 is involved in it, you will get a lot of lock. These locks whether finally upgrade to watch the lock, can block other inquiries.</p><p>  So often, don't take long time running decision support search a

12、nd online transaction processing inquires the mixed together.</p><p>  When database meet blocked, often need to check the application submitted to the SQL statement itself, and check and connection manageme

13、nt, all the results do processing and other relevant application behavior. Usually, the lock for to avoid the conflict in the jam, the author has the following Suggestions.</p><p>  Suggest a: after the comp

14、letion of the extraction of all query results do.</p><p>  Some applications in order to improve the response speed of the user inquires, will have the option of extraction need record. The "smart"

15、 looks very reasonable, but, but will cause more waste. Because inquires not timely and fruit extraction of words, the lock cannot be released. When others inquires the data, will be happening.</p><p>  So,

16、the author suggest in application design, database query for record to the extraction of in time. Through other means, such as adding inquires the conditions, or the way backstage inquires, to improve the efficiency of t

17、he inquires. At the same time, in the application level set reasonable cache, and can also be very significantly improved query efficiency.</p><p>  Suggest two: in the transaction execution don't let th

18、e user input content.</p><p>  Although in the affairs of the process with sex, can let the user participation, in order to improve the interactivity. But, we don't recommend the database administrator t

19、end to do so. Because if the user in affairs during the execution of the input and number, will extend the affairs of the execution time. Although people smarter, but the response speed still don't have a computer so

20、 fast. So, during the implementation of the user participation to let the process, will extend the affairs of wa</p><p>  Suggest three: make affairs as far as possible the brief.</p><p>  The a

21、uthor thinks that, database administrator should put some problem is simplified. When a need to many SQL statements to complete, might as well take the task decomposition. At the same time, it breaks down into some brief

22、 business affairs.</p><p>  If the database a product information table, its record number two million. Now in a management needs, the one-time change one of the one million five hundred thousand record. If

23、through a change affairs, the time is long. If it involves cascade update it, is time the meeting is longer.</p><p>  In view of this situation, we can learn affairs brief words. If the product information,

24、may have a product type field. So in the update data, can we not one-time updates. But through the product category fields to control, to record the iteration points. So every category of update firm consumption of time

25、may be greatly reduces. So although operation, will need more steps. But, can effectively avoid to go to the occurrence of congestion, and improve the performance of the database.</p><p>  Suggest four: chil

26、d inquires the and list box, had better not use at the same time.</p><p>  Sometimes in the application of design, through the list box can really improve user input speed and accuracy, but, if foreground ap

27、plication does not have buffer mechanism, you often can cause congestion.</p><p>  As in a order management system, may need frequent input sales representatives. In order to user input convenience, sales re

28、presentative often design into a list box. Every time need to input, foreground application from the background of all sales representative inquires information (if the application is not involved in the cache). On one h

29、and, the son of nature, would be speed query slow; Second, the list box have growth time operation of the inquiry. The two parties face touch together, may </p><p>  So, in the application design, the child

30、inquires the best less. And the child inquires the list box and use at the same time, more need to ban. If you can't avoid it, should be in application realize caching mechanism. That way, the applications need to sa

31、les representative information, will from application cache made, not every time to check the database.</p><p>  At the same time, can be in the list box design "to search" function. When there is

32、a change to the user information, such as the system administrator to join a new sales representatives. In no again before inquires, because of their application is achieved in the cache data, so not just updated content

33、. At this time, users will need to run to inquires the function, let the foreground application from a database query information again. This kind of design, can increase the list box and the son </p><p>  S

34、uggest five: in the set when cancel inquires back issues.</p><p>  Foreground application is designed, should allow users to a temporary change in idea, cancel the query. Such as user inquires the all produc

35、t information, may feel response time is long, hard to bear. At this time, they will think of cancel inquires the. In this case, the application design need to design a cancel inquires the button. The user can in the pro

36、cess of inquires click this button cancel inquires at any time. Meanwhile, in the button affair, need to pay attention to join a rollback co</p><p>  At the same time to the best lock or query timeout mechan

37、ism. This is largely because, sometimes also can cost a lot inquires user host to a large number of resources, and cause client crash. At this time, to be able to lock the inquires the or overtime mechanisms, namely in i

38、nquires after overtime, database server of related objects for automatic unlock. This is also the database administrator need to program developers negotiation of a problem.</p><p>  In addition, explicit da

39、tabase connection to take control in the concurrent users, is expected to full load next use application to bear ability test, use the link, each inquires to set use inquires and lock exceeds the overtime, these methods

40、can effectively avoid the lock conflict obstruction. When database administrators found that blocking the symptoms, can from these aspect, looking for solutions.</p><p>  From the above analysis can see, SQL

41、 Server database lock is a double-edged sword. The security database data consistency at the same time, they will give the database caused some negative effect. How do these negative influence to the least, is our databa

42、se administrators task. In application design, follow the advice above, can effectively solve the problems for the lock blockages, improve the performance of the database. Visible, to basically solve congestion problem,

43、need database management</p><p><b>  中文</b></p><p>  關(guān)于數(shù)據(jù)庫(kù)死鎖的知識(shí)</p><p>  數(shù)據(jù)庫(kù)本身提供了鎖管理機(jī)制,但是從一方面,數(shù)據(jù)庫(kù)客戶端應(yīng)用程序的“傀儡”,這主要是由于客戶端到服務(wù)器的完全控制獲得的鎖的能力。客戶機(jī)在請(qǐng)求在查詢的查詢處理的方法,往往有直接的控制,所以,如果我

44、們的應(yīng)用程序設(shè)計(jì)的不夠合理,那么出現(xiàn)的數(shù)據(jù)庫(kù)死鎖現(xiàn)象就很正常了。</p><p>  下面列舉一些容易出現(xiàn)鎖死的應(yīng)用程序例子:</p><p>  一、客戶端取消查詢后沒(méi)有回滾實(shí)務(wù)。</p><p>  大多數(shù)應(yīng)用程序查詢通常發(fā)生的作業(yè)。然而,用戶通過(guò)前臺(tái)客戶端應(yīng)用程序的后端數(shù)據(jù)庫(kù)查詢,有時(shí)候會(huì)取消詢問(wèn)因?yàn)楦鞣N原因。如果用戶打開(kāi)窗戶口查詢之后,因?yàn)橛脩舭l(fā)現(xiàn)反映緩慢崩

45、潰或被迫取消查詢。但是,當(dāng)客戶端當(dāng)取消問(wèn)道,如果不添加回滾事務(wù)聲明,然后在這個(gè)時(shí)候,因?yàn)橛脩糁挥蟹?wù)器發(fā)送了查詢請(qǐng)求,因此,后端數(shù)據(jù)庫(kù)中涉及的表,所有已添加L鎖。因此,即使用戶取消查詢之后,所有的事務(wù)的鎖在將繼續(xù)。在這一點(diǎn)上,如果其他用戶需要檢查表或用戶打開(kāi)窗口來(lái)輸入查詢的查詢條件,提高系統(tǒng)的響應(yīng)速度時(shí)發(fā)生堵塞現(xiàn)象。</p><p>  二、客戶端沒(méi)有及時(shí)取得所有查詢的結(jié)果.</p><p&g

46、t;  通常,用戶將被發(fā)送到服務(wù)器的查詢后,前臺(tái)應(yīng)用程序必須立刻進(jìn)行提取所有的結(jié)果。如果應(yīng)用程序沒(méi)有旅行中提取所有的結(jié)果,它就會(huì)產(chǎn)生問(wèn)題。只要應(yīng)用程序沒(méi)有及時(shí)提取所有的結(jié)果,鎖可能呆在桌子和阻止其他用戶。由于應(yīng)用程序已被提交至服務(wù)器將平方語(yǔ)句,應(yīng)用程序必須提取所有結(jié)果。如果應(yīng)用程序沒(méi)有遵循原則詞(比如因?yàn)樵谀莻€(gè)時(shí)候,沒(méi)有監(jiān)督配置),不能從根本上解決擁堵。</p><p>  三、查詢執(zhí)行時(shí)間過(guò)長(zhǎng)。</p&g

47、t;<p>  一些查詢將成本的一個(gè)相對(duì)較長(zhǎng)的時(shí)間。至于查詢?cè)O(shè)計(jì)不合理或查詢?cè)O(shè)計(jì)觀察和記錄,將使查詢的執(zhí)行時(shí)間延長(zhǎng)。如果有時(shí)需要更新用戶記錄或刪除操作,如果隊(duì)伍參與著它,你會(huì)得到很多的鎖。這些鎖升級(jí)看是否最后鎖可以阻止其他的查詢。  </p><p>  所以通常,不要把長(zhǎng)時(shí)間運(yùn)行決策支持搜索和在線事務(wù)處理,詢問(wèn)混合在一起。</p><p>  當(dāng)數(shù)據(jù)庫(kù)滿足封鎖,通常需要檢查

48、應(yīng)用程序提交的SQL語(yǔ)句本身,并檢查和連接管理,所有的結(jié)果進(jìn)行處理和其他相關(guān)的應(yīng)用程序行為。通常,為了避免沖突的擁塞在鎖上,作者提出以下的建議。</p><p>  建議一:完成后提取所有查詢結(jié)果。</p><p>  一些應(yīng)用程序?yàn)榱颂岣哂脩舨樵兊捻憫?yīng)速度,將有權(quán)選擇提取需要記錄?!爸悄堋笨雌饋?lái)很合理,但是,卻會(huì)導(dǎo)致更大的浪費(fèi)。因?yàn)闆](méi)有及時(shí)的話查詢結(jié)果提取、鎖不能被釋放。當(dāng)別人查詢數(shù)據(jù),

49、將發(fā)生阻塞的。</p><p>  因此,筆者建議在應(yīng)用程序設(shè)計(jì)、數(shù)據(jù)庫(kù)查詢記錄來(lái)提取時(shí)間。通過(guò)其他手段,如添加查詢條件,或后臺(tái)的查詢時(shí),提高查詢效率。同時(shí),在應(yīng)用程序級(jí)別設(shè)置合理的緩存,也可以是非常顯著提高查詢效率。</p><p>  建議二:在事務(wù)執(zhí)行時(shí)不要讓用戶輸入內(nèi)容。</p><p>  盡管在事務(wù)的過(guò)程性,能讓用戶參與,為了提高交互性。但是,我們并不推

50、薦使用數(shù)據(jù)庫(kù)管理員傾向于這么做。因?yàn)槿绻脩粼谑聞?wù)執(zhí)行期間輸入?yún)?shù),并將擴(kuò)展事務(wù)的執(zhí)行時(shí)間。盡管人們變得更聰明,但是響應(yīng)速度仍然沒(méi)有電腦,那么快。因此,在實(shí)現(xiàn)用戶的參與讓這個(gè)過(guò)程中,將擴(kuò)展事務(wù)的等待時(shí)間。所以除非有特殊的需求,而不是在應(yīng)用程序的執(zhí)行過(guò)程中,讓用戶輸入?yún)?shù)。一些事務(wù)的執(zhí)行必須參數(shù),最好事先提供。如果能夠通過(guò)中的變量參數(shù)如需要進(jìn)去。</p><p>  建議三:使事務(wù)盡可能的簡(jiǎn)短。 </p>

51、;<p>  數(shù)據(jù)庫(kù)管理員應(yīng)該放一些問(wèn)題簡(jiǎn)單化。當(dāng)一個(gè)需要很多的SQL語(yǔ)句完成,不妨把任務(wù)分解。同時(shí),它分解成一些簡(jiǎn)短的業(yè)務(wù)事務(wù)。</p><p>  如果數(shù)據(jù)庫(kù)產(chǎn)品信息表,它記錄編號(hào)二百萬(wàn)?,F(xiàn)在在一個(gè)管理需求,一次性修改其中一個(gè)十億零五十萬(wàn)年的紀(jì)錄。如果通過(guò)改變事務(wù)的時(shí)間較長(zhǎng)。如果涉及到級(jí)聯(lián)更新它,時(shí)間會(huì)更長(zhǎng)。</p><p>  鑒于這種情況,我們可以學(xué)習(xí)事務(wù)簡(jiǎn)短的話。如

52、果產(chǎn)品信息,可能有一個(gè)產(chǎn)品類(lèi)型字段。所以在更新數(shù)據(jù),我們能不能一次性更新。但通過(guò)產(chǎn)品類(lèi)別字段來(lái)控制,來(lái)記錄迭代點(diǎn)。所以每一類(lèi)更新公司的消費(fèi)時(shí)間可能會(huì)極大地降低。所以,雖然操作,將需要更多的步驟。但是,通常,可以有效地避免擁塞的發(fā)生,提高數(shù)據(jù)庫(kù)的性能。</p><p>  建議四:子查詢與列表框,最好不要同時(shí)使用。</p><p>  ??有時(shí)在應(yīng)用程序設(shè)計(jì),通過(guò)列表框真的可以改善用戶輸入的

53、速度和準(zhǔn)確性,但是,如果前臺(tái)應(yīng)用程序沒(méi)有緩沖機(jī)制,你往往會(huì)引起交通擁堵。</p><p>  在一個(gè)訂單管理系統(tǒng),可能需要經(jīng)常輸入銷(xiāo)售代表。為了方便用戶輸入,銷(xiāo)售代表經(jīng)常設(shè)計(jì)成一個(gè)列表框。每次需要輸入,前臺(tái)應(yīng)用程序從背景的查詢將銷(xiāo)售代表信息(如果應(yīng)用程序沒(méi)有涉及緩存)。一方面,自然的孩子,將查詢速度緩慢;第二,列表框有成長(zhǎng)時(shí)間運(yùn)行的查詢。這兩方面聯(lián)系在一起,可能導(dǎo)致應(yīng)用程序提高運(yùn)行的時(shí)間過(guò)程查詢。和其他的用戶查詢

54、,例如系統(tǒng)管理員需要維護(hù)客戶信息,充血。</p><p>  所以,在應(yīng)用程序設(shè)計(jì)、孩子提問(wèn)最好的少。和孩子提問(wèn)列表框和同時(shí)使用,更需要禁止。如果你無(wú)法避免,應(yīng)該在應(yīng)用程序?qū)崿F(xiàn)緩存機(jī)制。這樣,應(yīng)用程序需要的銷(xiāo)售代表的信息,將從應(yīng)用程序緩存中創(chuàng)造出來(lái)的,而不是每次檢查數(shù)據(jù)庫(kù)。</p><p>  同時(shí),可以在列表框設(shè)計(jì)“搜索”功能。當(dāng)有一個(gè)變化給用戶的信息,如系統(tǒng)管理員加入一個(gè)新的銷(xiāo)售代表。

55、在沒(méi)有之前再提問(wèn),因?yàn)樗麄兊膽?yīng)用程序就能實(shí)現(xiàn)緩存數(shù)據(jù),所以不僅僅是更新的內(nèi)容。此時(shí),用戶將需要運(yùn)行查詢功能,讓前臺(tái)應(yīng)用程序從一個(gè)數(shù)據(jù)庫(kù)查詢信息。這種設(shè)計(jì),可以增加列表框和兒子的執(zhí)行時(shí)間的查詢時(shí),有效地避免擁擠。</p><p>  建議五:在取消查詢時(shí)設(shè)置回退事務(wù)。</p><p>  ??前臺(tái)應(yīng)用程序設(shè)計(jì),應(yīng)該允許用戶臨時(shí)改變主意,取消查詢。如果用戶查詢所有產(chǎn)品的信息,可能會(huì)覺(jué)得響應(yīng)時(shí)間

56、長(zhǎng),難以忍受。在這段時(shí)間,他們會(huì)想到取消,問(wèn)。在這種情況下,應(yīng)用程序設(shè)計(jì)需要設(shè)計(jì)一個(gè)cancel按鈕,問(wèn)。用戶可以查詢過(guò)程點(diǎn)擊該按鈕取消瀏覽。同時(shí),在按鈕事件,需要注意加入一個(gè)回滾命令。讓數(shù)據(jù)庫(kù)服務(wù)器可以提示來(lái)記錄或表來(lái)解鎖。</p><p>  在同一時(shí)間或最好的鎖定超時(shí)機(jī)制查詢。這很大程度上是因?yàn)?有時(shí)需要花費(fèi)很多的要求用戶主機(jī)大量的資源,并導(dǎo)致客戶端崩潰。這時(shí),就可以鎖定超時(shí)工作或查詢機(jī)制,即在后來(lái)的要求加

57、班,數(shù)據(jù)庫(kù)服務(wù)器相關(guān)的對(duì)象自動(dòng)解鎖。這也是數(shù)據(jù)庫(kù)管理員需要規(guī)劃發(fā)展問(wèn)題的談判。</p><p>  此外,顯式連接到并發(fā)用戶控制數(shù)據(jù)庫(kù),負(fù)載預(yù)計(jì)將使用此應(yīng)用程序來(lái)承受能力測(cè)試,使用了鏈接,每個(gè)查詢和加班鎖定設(shè)置使用查詢加班,等等,該方法可以有效地避免阻塞鎖沖突。當(dāng)數(shù)據(jù)庫(kù)管理員發(fā)現(xiàn),阻斷這些癥狀,能從這些方面,尋找解決方案。</p><p>  從上面的分析可以看到,SQL Server數(shù)據(jù)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論