登录

  • mysql -u用户 -p密码
  • mysql -hIP地址 -u用户 -u密码

退出

  • exit

Sql语句分类

  • DDL 数据定义语言,用来定义数据库对象, 关键字:create,drop,alter等
  • DML 数据操作语言,用来对数据库中表的数据进行增删改,关键字:insert,delete,update等
  • DQL 数据查询语言,用来查询数据库中表的数据,关键字:select,where等
  • DCL 数据控制语言,用来定义数据库的访问权限和安全级别,关键字: grant,revoke等

DDL操作数据库

1.创建数据库

  • 直接创建数据库

    CAREATE DATABASE 数据库名;
  • 判断是否存在并创建数据库

    CREAET DATABASE IF NOT EXISTS 数据库名;
  • 创建数据库并指定字符集

    CREATE DATABASE 数据库名 CHARACTER SET 字符集;

2.查看数据库

  • 查看所有数据库

    SHOW DATABASES;
  • 查看某个数据的定义信息

    SHOW CREATE DATABASE 数据库名;

3.修改数据库

  • 修改数据的字符集

    ALTER DATABASE 数据库名 DEFAULT CHARACTER SET 字符集;

4.删除数据库

  • 删除指定的数据库

    DROP DATABASE 数据库名;

5.使用数据库

  • 使用/切换数据库

    USE 数据库;
  • 查看当前正在使用的数据库

    SELECT DATABASE();

6.创建表

  • 直接创建表

    CREATE TABLE 表名(字段名1 字段类型1, 字段名2 字段类型2, ...);
  • 创建一个表结构相同的表

    CREATE TABLE 新表名 LIKE 旧表名;

7.查看表

  • 查看所有表

    SHOW TABLES;
  • 查看表结构

    DESC 表名;
  • 查看创建表的SQL语句

    SHOW CREATE TABLE 表名;

8.删除表

  • 直接删除表

    DROP TABLE 表名;
  • 判断表存在并删除表

    DROP TABLE IF EXISTS 表名;

9.修改表

  • 添加列(字段)

    ALTER TABLE 表名 ADD 列名 类型;
  • 修改列类型

    ALTER TABLE 表名 MODIFY 列名 新类型;
  • 修改列名

    ALTER TABLE 表名 CHANGE 旧列名 新列名 类型;
  • 删除列

    ALTER TABLE 表名 DROP 列名;
  • 修改表名

    RENAME TATBLE 旧表名 TO 新表名;
  • 修改表字符集

    ALTER TABLE 表名 CHARACTER SET 字符集;

10.常用字段类型

类型 描述 说明
int(integer) 整数 integer默认11
double 双精度浮点数
float 单精度浮点数
varchar(M) 字符串 M为0-255之间整数
char(M) 字符串 M为0-255之间整数
date 日期类型 yyyy-MM-dd
datetime 日期时间类型 yyyy-MM-dd HH:mm:ss

DML操作数据库

1.表插入数据

  • 插入全部字段

    INSERT INTO 表名 VALUES(值1, 值2, 值3,...);
  • 插入部分字段

    INSERT INTO 表名(字段1, 字段2, 字段3, ...) VALUES(值1, 值2, 值3, ...);

2.复制表

  • 全部复制

    INSERT INTO 新表 SELECT * FROM 旧表;
  • 部分复制

    INSERT INTO 新表(字段1, 字段2, ...) SELECT 字段1,字段2,... FROM 旧表;

3.更新表

  • 不带条件修改表数据

    UPDATE 表名 SET 字段名1=值,字段名2=值;
  • 带条件修改表数据

    UPDATE 表名 SET 字段名1=值,字段名2=值 WHERE 字段名=值;

4.删除表数据

  • 不带条件删除表数据

    DELETE FROM 表名;
  • 带条件删除表数据

    DELETE FROM 表名 WHERE 字段名=值;
  • 整表销毁,重新创建一个同名新表

    TRUNCATE TABLE 表名;

DQL操作数据库

1.简单查询

  • 查询表所有数据

    SELECT * FROM 表名;
  • 查询表部分数据

    SELECT 字段名1,字段名2,... FROM 表名;
  • 别名查询(AS可省略)

    SELECT 字段名1 AS 别名1, 字段名2 AS 别名2,... FROM 表名;
  • 筛选重复值查询

    SELECT DISTINCT 字段名1,字段名2,... FROM 表名;
  • 查询结果参与运算(字段值必须为数值类型)

    SELECT 字段名 + 值 FROM 表名;

    SELECT 字段名1 + 字段名2 FROM 表名;

2.条件查询

