美文网首页
MySQL#命令

MySQL#命令

作者: upup果 | 来源:发表于2020-12-09 08:38 被阅读0次

参考地址:https://github.com/Snailclimb/JavaGuide/blob/master/docs/database/%E4%B8%80%E5%8D%83%E8%A1%8CMySQL%E5%91%BD%E4%BB%A4.md

基本操作

  1. /* Windows服务 /
    -- 启动MySQL
    net start mysql
    -- 创建Windows服务
    sc create mysql binPath= mysqld_bin_path(注意:等号与值之间有空格)
    /
    连接与断开服务器 */
    mysql -h 地址 -P 端口 -u 用户名 -p 密码
  2. SHOW PROCESSLIST -- 显示哪些线程正在运行
    SHOW VARIABLES -- 显示系统变量信息

数据库操作

  1. -- 查看当前数据库
    SELECT DATABASE();
  2. -- 显示当前时间、用户名、数据库版本
    SELECT now(), user(), version();
  3. -- 创建库
    CREATE DATABASE[ IF NOT EXISTS] 数据库名 数据库选项
    数据库选项:
    CHARACTER SET charset_name
    COLLATE collation_name
  4. -- 查看已有库
    SHOW DATABASES[ LIKE 'PATTERN']
  5. -- 查看当前库信息
    SHOW CREATE DATABASE 数据库名
  6. -- 修改库的选项信息
    ALTER DATABASE 库名 选项信息
  7. -- 删除库
    DROP DATABASE[ IF EXISTS] 数据库名
    同时删除该数据库相关的目录及其目录内容

表的操作

  1. -- 创建表
    CREATE [TEMPORARY] TABLE[ IF NOT EXISTS] [库名.]表名 ( 表的结构定义 )[ 表选项]
    每个字段必须有数据类型
    最后一个字段后不能有逗号
    TEMPORARY 临时表,会话结束时表自动消失
    对于字段的定义:
    字段名 数据类型 [NOT NULL | NULL] [DEFAULT default_value] [AUTO_INCREMENT] [UNIQUE [KEY] | [PRIMARY] KEY] [COMMENT 'string']
  2. -- 表选项
    (1) -- 字符集
    CHARSET = charset_name
    如果表没有设定,则使用数据库字符集
    (2) -- 存储引擎
    ENGINE = engine_name
    表在管理数据时采用的不同的数据结构,结构不同会导致处理方式、提供的特性操作等不同
    常见的引擎:InnoDB MyISAM Memory/Heap BDB Merge Example CSV MaxDB Archive
    不同的引擎在保存表的结构和数据时采用不同的方式
    MyISAM表文件含义:.frm表定义,.MYD表数据,.MYI表索引
    InnoDB表文件含义:.frm表定义,表空间数据和日志文件
    SHOW ENGINES -- 显示存储引擎的状态信息
    SHOW ENGINE 引擎名 {LOGS|STATUS} -- 显示存储引擎的日志或状态信息
    (3) -- 自增起始数
    AUTO_INCREMENT = 行数
    (4) -- 数据文件目录
    DATA DIRECTORY = '目录'
    (5) -- 索引文件目录
    INDEX DIRECTORY = '目录'
    -- 表注释
    COMMENT = 'string'
  3. -- 查看所有表
    SHOW TABLES[ LIKE 'pattern']
    SHOW TABLES FROM 库名
  4. -- 查看表结构
    SHOW CREATE TABLE 表名 (信息更详细)
    DESC 表名 / DESCRIBE 表名 / EXPLAIN 表名 / SHOW COLUMNS FROM 表名 [LIKE 'PATTERN']
  5. -- 修改表
    (1) -- 修改表本身的选项
    ALTER TABLE 表名 表的选项
    eg: ALTER TABLE 表名 ENGINE=MYISAM;
    (2) -- 对表进行重命名
    RENAME TABLE 原表名 TO 新表名
    RENAME TABLE 原表名 TO 库名.表名 (可将表移动到另一个数据库)
    -- RENAME可以交换两个表名
    (3) -- 修改表的字段机构(13.1.2. ALTER TABLE语法)
    ALTER TABLE 表名 操作名
    -- 操作名
    ADD[ COLUMN] 字段定义 -- 增加字段
    AFTER 字段名 -- 表示增加在该字段名后面
    FIRST -- 表示增加在第一个
    ADD PRIMARY KEY(字段名) -- 创建主键
    ADD UNIQUE [索引名] (字段名)-- 创建唯一索引
    ADD INDEX [索引名] (字段名) -- 创建普通索引
    DROP[ COLUMN] 字段名 -- 删除字段
    MODIFY[ COLUMN] 字段名 字段属性 -- 支持对字段属性进行修改,不能修改字段名(所有原有属性也需写上)
    CHANGE[ COLUMN] 原字段名 新字段名 字段属性 -- 支持对字段名修改
    DROP PRIMARY KEY -- 删除主键(删除主键前需删除其AUTO_INCREMENT属性)
    DROP INDEX 索引名 -- 删除索引
    DROP FOREIGN KEY 外键 -- 删除外键
  6. -- 删除表
    DROP TABLE[ IF EXISTS] 表名 ...
  7. -- 清空表数据
    TRUNCATE [TABLE] 表名

