MySql基础语法

SQL

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

  1. SQL 语句可以单行或多行书写,以分号结尾。
  2. 可使用空格和缩进来增强语句的可读性。
  3. MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写。
  4. 3 种注释
注释的语法说明
- - 空格单行注释
/**/多行注释
#这是mysql特有的注释方式

3. SQL分类

  • DDL(Data Definition Language)数据定义语言
    用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter 等

  • DML(Data Manipulation Language)数据操作语言
    用来对数据库中表的数据进行增删改。关键字:insert, delete, update 等

  • DQL(Data Query Language)数据查询语言
    用来查询数据库中表的记录(数据)。关键字:select, where 等

  • DCL(Data Control Language)数据控制语言(了解)
    用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等

DDL:操作数据库、表

1. 操作数据库:CRUD

  1. C(Create):创建

    创建数据库:create database 数据库名称;
    创建数据库,判断不存在,再创建: create database if not exists 数据库名称;
    创建数据库,并指定字符集: create database 数据库名称 character set 字符集名;
    
  2. R(Retrieve):查询

    查询所有数据库的名称: show databases;
    查询某个数据库的字符集:查询某个数据库的创建语句,show create database 数据库名称;
    
  3. U(Update):修改

    修改数据库的字符集
    alter database 数据库名称 character set 字符集名称;
    
  4. D(Delete):删除

    删除数据库:drop database 数据库名称;
    判断数据库存在,存在再删除:drop database if exists 数据库名称;
    
  5. 使用数据库

    查询当前正在使用的数据库名称:select database();
    使用数据库: use 数据库名称;
    操作表:CRUD

  6. C(Create):创建

    1. 语法:

      注意:最后一列,不需要加逗号(,)

    2. 数据库类型:

       1. int:整数类型 ;age int,
       2. double:小数类型 ;score double(5,2)
       3. date:日期,只包含年月日,yyyy-MM-dd
       4. datetime:日期,包含年月日时分秒	 yyyy-MM-dd HH:mm:ss
       5. timestamp:时间错类型	包含年月日时分秒	 yyyy-MM-dd HH:mm:ss	
          如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值
       6. varchar:字符串
           name varchar(20):姓名最大20个字符
       	zhangsan 8个字符  张三 2个字符
      

      创建表

       create table student(
       	id int,
       	name varchar(32),
       	age int ,
       	score double(4,1),
       	birthday date,
       	insert_time timestamp
       );
      

      复制表:

           create table 表名 like 被复制的表名;
      
  7. R(Retrieve):查询

    查询某个数据库中所有的表名称:show tables;
    查询表结构:desc 表名;
    
  8. 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 列名;
    
  9. D(Delete):删除

    drop table 表名;
    drop table  if exists 表名 ;
    

DML:增删改表中数据

  1. 添加数据:
    语法:

    insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);
    

注意:

  • 列名和值要一一对应。

    如果表名后,不定义列名,则默认给所有列添加值,insert into 表名 values(值1,值2,...值n);
    除了数字类型,其他类型需要使用引号(单双都可以)引起来
    
  1. 删除数据:

    语法:

     delete from 表名 [where 条件]
    

    注意:

     如果不加条件,则删除表中所有记录。
     如果要删除所有记录:
     	1. delete from 表名; -- 不推荐使用。有多少条记录就会执行多少次删除操作
     	2. TRUNCATE TABLE 表名; -- 推荐使用,效率更高 先删除表,然后再创建一张一样的表。
    
  2. 修改数据:

    语法:

     update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];
    

    注意:

     1. 如果不加任何条件,则会将表中所有记录全部修改。
    

DQL:查询表中的记录

  • select * from 表名;

    1. 语法:

        select:
     		字段列表
     	from
     		表名列表
     	where
     		条件列表
     	group by
     		分组字段
     	having
     		分组之后的条件
     	order by
     		排序
     	limit
     		分页限定
    

注:在工作企业中,上面的写法较为规范
2. 基础查询

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

DQL查询语句:

排序查询
1、语法:

SELECT 字段名 FROM 表名 WHERE 字段=值 ORDER BY 字段名 [ASC|DESC];
order by 排序字段1 排序方式1 ,  排序字段2 排序方式2...
排序方式:
     	ASC:升序,默认的。
		DESC:降序。

2、注意:组合排序

 如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。

聚合函数

SQL中的聚合函数作用
max(列名)求这一列最大值
min(列名)求这一列最小值
count(列名)统计这一列有多少条记录
avg(列名)求这一列的平均值
sum(列名)对这一列求总和

分组查询

  1. 语法:

    SELECT 字段 1,字段 2... FROM 表名 GROUP BY 分组字段 [HAVING 条件];
    
  2. 注意:
    分组之后查询的字段:分组字段、聚合函数(这样查出来才比较有意义)

  3. where 和 having 的区别?

    where 在分组之前进行限定,如果不满足条件,则不参与分组。having在分组之后进行限定,如果不满足结果,则不会被查询出来
    where 后不可以跟聚合函数,having可以进行聚合函数的判断。
    

分页查询

  1. 语法:

    SELECT *|字段列表 [as 别名] FROM 表名 [WHERE 子句] [GROUP BY 子句][HAVING 子句][ORDER BY 子句][LIMIT 子句];
    limit 开始的索引,每页查询的条数;
    
  2. 公式:

    开始的索引 = (当前的页码 - 1) * 每页显示的条数
    如下每页显示3条记录 :
     	SELECT * FROM student LIMIT 0,3; -- 第1页	
     	SELECT * FROM student LIMIT 3,3; -- 第2页	
     	SELECT * FROM student LIMIT 6,3; -- 第3页
    
  3. limit 是一个MySQL"方言"

posted @ 2019-07-26 23:22  _SpringCloud  阅读(6)  评论(0编辑  收藏  举报  来源