当前位置 博文首页 > @王某人:数据库基础----mysql-----CRUD

    @王某人:数据库基础----mysql-----CRUD

    作者:[db:作者] 时间:2021-06-17 21:13

    数据库

    ?????简介:

    ??????????数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,
    ???????????????可以被各种 用户或应用共享的数据集合。
    ??????????数据库:存储、维护和管理数据的集合。
    ??????????数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库
    ???????????????的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数
    ???????????????据库的安全性和完整性。 用户通过数据库管理系统访问数据库中的数据。
    ???????????????数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。
    ??????????常用数据库管理系统:
    在这里插入图片描述

    ?????三大范式:

    在这里插入图片描述

    SQL语言:

    ?????概述:

    ??????????SQL:Structure Query Language(结构化查询语言)来被国际化标准组织(ISO)采
    ??????????纳为关系数据库语言的国际标准。
    ??????????各数据库厂商都支持ISO的SQL标准,(普通话 )
    ??????????各数据库厂商在标准的基础上做了自己的扩展,(方言)
    ??????????Create, Read, Update, and Delete 通常称为CRUD操作。

    ?????分类:

    • DDL(Data Definition Language):数据定义语言
      用来定义数据库对象:库、表、列等。
    • DML(Data Manipulation Language):数据操作语言
      用来定义数据库记录(数据)增删改。
    • DCL(Data Control Language):数据控制语言
      用来定义访问权限和安全级别。 -
    • DQL(Data Query Language):数据查询语言
      用来查询记录(数据)查询。

    ?????DDL

    ??????????操作数据库:
    ??????????1,创建:
    ???????????????CREATE DATABASE 数据库名 character set 编码方式 collate 排序方式
    ???????????????编码方式:gb2312,utf-8,gbk,iso-8859-1
    ??????????2.查看数据库:
    ???????????????show databases 数据库名;
    ???????????????查看前面创建的数据库的定义信息:
    ???????????????show create databases 数据库名;
    ??????????3,修改数据库:
    ???????????????alter database 数据库名 character set 编码方式
    ??????????4,删除数据库:
    ???????????????drop database 数据库名
    ??????????5,查询当前使用的数据库:
    ???????????????Select database();
    ??????????6,切换数据库:
    ???????????????use 数据库名
    ??????????操作表:
    ??????????1,创建新表:
    ???????????????CREATE TABLE
    ???????????????语法:
    ????????????????????CREATE TABLE 表名(
    ????????????????????列名1 数据类型 [约束],
    ????????????????????列名2 数据类型 [约束],
    ????????????????????列名n 数据类型 [约束]
    ???????????????);
    ??????????常用数据类型:
    ???????????????int:整型 double:浮点型,如double(5,2)表示最多5位,其中必须有2位小
    ????????????????????数,即最大值为 999.99;默认支持四舍五入
    ???????????????char:固定长度字符串类型; char(10) 'aaa ’ 占10位
    ???????????????varchar:可变长度字符串类型; varchar(10) ‘aaa’ 占3位
    ???????????????text:字符串类型,比如小说信息;
    ???????????????blob:字节类型,保存文件信息(视频,音频,图片);
    ???????????????date:日期类型,格式为:yyyy-MM-dd;
    ???????????????time:时间类型,格式为:hh:mm:ss timestamp:
    ????????????????????时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值
    ???????????????datetime:日期时间类型 yyyy-MM-dd hh:mm:ss
    ??????????2,删除表:
    ???????????????drop table 表名;
    ??????????3,当前数据库中的所有表
    ???????????????show tables;
    ??????????4,查看表的字段信息
    ???????????????desc 表名;
    ??????????5,增加列:
    ???????????????alter table 表名 add 新列名 新的数据类型
    ??????????6,修改列:
    ???????????????alter table 表名 change 旧列名 新列名 新的数据类型
    ??????????7,删除列:
    ???????????????alter table 表名 drop 列名
    ??????????8,重命名表:
    ???????????????alter table 旧表名 rename 新表名;
    ??????????9,查看表的创建细节:
    ???????????????show create table 表名;
    ??????????10,修改表的字符集:
    ???????????????alter table 表名 character set 编码方式

    ?????DML

    ??????????DML是对表中的数据进行增、删、改的操作。
    ??????????主要包括:INSERT 、UPDATE、 DELETE
    ??????????在mysql中,字符串类型和日期类型都要用单引号括起来。
    ??????????空值:null
    ?????1,插入操作(insert):
    ??????????insert into 表名 (列名) values(数据值);
    ??????????同时插入多行:
    ?????????? insert into 表名(列名) values(第一行数据),(第二行数据),(),();
    ?????2,修改(更新)操作(UPDATE):
    ??????????UPDATE 表名 SET 列名1=列值1,列名2=列值2 … WHERE 列名=值
    ?????3,删除操作(DELETE):
    ??????????DELETE from 表名 【WHERE 列名=值】
    ??????????Turncate table 表名
    ??????????- DELETE 删除表中的数据,表结构还在;删除后的数据可以找回
    ??????????- TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。
    ???????????????- 删除的数据不能找回。执行速度比DELETE快。
    ??????????注:
    ???????????????为空的条件:列名 is null or 列名=’’ (两个单引号表示空字符串)
    ???????????????获取当前系统时间:now() select now();

    ?????DCL

    ??????????1,创建用户:
    ???????????????create user 用户名@指定ip identified by 密码;
    ???????????????create user 用户名@客户端ip identified by 密码; (指定IP才能登陆)
    ???????????????create user 用户名@‘% ’ identified by 密码 (任意IP均可登陆)
    ??????????2,用户授权:
    ???????????????给指定用户授予指定指定数据库指定权限
    ???????????????grant 权限1,权限2,…,权限n on 数据库名.* to 用户名@IP;
    ??????????3,用户权限查询:
    ???????????????show grants for 用户名@IP;
    ??????????4,撤销用户权限:
    ???????????????revoke 权限1,权限2,…,权限n on 数据库名.* from 用户名@IP;
    ??????????5,删除用户:
    ???????????????drop user 用户名@IP;

    ?????DQL

    ??????????数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。
    ??????????查询返回的结果集是一张虚拟表。
    ?????select:
    ??????????语法:
    ???????????????SELECT 列名 FROM 表名 【WHERE --> BROUP BY–>HAVING–> ORDER BY】
    ???????????????SELECT 要查询的列名称
    ????????????????????FROM 表名称
    ????????????????????WHERE 限定条件 /行条件/
    ????????????????????GROUP BY grouping_columns /对结果分组/
    ????????????????????HAVING condition /分组后的行条件/
    ????????????????????ORDER BY sorting_columns /对结果分组/
    ????????????????????LIMIT offset_start, row_count /结果限定/
    ??????????运算符及关键字:
    ???????????????=、!=、<>、<、<=、>、>=; BETWEEN…AND; IN(set); IS NULL; AND;
    ??????????OR; NOT;
    ?????模糊查询:
    ??????????语法: 列名 like ‘表达式’ //表达式必须是字符串
    ??????????通配符: _(下划线): 任意一个字符
    ??????????%:任意0~n个字符,‘张%’
    ?????字段控制查询:
    ??????????去除重复记录:
    ???????????????select distinct 字段名 from 表名;
    ??????????字段之和:
    ???????????????select 字段1+字段2 from 表名 ;
    ???????????????两字段必须是数值类型,有一个不是会出错
    ??????????把NULL转换成数值0:
    ???????????????SELECT *,sal+IFNULL(comm,0) FROM emp;
    ??????????给列名加别名:
    ???????????????字段名 as 别名 (as可省略)
    ?????排序:
    ??????????order by 列名 asc/desc //asc 升序 desc 降序 默认不写的话是升序
    ?????聚合函数:
    ??????????聚合函数是用来做纵向运算的函数:
    ??????????COUNT(列名):统计指定列不为NULL的记录行数;
    ??????????MAX(列名):计算指定列的最大值,如是字符串类型,那么使用字符串排序运算;
    ?????????? MIN(列名):计算指定列的最小值,如是字符串类型,那么使用字符串排序运算;
    ??????????SUM(列名):计算指定列的数值和,如不是数值类型,那么计算结果为0;
    ??????????AVG(列名):计算指定列的平均值,如不是数值类型,那么计算结果为0;
    ?????分组查询:
    ??????????当需要分组查询时需要使用GROUP BY子句,例如查询每个部门的工资和
    ??????????注意:如果查询语句中有分组操作,
    ??????????则select后面能添加的只能是聚合函数和被分组的列名
    ?????Having子句:
    ??????????1.having是在分组后对数据进行过滤,where是在分组前对数据进行过滤
    ??????????2.having后面可以使用分组函数(统计函数) where后面不可以使用分组函数。
    ?????????? WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条、
    ??????????件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。
    ?????LIMIT:
    ??????????LIMIT用来限定查询结果的起始行,以及总行数。
    ??????????limit 开始下标,显示条数;//开始下标从0开始
    ??????????limit 显示条数;//表示默认从0开始获取数据
    ?????分页查询:
    ??????????pageIndex 页码值 pageSize 每页显示条数
    ??????????limit (pageindex-1)*pagesize,pagesize;