在进行数据表检查或修补时,可以先将数据表锁定,可确保数据表的安全:
东阿网站建设公司创新互联建站,东阿网站设计制作,有大型网站制作公司丰富经验。已为东阿1000多家提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的东阿做网站的公司定做!
mysqlLOCK TABLE tbl_name READ;
mysqlFLUSH TABLES;
将数据表锁定后再进行检查或修补的工作。完成后再解除锁定:
mys()qlUNLOCK TABLES;
//LOCK TABLE tbl_name READ表示要锁定成只读状态,在这个状态下用户只能读取数据表,不能写入。
LOCK TABLE tbl_name WRITE则是更严格的锁定,用户不能读取也不能写入。
标准的方法是锁定数据库,你开始写数据的时候就独占方式锁定表,这时候其它用户(或者同一用户的其它进程)查询数据库会报错,直到你修改完毕后再解除表锁定。
此外,还有一个更加完美一点的方法:增加TYPE字段的含义,1表示需要发送、2表示已经发送、3表示正在发送,你的程序每次只查询TYPE=1的来处理,处理之前整体修改TYPE=3(这个修改应该瞬间完成,而且一个UPDATE语句执行的时候MYSQL会自动锁定),然后慢慢发送和修改TYPE=2。
mysql一般不会死锁,除非程序有问题。性能优先事务不优先的数据库(设置)不要追求可靠性万无一失。
网站性能问题主要是数据库量大了以后,查询扫描硬盘而产生的。其它性能不要太在意。编写代码的时候不要坚持性能原则,而是坚持可用性原则。初学者编写代码通常容易面向性能,但是一个项目的一个页面几百、几千行代码是很常见的。要面向可用性、可维护性、可读性。这是项目原则。你看看java语言。对于网站,除了查询扫描硬盘而产生的时间延迟,其它是不管的,只要不算有问题就可以。
连接方式是否为永久连接,在访问量未达到高并发之前,还是非永久链接更好。非永久连接的资源消耗是不大于永久连接的,因为mysql是把连接权限缓存的,不会多次扫描硬盘,性能是可执行级别的而不是查找数据级别的。在访问量达到高并发之后,性能问题的原因是多方面的,多环节的,是否为永久连接不是主要原因。