当前位置: 代码迷 >> 综合 >> MySQL学习日志(day01)
  详细解决方案

MySQL学习日志(day01)

热度:56   发布时间:2023-12-13 22:19:34.0

MySql登录

  • mysql -uroot -proot \ mysql -uroot -p
  • mysql -hip -uroot -p连接目标的密码
  • mysql --host=ip --user=root --password=连接目标的密码

Mysql退出

  • exit
  • quit

MySQL目录结构

  1. mysql的安装目录
    配置文件 my.ini
  2. mysql的数据目录
    数据库:文件夹
    表:文件
    数据:数据

SQL

什么是SQL?
Structured Query Language:结构化查询语言
其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,成为“方言”。

SQL通用语法

  1. SQL语句可以单行或多行书写,以分号结尾;
  2. 可以使用空格和缩进来增强语句的可读性;
  3. MySQL数据库的SQL语句不区分大小写,关键字建议使用大写;
  4. 3中注释
    • 单行注释:- - 注释内容 或 # 注释内容 (注意- -后的空格 )
    • 多行注释:/* 注释 */

SQL语句的分类

  1. DDL:操作数据库和表。关键字:create、drop、alter等
  2. DML:操作数据库中存储的表中的记录(增删改表中的数据)。关键字:insert、delete、update等。
  3. DQL:操作数据库中存储的表中的记录(查询表中的数据)。关键字:select、、where等。
  4. DCL:授权。关键字:GRANT、REMOVKE等。

DDL:操作数据库和表

  1. 操作数据库:CRUD
    1 . Create:创建数据库:
    create database 数据库名;
    create database if not exists 数据库名; 如果数据库不存在就创建

创建一个数据库db1,判断是否存在,并指定字符集为gbk
create database if not exists db1 character set gbk;

2 . Retrieve(查询)
*查询所有数据库的名称:show database;
*查询某个数据库的字符集:查询某个数据库的创建语句:show create database 数据库名称;
3 . Update(修改)
修改数据库的字符集
alter database 数据库名称 character set 字符集名称;
4 . Delete
drop database 数据库名称;
判断数据库存在与否删除。
drop database if exists 数据库名;
5 . 使用数据库
查询当前正在使用的数据库名称:select database();
使用数据库
use 数据库名称;

  1. 操作表
    1 . C(Create):创建
    语法:
create table 表名(列名1 数据类型1,列名2 数据类型2...列名n 数据类型n);

复制表:create table 表名 like 被复制的表名;
数据类型:

  1. int:整数类型
  2. double:小数类型
  3. date:日期类型
  4. datetime:时间戳类型,精确到时分秒
  5. varchar:字符串类型

2 .R(Retrieve):查询
查询数据库中表的名称
*show tables;
查询表结构
*desc 表明;
3 .U(Update):修改

  1. 修改表名
    alter table 表名 rename to 新的表名;
  2. 修改表的字符集
    alter table 表名 character set 字符集名称;
  3. 添加一列
    alter table 表名 add 列名 数据类型;
  4. 修改列的名称 类型
    alter table 表名 change 列名 新列名 新数据类型;
    alter table 表名 modify 列名 新数据类型;
  5. 删除列
    alter table 表名 drop 列名;
    4 .DDelete):删除表
    drop table 表名;
    drop table if exits 表名;

客户端图形化工具:SQLYoga

在这里插入图片描述
安装简单

DML:增删改表中的数据

  1. 添加数据
    语法:sql insert into 表名(列名1,列名2,...,列名n) values(值1,值2,...,值n)
    注意:

    1. 列名和值要一一对应
    2. 如果表名后,不定义列名,则默认给所有列添加值 sql insert into 表名 values(值1,值2,...,值n)
    3. 除了数字类型,其他类型需要使用引号(单引双引都可以)引起来
  2. 删除数据
    语法格式:sql delete from 表名 [where 条件]
    注意:

    1. 如果不加条件,则删除表中的所有记录
      2.如果要删除所有记录
      1. delete from 表名;——不推荐使用。有所少条记录就会执行多少次删除操作
      2. truncate table 表名; ——推荐使用,效率更高。删除表,然后再创建一个一模一样的新表
  3. 修改数据
    语法:update 表名 set 列名1 = 值1,列名2 = 值2,...[where 条件]
    注意:
    如果不加任何条件则会将表中所有数据都修改;

DQL:查询表中的记录

*select * from表名;
  1. 语法:
select字段列表
from表名列表
where条件列表
group by分组字段
having分组之后的条件
order by排序
limit分页限定
  1. 基础查询
    1. 多个字段的查询select 字段名1,字段名2,...from 表名;
      注意:如果查询所有字段,则可以用*代替字段列表
    2. 去除重复
      *distinct
    3. 计算列
      *一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)
      *ifnull(表达式1,表达式2):null参与的运算,计算结果都为null
      表达式1:哪个字段需要判断是否为null
      如果该字段为null后的替换值
    4. 起别名
      *as:as也可以省略
  2. 条件查询
    1. where子句后跟条件
    2. 运算符
    >、<、<=、>=、=、<>
    BETWEEN…AND
    IN(集合):在集合内的
    LIKE:模糊查询。占位符:_单个任意占位符;%:多个任意字符
    IS NULL
    and 或 &&
    or 或 ||
    not 或 !
    使用:

查询年龄大于20岁
SELECT * FROM student WHERE age > 20;
查询年龄大于等于20小于等于30岁
SELECT * FROM student WHERE age >= 20 && age <= 30;
SELECT * FROM student WHERE age BETWEEN 20 AND 30;
查询年龄22,19,25岁的信息
SELECT * FROM student WHERE age =22 orage =19 or age =25;
SELECT * FROM student WHERE age IN(22,19,25);
查询英语成绩为null
SELECT * FROM student WHERE English IS NULL;
差不为空:IS NOT NULL;
查询姓马的名字
SELECT * FROM student WHERE name LIKE ‘马%’;

  相关解决方案