SELECT 字段名 FROM 表名 WHERE 条件;

  • 比较运算符条件

    SELECT * FROM table WHERE age>=18;
  • 逻辑运算符条件(and or not)

    SELECT * FROM table WHERE age>=19 AND gender='男';
  • 范围运算符条件(in between)

    SELECT * FROM table WHERE name in('小红','小明');

    SELECT * FROM table WHERE age BETWEEN 18 AND 30;

3.模糊查询

SELECT * FROM 表名 WHERE 字段名 LIKE '通配符字符串';

  • 通配符字符串

    %: 任意个字符

    _: 一个字符
  • 查询名字'jordan'开头的数据

    SELECT * FROM table WHERE name LIKE 'jordan%';
  • 查询名字包含'jordan'的数据

    SELECT * FROM table WHERE name LIKE '%jordan%';
  • 查询名字'乔丹'开头,结尾两个字长度的数据

    SELECT * FROM table WHERE name LIKE '乔丹__';

4.查询结果排序

SELECT 字段名 FROM 表名 WHERE 字段名=值 ORDER BY 字段名 [ASX|DESC];

  • ORDER BY 排序
  • ASC 升序
  • DESC 降序
  • 查询年龄大于18的数据,并升序排列

    SELECT * FROM table WHERE age>18 ORDER BY age ASC;
  • 查询年龄大于18,升序排列, 如果年龄相同,则按体重大小降序排列

    SELECT * FROM table WHERE age>18 ORDER BY age ASC,weight DESC;

5.聚合函数

聚合函数为纵向查询,即对表的一列值(Null值会被过滤掉)进行计算并返回结果。

  • 统计指定列记录条数 COUNT

    SELECT COUNT(字段名) FROM 表名;
  • 计算指定列数值总和 SUM

    SELECT SUM(字段名) FROM 表名;
  • 计算指定列最大值 MAX

    SELECT MAX(字段名) FROM 表名;
  • 计算指定列最小值 MIN

    SELECT MIN(字段名) FROM 表名;
  • 计算指定列平均值 AVG

    SELECT AVG(字段名) FROM 表名;

6.分组查询

分组查询是指使用GROUP BY语句对查询信息进行分组,相同条件数据作为一组,通常与聚合函数一起使用

SELECT * FROM 表名 GROUP BY 分组字段 [HAVING条件];

  • 查询根据性别分组,统计男女人数各总数

    SELECT COUNT(*),sex FROM table GROUP BY sex;
  • 查询年龄大于18岁,根据性别分组,统计男女人数各总数

    SELECT COUNT(*),sex FROM table WHERE age>18 GROUP BY sex;
  • 查询年龄大于18岁,根据性别分组,统计男人人数各总数,并只显示总数大于10的数据

    SELECT COUNT(*),sex FROM table WHERE age>18 GROUP BY sex HAVING COUNT(*)>10;

HAVING 与 WHERE 的区别

  • HAVING是在数据分组后再进行过滤,WHERE是在数据分组前进行过滤。
  • HAVING后面可以使用聚合函数,WHERE不可以。

7.分页LIMIT

LIMIT offset,length; offset为偏移量,默认为0,length是返回的数据条数

  • 查询第二页数据,返回10条数据

    SELECT * FROM table LIMIT 1,10;

8.查询语句总和

SELECT *|字段名 [AS 别名] FROM 表名 [WHERE语句] [GROUP BY语句] [HAVING 语句] [ORDER BY 语句] [LIMIT 语句];

DCL操作数据库

1.DCL约束种类

  • 主键:PRIMARY KEY
  • 唯一:UNIQUE
  • 非空:NOT NULL
  • 默认:DEFAULT
  • 外键:FOREIGN KEY
  • 用法:

    CREATE TABLE 表名(字段名1 [DCL约束], 字段名2 [DCL约束], ...);

2.主键

  • 特点:唯一,非NULL
  • 创建person表,包含字段(id,name) 设定id为主键

    CREATE TABLE person(id int PRIMARY KEY, name varchar(10));
  • 主键自增 AUTO_INCREMENT,插入数据,主键自行递增

    CREATE TABLE person(id int PRIMARY KEY AUTO_INCREMENT);
  • 删除主键

    ALTER TABLE 表名 DROP PRIMARY KEY;

3.约束总和举例

  • 创建一张person表, 包含(id, name, age, sex, session_id)id为递增主键,name唯一非空,age非空默认为0,sex非空,session_id为外键。
CREATE TABLE person(
id int PRIMARY KEY AUTO_INCREMENT,
name varchar(10) UNIQUE NOT NULL,
age int NOT NULL DEFAULT 0,
sex char(4) NOT NULL,
session_id int FOREIGN KEY
)

