mysql5.5的默认存储引擎是innodb,是不是myisam引擎要被淘汰了

mysql5.5的默认存储引擎是innodb,是不是myisam引擎要被淘汰了,第1张

一、不是被淘汰。

1)如果是一些小型的应用或项目,那么MyISAM 会更适合。

2)如果使用一个超大数据量的项目,而且需要事务处理或外键支持,那么直接使用InnoDB方 式。

二、区别总结:

1.InnoDB不支持FULLTEXT类型的索引。

2.InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含 where条件时,两种表的 *** 作是一样的。

3.对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。

4.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。

5.LOAD TABLE FROM MASTER *** 作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。

另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”

PHP提供了三种不同的api连接到MySQL,这三种api是:mysql, mysqli以及PDO扩展。MySql函数是非常受欢迎的,但是官方团队并不鼓励再使用它们。在php手册里边,当你看到关于Mysql的函数,会发现都标有红色的标志,那意味着它们已经被弃用了。弃用ext/mysql函数不仅安全,而且使用其他数据库查询方法可以同样具有MySQL函数的所有功能。更好的方法是使用PDO代替ext/mysql函数。

以下是PHP里不应该再使用mysql函数的3大原因:

1、mysql函数已在PHP5.5中正式弃用,并将在PHP7中被删除。

2、mysql函数缺少面向对象的接口。

3、mysql函数不支持以下特性:

不支持非阻塞连续获取

不支持异步查询

不支持参数化查询

不支持存储过程

不支持多个语句

不支持在MySQL 5.1的中所有功能

不支持加密(SSL)

不支持压缩

不支持完整的字符集


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/6200751.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-17
下一篇2023-03-17

发表评论

登录后才能评论

评论列表(0条)

    保存