日期:2014-05-18  浏览次数:20623 次

请教下mysql问题
之前一直用SQL Server 在查询并允许脏读的情况下可以加上with(nolock) 这样的关键字。
但现在用mysql有没有这样的关键字?
因为现在的服务器并不是太好,联合查询时,超过4张表以上就会进行锁表。
复杂一点的SQL语句执行起来很吃力。
例如:
select c1,c2,c3,c4 from t1 left join t2 on ...
left join t3 on ... left join t4 on...
where '条件'  
这样就会锁表了。--无奈
请问有没有什么好的办法?



------解决方案--------------------
http://xu20cn.blog.51cto.com/274020/72574
------解决方案--------------------
SQL code
下面描述了一些方法来避免或减少表锁定造成的竞争: 

· 试图使 SELECT 语句运行得更快。可能必须创建一些摘要(summary)表做到这点。 
· 用--low-priority-updates启动mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的第2个SELECT语句将在UPDATE语句前执行,而不需要等候第1个 SELECT 完成。 
· 可以使用SET_UPDATES=1语句指定具体连接中的所有更新应使用低优先级。 
· 可以用LOW_PRIORITY属性给与一个特定的INSERT、UPDATE或DELETE语句较低优先级。 
· 可以用HIGH_PRIORITY属性给与一个特定的SELECT语句较高优先级。 
· 为max_write_lock_count系统变量指定一个低值来启动mysqld来强制MySQL在具体数量的插入完成后临时提高所有等待一个表的SELECT 语句的优先级。这样允许在一定数量的WRITE锁定后给出READ锁定。 
· 如果你有关于INSERT结合SELECT的问题,切换到使用新的MyISAM表,因为它们支持并发的SELECT和INSERT。 
· 如果你对同一个表混合插入和删除,INSERT DELAYED将会有很大的帮助。 
· 如果你对同一个表混合使用 SELECT 和DELETE 语句出现问题,DELETE 的LIMIT 选项可以有所帮助。 
· 对 SELECT 语句使用SQL_BUFFER_RESULT可以帮助使表锁定时间变短。 
· 可以更改mysys/thr_lock.c中的锁代码以使用单一的队列。在这种情况下,写锁定和读锁定将具有相同的优先级,对一些应用程序会有帮助。 

这里是一些MySQL中表锁定相关的技巧: 

· 如果不混合更新与需要在同一个表中检查许多行的选择,可以进行并行操作。 
· 可以使用 LOCK TABLES 来提高速度,因为在一个锁定中进行许多更新比没有锁定的更新要快得多。将表中的内容切分为几个表也可以有所帮助。 
· 如果在MySQL中表锁定时遇到速度问题,可以将表转换为 InnoDB 或BDB 表来提高性能