Mysql常用操作笔记的更多相关文章

  1. mysql常用操作语句

    mysql常用操作语句 1.mysql -u root -p   2.mysql -h localhost -u root -p database_name 2.列出数据库: 1.show datab ...

  2. MySQL常用操作总结

    MySQL常用操作 前提条件:已安装MySQL. 学习目标:用一条sql语句写出A和B的剩余数量 AA表 BB表 以上为一道面试题,接下来由这道面试题来回顾一些数据库的基本操作. 登录MySQL su ...

  3. centos LAMP第四部分mysql操作 忘记root密码 skip-innodb 配置慢查询日志 mysql常用操作 mysql常用操作 mysql备份与恢复 第二十二节课

    centos  LAMP第四部分mysql操作  忘记root密码  skip-innodb 配置慢查询日志 mysql常用操作  mysql常用操作 mysql备份与恢复   第二十二节课 mysq ...

  4. Windows平台下MySQL常用操作与命令

    Windows平台下MySQL常用操作与命令 Windows平台下MySQL常用操作与命令,学习mysql的朋友可以参考下. 1.导出整个数据库 mysqldump -u 用户名 -p --defau ...

  5. MySQL常用操作2

    MySQL常用操作2 判断函数 IF(expr, value1, value2)  --  如果表达式expr为true,则返回value1,否则返回value2 IFNULL(value1, val ...

  6. Linux 笔记 - 第十五章 MySQL 常用操作和 phpMyAdmin

    博客地址:http://www.moonxy.com 一.前言 前面几章介绍了 MySQL 的安装和简单的配置,只会这些还不够,作为 Linux 系统管理员,我们还需要掌握一些基本的操作,以满足日常管 ...

  7. MYSQL常用操作函数的封装

    1.mysql常用函数封装文件:mysql.func.php <?php /** * 连接MYSQL函数 * @param string $host * @param string $usern ...

  8. 第二篇 Mysql常用操作记录(转载)

    我们在创建网站的时候,一般需要用到数据库.考虑到安全性,建议使用非root用户.常用命令如下: 1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户my ...

  9. mysql常用操作及常见问题

    常用操作 mysql备份: --整库备份 docker exec 容器ID mysqldump -uroot -p密码 --databases 库名 > 库名.sql --仅导出表和数据 mys ...

随机推荐

  1. python.36的特性新定义初学者必看课程

    一.Python3.6新特性 1.新的格局化字符串办法 <p "="">新的格局化字符串办法,即在一般字符串前增加 f 或 F 前缀,其效果相似于str.fo ...

  2. 认识并学会使用spring boot

    1,什么是SpringBoot SpringBoot是Spring项目中的一个子工程,与我们所熟知的Spring-framework 同属于spring的产品,用一些固定的方式来构建生产级别的spri ...

  3. python中time模块的调用及使用

    1 import time #通常import语句会写到代码的开头 2 3 print('------------------------') 4 print('------------------- ...

  4. 2022李宏毅作业hw1—新冠阳性人员数量预测。

    ​ 事前  : kaggle地址:ML2021Spring-hw1 | Kaggle 我的git地址: https://github.com/xiaolilaoli/lihongyi2022homew ...

  5. 大数据分析用自助式BI工具就能轻松解决,so easy!

    之前老板给了我一个任务,让我赶紧学习一下大数据分析,下个季度就要用. 赶紧看了一下日历,这离下个季度还有不到半个月的时间,而且我还没有数据分析基础,该怎么能在这么短的时间内学会大数据分析呢-- 经过多 ...

  6. .Net Core之JWT授权

    一.什么是JWT 文章参考:https://www.leo96.com/article/detail/55 JSON Web令牌(JWT)是一个开放标准(RFC 7519),它定义 了一种紧凑且自包含 ...

  7. svn问题总结

    有问题先尝试右键刷新,或clean up svn图标不显示 解决办法:打开注册表regedit,HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\Curren ...

  8. Windows操作下各种工具常用快捷键

    目录 Windows快捷键 谷歌浏览器快捷键 Nodepad++快捷键 Mobaxterm快捷键 Markdown快捷键 Windows快捷键 Win + E打开文件系统 Win + L锁屏 谷歌浏览 ...

  9. hdfs刷新节点失败,未显示Refresh nodes successful

    使用命令:hdfs dfsadmin -refreshNodes 没有显示Refresh nodes successful,而是:refreshNodes: /opt/module/hadoop-2. ...

  10. 常用的一些性能查询sql语句

    转至:https://blog.csdn.net/bosschen/article/details/84829912 --查看表锁 select * from sys.v_$sqlarea where ...