数据操作

  1. -- 增
    INSERT [INTO] 表名 [(字段列表)] VALUES (值列表)[, (值列表), ...]
    -- 如果要插入的值列表包含所有字段并且顺序一致,则可以省略字段列表。
    -- 可同时插入多条数据记录!
    REPLACE 与 INSERT 完全一样,可互换。
    INSERT [INTO] 表名 SET 字段名=值[, 字段名=值, ...]
  2. -- 查
    SELECT 字段列表 FROM 表名[ 其他子句]
    -- 可来自多个表的多个字段
    -- 其他子句可以不使用
    -- 字段列表可以用*代替,表示所有字段
  3. -- 删
    DELETE FROM 表名[ 删除条件子句]
    没有条件子句,则会删除全部
  4. -- 改
    UPDATE 表名 SET 字段名=新值[, 字段名=新值] [更新条件]

建表规范

  1. -- Normal Format, NF
    - 每个表保存一个实体信息
    - 每个具有一个ID字段作为主键
    - ID主键 + 原子表
  2. -- 1NF, 第一范式
    字段不能再分,就满足第一范式。
  3. -- 2NF, 第二范式
    满足第一范式的前提下,不能出现部分依赖。
    消除复合主键就可以避免部分依赖。增加单列关键字。
  4. -- 3NF, 第三范式
    满足第二范式的前提下,不能出现传递依赖。
    某个字段依赖于主键,而有其他字段依赖于该字段。这就是传递依赖。
    将一个实体信息的数据放在一个表内实现。

SELECT语句

SELECT [ALL|DISTINCT] select_expr FROM -> WHERE -> GROUP BY [合计函数] -> HAVING -> ORDER BY -> LIMIT

  1. select_expr
    -- 可以用 * 表示所有字段。
    select * from tb;
    -- 可以使用表达式(计算公式、函数调用、字段也是个表达式)
    select stu, 29+25, now() from tb;
    -- 可以为每个列使用别名。适用于简化列标识,避免多个列标识符重复。
    - 使用 as 关键字,也可省略 as.
    select stu+10 as add10 from tb;
  2. FROM 子句
    用于标识查询来源。
    -- 可以为表起别名。使用as关键字。
    SELECT * FROM tb1 AS tt, tb2 AS bb;
    -- from子句后,可以同时出现多个表。
    -- 多个表会横向叠加到一起,而数据会形成一个笛卡尔积。
    SELECT * FROM tb1, tb2;
    -- 向优化符提示如何选择索引
    USE INDEX、IGNORE INDEX、FORCE INDEX
    SELECT * FROM table1 USE INDEX (key1,key2) WHERE key1=1 AND key2=2 AND key3=3;
    SELECT * FROM table1 IGNORE INDEX (key3) WHERE key1=1 AND key2=2 AND key3=3;
  3. WHERE 子句
    -- 从from获得的数据源中进行筛选。
    -- 整型1表示真,0表示假。
    -- 表达式由运算符和运算数组成。
    -- 运算数:变量(字段)、值、函数返回值
    -- 运算符:
    =, <=>, <>, !=, <=, <, >=, >, !, &&, ||,
    in (not) null, (not) like, (not) in, (not) between and, is (not), and, or, not, xor
    is/is not 加上ture/false/unknown,检验某个值的真假
    <=>与<>功能相同,<=>可用于null比较
  4. GROUP BY 子句, 分组子句
    GROUP BY 字段/别名 [排序方式]
    分组后会进行排序。升序:ASC,降序:DESC
    以下[合计函数]需配合 GROUP BY 使用:
    count 返回不同的非NULL值数目 count(*)、count(字段)
    sum 求和
    max 求最大值
    min 求最小值
    avg 求平均值
    group_concat 返回带有来自一个组的连接的非NULL值的字符串结果。组内字符串连接。
  5. HAVING 子句,条件子句
    与 where 功能、用法相同,执行时机不同。
    where 在开始时执行检测数据,对原数据进行过滤。
    having 对筛选出的结果再次进行过滤。
    having 字段必须是查询出来的,where 字段必须是数据表存在的。
    where 不可以使用字段的别名,having 可以。因为执行WHERE代码时,可能尚未确定列值。
    where 不可以使用合计函数。一般需用合计函数才会用 having
    SQL标准要求HAVING必须引用GROUP BY子句中的列或用于合计函数中的列。
  6. ORDER BY 子句,排序子句
    order by 排序字段/别名 排序方式 [,排序字段/别名 排序方式]...
    升序:ASC,降序:DESC
    支持多个字段的排序。
  7. LIMIT 子句,限制结果数量子句
    仅对处理好的结果进行数量限制。将处理好的结果的看作是一个集合,按照记录出现的顺序,索引从0开始。
    limit 起始位置, 获取条数
    省略第一个参数,表示从索引0开始。limit 获取条数
  8. DISTINCT, ALL 选项
    distinct 去除重复记录
    默认为 all, 全部记录

