阅读本文大概需要 4 分钟。
来自:网络
1、MySQL中myisam与innodb的区别
不支持事务,但是每次查询都是原子的;
支持表级锁,即每次操作对整个表加锁;
存储表的总行数;
一个MYISAM表有三个文件:索引文件、表结构文件、数据文件;
采用非聚集索引,索引文件的数据域存储指向数据文件的指针。辅索引与主索引基本一致,但是辅索引不用保证唯一性。
支持ACID的事务,支持事务的四种隔离级别;
支持行级锁及外键约束:因此可以支持写并发;
不存储总行数;
一个InnoDb引擎存储在一个文件空间(共享表空间,表大小不受操作系统控制,一个表可能分布在多个文件里),也有可能为多个(设置为独立表空,表大小受操作系统文件大小限制,一般为2G),受操作系统文件大小的限制;
主键索引采用聚集索引(索引的数据域存储数据文件本身),辅索引的数据域存储主键的值;因此从辅索引查找数据,需要先通过辅索引找到主键值,再访问辅索引;最好使用自增主键,防止插入数据时,为维持B+树结构,文件的大调整。
2、MySQL INT和CHAR隐式类型转换需要注意什么?
+----+----------+
| id | name
|
+----+----------+
|
1
| apple |
| 2 | banana
|
|
3
| 99cat |
+----+----------+
// 查询条件转化为数字1再比较
mysql>
select *
from product
where id =
'1abc23';
+----+---------+
| id | name |
+----+---------+
|
1 | apple |
+----+---------+
// 查询字段全部转化成数字,id:1和id:2字段值转化为0,id:3转化成99,再比较
mysql>
select *
from product
where name=
0;
+----+----------+
| id | name |
+----+----------+
|
1 | apple |
|
2 | banana |
+----+----------+
3、MySQL 如何高效率随机获取N条数据?
SELECT *
FROM
`mm_account`
AS t1
JOIN (
SELECT
ROUND(
RAND() * (
SELECT
MAX(
id)
FROM
`mm_account`))
AS
id)
AS t2
WHERE t1.id >= t2.id
ORDER
BY t1.id
ASC
LIMIT
4;
SELECT *
FROM
`mm_account`
WHERE
id >= (
SELECT
floor(
RAND() * (
SELECT
MAX(
id)
FROM
`mm_account`)))
and city=
"city_91"
and showSex=
1
ORDER
BY
id
LIMIT
4;
SELECT *
FROM mm_account
WHERE
id >= ((
SELECT
MAX(
id)
FROM mm_account)-(
SELECT
MIN(
id)
FROM mm_account)) *
RAND() + (
SELECT
MIN(
id)
FROM mm_account)
limit
5;
SELECT *
FROM
`mm_account`
AS t1
JOIN (
SELECT
ROUND(
RAND() * (
(
SELECT
MAX(
id)
FROM
`mm_account`
where
id<
1000 )-(
SELECT
MIN(
id)
FROM
`mm_account`
where
id<
1000 ))+(
SELECT
MIN(
id)
FROM
`mm_account`
where
id<
1000 ))
AS
id)
AS t2
WHERE t1.id >= t2.id
ORDER
BY t1.id
LIMIT
5;
4、说说你知道的MySQL的索引类型,并分别简述一下各自的场景。
推荐阅读:
【56期】你说你熟悉并发编程,那么你说说Java锁有哪些种类,以及区别
【55期】面试中经常被问到Java引用类型原理,带你深入剖析
微信扫描二维码,关注我的公众号
朕已阅
本文分享自微信公众号 - 程序员的成长之路(cxydczzl)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。
来源:oschina
链接:https://my.oschina.net/u/4581745/blog/4671085