MySQL 零碎知识 - MySQL必知必会

重读《MySQL必知必会》

  • DISTINCT 作用于其后面的所有列

  • DESRIBE 相当于 SHOW COLUMNS FROM

  • SELECT xxx FROM table WHERE a = 'Hello' 能匹配出 Hellohello。因为 MySQL在执行匹配时默认不区分大小写

  • 单引号用来限定字符串,数值列则不需要

  • 通配符 % 匹配0到多个字符,_ 匹配一个字符

  • REGEXP 后接正则表达式匹配

  • 和其他SQL不同,MySQL使用 concat 函数拼接字段,而不是使用 + 或者 ||

  • + - * / 是算术运算

  • HAVING 完全可替代 WHERE,不过,一般把 HAVING 用在分组的数据上

  • UNION 操作,我从来没在实际生产上用过,其实就是在多个表里组织处数据结构相同 的表,然后通过 UNION 组成一张虚拟表,不过估计是性能杀手来着。UNION 默认 去除了重复的行,使用 UNION ALL 可以取消这种行为。

  • 全文索引,使用关键字 FULLTEXTMySQL5.6已经支持

  • 使用 RENAME TABLE xxx TO yyy 来重命名


更多文章
  • Nginx 请求匹配规则
  • Web开发系列(六):关系型数据库,ORM
  • Web开发系列(七):缓存,CDN
  • Web开发系列(八):单点故障,负载均衡
  • Web开发系列(五):form, json, xml
  • Web开发系列(四):Flask, Tornado和WSGI
  • Web开发系列(三):什么是HTML,CSS,JS?
  • Web开发系列(二):HTTP协议
  • Web开发系列(一):从输入网址到最后,这个过程经历了什么?
  • SNI: 让Nginx在一个IP上使用多个证书
  • Haskell: infixl, infixr, infix
  • Haskell简明教程(五):处理JSON
  • Haskell简明教程(四):Monoid, Applicative, Monad
  • HTTPS 的详细流程
  • OAuth2 为什么需要 Authorization Code?