UNION

  1. 将多个select查询的结果组合成一个结果集合。
    SELECT ... UNION [ALL|DISTINCT] SELECT ...
    默认 DISTINCT 方式,即所有返回的行都是唯一的
    建议,对每个SELECT查询加上小括号包裹。
    ORDER BY 排序时,需加上 LIMIT 进行结合。
    需要各select查询的字段数量一样。
    每个select查询的字段列表(数量、类型)应一致,因为结果中的字段名以第一条select语句为准。

子查询

  1. -- from型
    from后要求是一个表,必须给子查询结果取个别名。
    • 简化每个查询内的条件。
    • from型需将结果生成一个临时表格,可用以原表的锁定的释放。
    • 子查询返回一个表,表型子查询。
      select * from (select * from tb where id>0) as subfrom where id>1;
  2. -- where型
    • 子查询返回一个值,标量子查询。
    • 不需要给子查询取别名。
    • where子查询内的表,不能直接用以更新。
      select * from tb where money = (select max(money) from tb);
  3. -- 列子查询
    • 如果子查询结果返回的是一列。
    • 使用 in 或 not in 完成查询
    • exists 和 not exists 条件
      如果子查询返回数据,则返回1或0。常用于判断条件。
      select column1 from t1 where exists (select * from t2);
  4. -- 行子查询
    - 查询条件是一个行。
    select * from t1 where (id, gender) in (select id, gender from t2);
    行构造符:(col1, col2, ...) 或 ROW(col1, col2, ...)
    行构造符通常用于与对能返回两个或两个以上列的子查询进行比较。
  5. -- 特殊运算符
    != all() 相当于 not in
    = some() 相当于 in。any 是 some 的别名
    != some() 不等同于 not in,不等于其中某一个。
    all, some 可以配合其他运算符一起使用。

JOIN

将多个表的字段进行连接,可以指定连接条件。

  1. -- 内连接(inner join)
    • 默认就是内连接,可省略inner。
    • 只有数据存在时才能发送连接。即连接结果不能出现空行。
      on 表示连接条件。其条件表达式与where类似。也可以省略条件(表示条件永远为真)
      也可用where表示连接条件。
      还有 using, 但需字段名相同。 using(字段名)
      -- 交叉连接 cross join
      即,没有条件的内连接。
      select * from tb1 cross join tb2;
  2. -- 外连接(outer join)
    • 如果数据不存在,也会出现在连接结果中。
      -- 左外连接 left join
      如果数据不存在,左表记录会出现,而右表为null填充
      -- 右外连接 right join
      如果数据不存在,右表记录会出现,而左表为null填充
  3. -- 自然连接(natural join)
    自动判断连接条件完成连接。
    相当于省略了using,会自动查找相同字段名。
    natural join
    natural left join
    natural right join
    select info.id, info.name, info.stu_num, extra_info.hobby, extra_info.sex from info, extra_info where info.stu_num = ext

相关文章

  • MySQL#命令

    参考地址:https://github.com/Snailclimb/JavaGuide/blob/master/...

  • MySQL#索引

    为什么要使用索引? 通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 可以大大加快数据的检索速度(大大减...

  • Mysql学习笔记一

    1、连接Mysql mysql-h$ip-P$port-u$user-p net start mysql#或mys...

  • Centos7 下安装 WordPress(version 4.

    安装mysql# Centos6,Red hat6# 查询已安装的mysql相关软件包rpm -qa | grep...

  • 2.数据库的安装

    数据库的安装 CentOS安装MySQL# 安装MySQL服务端和客户端yum -y install mysql-...

  • Mysql#和$的区别

    区别分2部分: ① #{}表示一个占位符号,通过#{}可以实现preparedStatement向占位符中设置值,...

  • mysql#进阶1:基础查询

    /*语法:select 查询列表 from 表名;类似于打印东西特点:1.查询列表可以是:表中的字段、常量值、表达...

  • Linux常用命令

    目录 ls命令 cd命令 pwd命令 mkdir命令 rm命令 rmdir命令 mv命令 cp命令 cat命令 m...

  • Linux基础命令

    Linux基础命令 ifconfig命令 echo命令 tty命令 startx命令 export命令 pwd命令...

  • Linux常用命令笔记

    date命令 cal命令 df命令 free命令 exit命令 pwd命令 cd命令 ls命令 ls -a 例图 ...

网友评论

      本文标题:MySQL#命令

      本文链接:https://www.haomeiwen.com/subject/qvmzwktx.html