免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: liusz
打印 上一主题 下一主题

再次请教: 如何避免表锁定 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2005-09-06 19:32 |只看该作者

再次请教: 如何避免表锁定

原帖由 "北京野狼" 发表:


AINSERT,B进行DELETE,为什么需要锁,要是这样数据库还有什么用处?
我在论坛发贴,你斑竹删贴,难道CU论坛得加锁?

你们都不理解数据库在什么情况需要加锁。


在insert或者delete的瞬间是必须要锁的,道理我没必要多讲。
类似的争论我想没必要继续下去,请楼主最好找找权威的文档加以佐证。

论坛徽章:
0
12 [报告]
发表于 2005-09-06 19:44 |只看该作者

再次请教: 如何避免表锁定

Table locking enables many threads to read from a table at the same time, but if a thread wants to write to a table, it must first get exclusive access. During the update, all other threads that want to access this particular table will wait until the update is ready.


摘自mysql手册(3.23.40版本),
=>;”Getting Maximum Performance from MySQL“章
=>;“System/Compile Time and Startup Parameter Tuning”
=>;“Using Symbolic Links”
=>;“Table Locking Issues”
第5段便是

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
13 [报告]
发表于 2005-09-07 09:15 |只看该作者

再次请教: 如何避免表锁定

原帖由 "yejr" 发表:


在insert或者delete的瞬间是必须要锁的,道理我没必要多讲。
类似的争论我想没必要继续下去,请楼主最好找找权威的文档加以佐证。


没有任何数据库这时候应用程序需要锁表。您觉得没必要讲可以不讲。
数据库内部的操作和cpu轮训一样,没有真正的多任务,都是众多任务
在队列等待,一个时间只有一个线程真正去写数据库。

应用程序需要锁表的必要条件是,一个连贯的多个sql,后一个操作的内容依靠前一个操作的结果。从未听多在insert或者delete的瞬间是必须要锁的疯话

论坛徽章:
0
14 [报告]
发表于 2005-09-07 09:44 |只看该作者

再次请教: 如何避免表锁定

我不再参与此论题的讨论了。

论坛徽章:
0
15 [报告]
发表于 2005-09-07 10:07 |只看该作者

再次请教: 如何避免表锁定

MySQL的表锁定代码是不会死锁的。

MySQL使用表级锁定(而不是行级锁定或列级锁定)以达到很高的锁定速度。对于大表,表级锁定对大多数应用程序来说比行级锁定好一些,但是当然有一些缺陷。

在MySQL3.23.7和更高版本中,一个人能把行插入到MyISAM表同时其他线程正在读该表。注意,目前只有在表中内有删除的行时才工作。

表级锁定使很多线程能够同时读一个表,但是如果一个线程想要写一个表,它必须首先得到独占存取权。在更改期间,所有其他想要存取该特定表的线程将等到更改就绪。

因为数据库的更改通常被视为比SELECT更重要,更新一个表的所有语句比从一个表中检索信息的语句有更高的优先级。这应该保证更改不被“饿死”,因为一个人针对一个特定表会发出很多繁重的查询。

从MySQL 3.23.7开始,一个人可以能使用max_write_lock_count变量强制MySQL在一个表上一个特定数量的插入后发出一个SELECT。

对此一个主要的问题如下:

一个客户发出一个花很长时间运行的SELECT。
然后其他客户在一个使用的表上发出一个UPDATE;这个客户将等待直到SELECT完成。
另一个客户在同一个表上发出另一个SELECT语句;因为UPDATE比SELECT有更高的优先级,该SELECT将等待UPDATE的完成。它也将等待第一个SELECT完成!
对这个问题的一些可能的解决方案是:

试着使SELECT语句运行得更快;你可能必须创建一些摘要(summary)表做到这点。
用--low-priority-updates启动mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的最后的SELECT语句将在INSERT语句前执行。
你可以用LOW_PRIORITY属性给与一个特定的INSERT、UPDATE或DELETE语句较低优先级。
为max_write_lock_count指定一个低值来启动mysqld使得在一定数量的WRITE锁定后给出READ锁定。
通过使用SQL命令:SET SQL_LOW_PRIORITY_UPDATES=1,你可从一个特定线程指定所有的更改应该由用低优先级完成。见7.25 SET OPTION句法。
你可以用HIGH_PRIORITY属性指明一个特定SELECT是很重要的。见7.12 SELECT句法。
如果你有关于INSERT结合SELECT的问题,切换到使用新的MyISAM表,因为它们支持并发的SELECT和INSERT。
如果你主要混合INSERT和SELECT语句,DELAYED属性的INSERT将可能解决你的问题。见7.14 INSERT句法。
如果你有关于SELECT和DELETE的问题,LIMIT选项的DELETE可以帮助你。见7.11 DELETE句法。

论坛徽章:
0
16 [报告]
发表于 2005-09-07 10:19 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
17 [报告]
发表于 2005-09-08 08:55 |只看该作者

再次请教: 如何避免表锁定

楼上的,你什么时候活过来的?
很久不见啊

论坛徽章:
0
18 [报告]
发表于 2005-09-08 11:40 |只看该作者

再次请教: 如何避免表锁定

如果做的应用是事务,从不加锁应该是不合理的

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
19 [报告]
发表于 2005-09-08 16:23 |只看该作者

再次请教: 如何避免表锁定

[quote]原帖由 "kk_00"]如果做的应用是事务,从不加锁应该是不合理的[/quote 发表:


如果是事务处理就更没必要加锁了。
wangyih说的很对,web网站那个不都是大量并发的insert,delete,谁写程序加过锁?

我们说的应用程序加锁和LZ的情况没有关系。

论坛徽章:
0
20 [报告]
发表于 2005-09-26 13:50 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP