导航

MySQL的基础(优化)1

Posted on 2017-03-31 11:06  deeply_desire  阅读(278)  评论(0编辑  收藏  举报

1,在创建表的时候,为了获得更好的性能,我们可以将表中字段的宽度设得尽可能小

2,在可能的情况下,应该尽量把字段设置为NOT NULL,这样在将来执行查询的时候,数据库不用去比较NULL值

3,对于某些文本字段,例如“省份”或者“性别”,我们可以将它们定义为ENUM类型。

4,尽量使用连接代替子查询,子查询可以一次性的完成很多逻辑上需要多个步骤才能完成的SQL操作,同时可避免事务或表锁死,写起来也很容易。但有些情况下,子查询可以被更有效率的连接(JOIN)替代。连接(JOIN).. 之所以更有效率一些,是因为 MySQL不需要在内存中创建临时表来完成这个逻辑上的需要两个步骤的查询工作

5,能使用内连接的(inner join)的情况下,尽量使用内连接

6,使用联合查询(UNION)来代替手动创建临时表,要注意的是所有 SELECT 语句中的字段数目要想同,它可以把需要使用临时表的两条或更多的 SELECT 查询合并的一个查询中。在客户端的查询会话结束的时候,临时表会被自动删除,从而保证数据库整齐、高效。例(UNION)如下:SELECT Name, Phone FROM client UNION SELECT Name, BirthDate FROM author UNION SELECT Name, Supplier FROM product

7,当需要用到一系列的语句来完成某种工作(例如要把某个数据同时插入两个相关联的表中),为了保持数据库中数据的一致性和完整性,我们就需要事务。事务以BEGIN 关键字开始,COMMIT关键字结束。在这之间的一条SQL操作失败,那么,ROLLBACK命令就可以把数据库恢复到BEGIN开始之前的状态。

BEGIN;
INSERT INTO salesinfo SET CustomerID=14;
UPDATE inventory SET Quantity=11
WHERE item='book';
COMMIT;

事务的另一个重要作用是当多个用户同时使用相同的数据源时,它可以利用锁定数据库的方法来为用户提供一种安全的访问方式,这样可以保证用户的操作不被其它的用户所干扰。

8,尽管事务是维护数据库完整性的一个非常好的方法,但却因为它的独占性,有时会影响数据库的性能,尤其是在很大的应用系统中。由于在事务执行的过程中,数据库将会被锁定,因此其它的用户请求只能暂时等待直到该事务结束。有些情况下我们可以通过锁定表的方法来获得更好的性能。下面的例子就用锁定表的方法来完成前面一个例子中事务的功能。

LOCK TABLE inventory WRITE
SELECT Quantity FROM inventory WHEREItem='book';
...
UPDATE inventory SET Quantity=11 WHEREItem='book';
UNLOCK TABLES
9,使用索引
 
该贴参考[http://bbs.landingbj.com/t-0-245601-1.html]。
感谢以上博友分享!