《MySQL必知必会》读书笔记1

第一到三章:了解SQL、MySQL简介、使用MySQL

  • 数据库: DB
    • 模式 -> 什么是模式?
    • 数据类型
    • 主键
  • 数据库管理系统: DBMS(比如MySql)
  • SQL: 一种与数据库通信的结构化查询语言
  • MySQL: 一个数据库软件
  • MySQL工具: MySQL命令行实用程序、 MySQL Administrator、 MySQL Query Browser
  • 连接和登录数据库
    • 主机名(本地localhost)
    • 端口(默认3306)
    • 合法的用户名
    • 密码
  • 选择数据库
  • 查看表
  • 查看列
    • desc table; 或者 show column from table;
  • 其他show 语句: help show;
    • show status; //获取服务器状态信息
    • show create database; show create table; //显示创建数据库或者表的mysql语句
    • show grants; //显示授予用户的安全权限
    • show errors; show warnings; //显示服务器错误或者警告消息
  • infomation_schema: 获得和过滤模式信息

第四章:检索数据

  • SELECT

    • 想选择什么?
    • 想从什么地方选择?
  • 检索一个列

    • SELECT name FROM tb_student;
  • 检索多个列

    • SELECT name, age FROM tb_student;
  • 检索所有列

    • SELECT * FROM tb_student;
  • 检索不同的行(去重)

    • DISTINCT
    • SELECT address FROM student;
    • SELECT address, department FROM student;(每行都不同才算重复)
  • 限制结果

    • LIMIT 5 :表示返回不超过5条数据
    • LIMIT 5, 3 :表示返回从第3行开始的5条数据
    • SELECT * FROM student LIMIT 5, 3;
  • 完全限定的表名

    • 可以使用 表名.列名 和 数据库名.表名 限定
    • SELECT student.name FROM crashcource.student;

第五章:排序检索数据

  • ORDER BY 字句 (order by 对文本的排序取决于数据库设置)
    • SELECT* FROM student ORDER BY birth; //把检索出来的结果按birth排序
  • 按多个列排序
    • SELECT * FROM student ORDER BY address, birth; //先按address排序,再按birth排序
  • ORDER BY 默认是升序(从A到Z),指定 DESC 关键字是降序。
    • SELECT * FROM student ORDER BY birth DESC;
  • 多列降序排序
    • SELECT * FROM student ORDER BY birth DESC, address; //先按birth降序排列,birth一样的再按address排列
  • ORDER BY 和 LIMIT 的组合
    • SELECT birth FROM student ORDER BY birth DESC LIMIT 1; //找出年纪最小的出生年份

第六章:过滤数据(WHERE字句)

  • WHERE字句操作符 = != < > >= <=

    • <> 不等于
    • BETWEEN AND 在指定的两个值间
    • SELECR * FROM student WHERE name='小明';
    • SELECR * FROM student WHERE birth BETWEEN 1990 AND 1999;

    操作符后面是数值不需要单引号,如果是字符,就需要单引号

    • 检查空值
    • SELECR * FROM student WHERE birth IS NULL; //检索出生日期是空的学生

第七章:数据过滤(高级搜索条件)

  • 逻辑操作符
    • AND 与 (优先级更高)
    • OR 或
      • WHERE 可以包含任意条 AND 或者 OR 操作符,不过要注意优先级,加上小括号消除歧义
    • IN 指定范围的匹配,跟 OR 功能一致,不过检索效率比 OR 更高
      • SELECR * FROM student WHERE id IN (1,2,3); //查询id=1、2、3的记录
    • NOT 取反
      • 否定后面的条件
      • SELECR * FROM student WHERE id NOT IN (1,2,3); //查询id=1、2、3以外的记录

第八章:通配符

  • LIKE 操作符
  • % 通配符:任何字符出现任意次数(可以区分大小写,怎么区分?)
    • SELECT * FROM student WHERE name LIKE '谢%'; //检索出名字以'谢'开头的所有人
  • _ 通配符:只能匹配单个字符
  • 注意事项:
    • 不要过度使用通配符,能用其他操作符代替就使用其他操作符
    • 除非必须,不要把通配符放在搜索模式的开始处,效率最低

第九章:正则表达式

  • 需要学习正则表达式的语法和规则

  • REGEXP 操作符

    • SELECT * FROM student WHERE name REGEXP '.岳';
  • 区分大小写

    • 默认是不区分的
    • 要区分的话需要加上 BINARY 关键字
      • SELECT * FROM student WHERE name REGEXP BINARY '.yue';
  • OR 匹配

    • REGEXP '1000 | 2000'
  • 匹配几个字符之一

    • REGEXP '[123]' 相当于 '1|2|3'
  • 匹配范围

    • [0123456789] 相当于 [0-9]
  • 匹配特殊字符(转义)

    • 正则表达式里面有一些特殊字符,要匹配这些特殊字符的时候,需要加上双反斜杠 \\ 在前面转义
      • \\. \\- \\| \\[ \\] \\\
    • \\f 换页
    • \\n 换行
    • \\r 回车
    • \\t 制表
    • \\v 纵向制表
  • 匹配字符类

    • 常见的一些组合的匹配
    • [:alnum:] 任意字母和数字,同[a-zA-Z0-9]
    • [:alpha:] 任意字母,同[a-zA-Z]
    • [:blank:] 空格和制表,同[\t]
    • [:cntrl:] ASCII控制字符(ASCII 0到31和127)
    • [:digit:] 任意数字,同[0-9]
    • [:graph:] 任意可打印字符,除了空格
    • [:lower:] 任意小写字母,同[a-z]
    • [:print:] 任意可打印字符
    • [:punct:] 既不在 [:alnum:] 也不在 [:cntrl:] 中的任意字符
    • [:space:] 包括空格在内的任意空白字符,同[\\f\\n\\r\\t\\v]
    • [:upper:] 任意大写字母,同[A-Z]
    • [:xdigit:] 任意十六进制数字,同[a-fA-F0-9]
  • 重复元字符

    • * 任意个
    • + 1个或者多个,同 {1,}
    • ? 0个或者1个,同 {0,1}
    • {n} 指定数目的匹配
    • {n,} 不少于指定数目的匹配
    • {n,m} 匹配数目的范围(m不超过255)
  • 定位符

    • ^ 文本的开始

    • $ 文本的结尾

    • [[:<:]] 词的开始

    • [[:>:]] 词的结尾

      • REGEXP '^[0-9\.]' 匹配任意数字或者.开头的记录
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容

  • 全书共有30章,在通读完之后。进行总结。 全书可以划分为1,2章节是对MYSQL数据库的介绍;3章节是连接数据库;...
    小董儿阅读 203评论 0 0
  • 前言 一、基础知识1.了解数据库数据库(database):保存有组织的数据的容器表(table):某种特定类型数...
    流水混帐阅读 500评论 0 1
  • 这一篇最主要是记录下命令,方便以后查找 使用Mysql 创建数据库 create database mysql_t...
    Treehl阅读 576评论 0 0
  • 表 存储在表中的数据是同一种类型的数据或清单。 数据库中的表有为一个名字来标识自己。 表具有一些特性,这些特性定义...
    蛐蛐囍阅读 1,309评论 0 7
  • 1.表中的任何列都可以作为主键, 只要它满足以下条件:任意两行都不具有相同的主键值;每一行都必须具有一个主键值( ...
    Cherryjs阅读 650评论 0 0