首页 > 数据库 >MySQL数据库基础1

MySQL数据库基础1

时间:2024-08-06 18:55:34浏览次数:10  
标签:comment 01 数据库 MySQL 基础 查询 字段 表名 员工

sql通用语法
  1. SQL语句可以单行或多行书写,以分号结尾。
  2. SQL语句可以使用空格/缩进来增强语句的可读性
  3. MySQL数据库的SQL语句不区分大小写,关键字建议使用大写
  4. 注释:

单行注释: -- 注释内容 或 # 注释内容(MySQL特有)

多行注释: /* 注释内容*

SQL分类

DDL
库操作

查询所有数据库

show databases;

查询当前数据库

select database();

创建数据库

create database [IF NOT EXIETS]数据库名[DEFAULT CHARSET 字符集] [COLLATE排序规则]

再次创建相同名称的数据库时会报错

设置字符集为utf8mb4

使用另一个数据库

use 数据库名;

此时在查看当前数据库就是目前你所在的数据库

删除数据库

drop database [IF EXISTS] 数据库名;

表操作-创建与查看

查询当前数据库所有的表

show tables;

表示当前数据库下没有数据表

创建表

create table 表名(

字段1 字段1的类型[comment 字段1的注释],

字段2 字段2的类型[comment 字段2的注释],

字段3 字段3的类型[comment 字段3的注释],

......

字段n 字段n的类型[comment 字段n的注释]

)[comment 表注释];

create table student(

name varchar(20) comment "姓名",

age int comment "年龄",

sno varchar(20) comment "学号"

) comment "学生表";

建表结果如下:

查询表结构:desc 表名

查询建表语句show create table 表名;

表操作-数据类型

主要分为三部分:数值类型、字符串类型、日期时间类型

数值类型

字符串类型

char和varchar的区别,这是一个常见的面试题 (定长和变长)

1、char性能高,varchar性能较低,原因是需要计算数据的长度进而确定需要使用的空间

2、char是定长的,varchar是变长的,更节省空间,使空间得倒充分利用

日期类型

设计一张员工信息表,要求如下:

1. 编号 (纯数字)

2. 员工工号(字符串类型,长度不超过10位)

3. 员工姓名 (字符串类型,长度不超过10位)

4. 性别 (男/女,存储一个汉字)

5. 年龄 (正常人年龄,不可能存储负数)

6. 身份证号 (二代身份证号均为18位,身份证中有X这样的字符)

7. 入职时间 (取值年月日即可) entrydate

create table emp(

id int comment'编号',

workno varchar(10) comment '工号',

name varchar(10) comment '姓名',

gender char(1) comment '性别',

age tinyint unsigned comment '年龄',

idcard char(18) comment '身份证号',

entrydate date comment '入职时间'

) comment '员工表';

表操作-添加修改与删除

添加字段

alter table 表名 add 字段名 类型(长度) [COMMENT 注释];

比如为emp表新增一个字段 昵称,nickname,类型为varchar(20)

alter table emp add nickname varchar(20) comment ‘昵称’;

修改字段

修改数据类型

alter table 表名 MODIFY 字段名 新数据类型

修改字段名和字段类型

alter table表名 change 旧字段名 新字段名 类型 [comment 注释];

例子:将emp表中的nickname字段修改为username,类型为varchar(30)

alter table emp change nickname usename varchar(30)


删除字段

alter table 表名 drop 字段名;

修改表名

alter table 表名 rename  to 新表名;

表操作-删除

删除表

drop table [if exists] 表名;

删除表,并重新创建该表( 意义是里面的数据全部都删除了)

truncate table表名;

DDL总结
DML

用于对数据库中表的数据记录进行增删改操作

添加数据insert

1、给指定字段添加数据

insert into 表名(字段1,字段2,字段3,...)values (值1,值2,值3...);  

插入后查询下表中的数据

F1:

F2:

2、给全部字段添加数据

insert into 表名 values(值1,值2,...);  此时值1对应表中第一个字段,值2对应表中第二个字段,...

插入成功,注意值的顺序要对应表中字段的顺序

数据表中多了一条新插入的数据

  1. 批量添加数据

insert into 表名(字段1,字段2,字段3,...)values

(值1,值2,值3...),

(值1,值2,值3...),

(值1,值2,值3...);

insert into 表名 values

(值1,值2,...),

(值1,值2,...),

(值1,值2,...);

如:insert into emp values 

(3,'0003','白眉鹰王殷天正','男',46,'1556662x','1328-01-01'),
(4,'0004','金毛狮王谢逊','男',45,'1556663x','1328-012-01'),
(5,'0005','青翼蝠王韦一笑','男',44,'1556664x','1328-03-01'),
(6,'0006','蛛儿','女',18,null,'1328-03-01'),
(7,'0007','张三丰','男',88,'1556664x','1260-03-01'),
(8,'0008','张翠山','男',22,null,'1328-03-01'),
(9,'0009','殷素素','女',18,null,'1328-03-01'),
(10,'00010','杨逍','男',40,'1556664x','1328-03-01'),
(11,'00011','杨不悔','女',20,'1556664x','1328-03-01');

插入后结果:

注意点

1、字段顺序和值的顺序是一一对应的

2、日期类型和字符串类型的要包在引号中

3、插入的数据大小,不能超过字段的范围

修改数据update

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

案例:

修改id为1的数据,将name修改为李四

update emp set name='李四' where id =1;

修改id为1的数据,name修改为赵敏,gender修改为女

update emp set name='赵敏',gender='女' where id =1;

将所有的员工入职日期修改为2000-01-01

update emp set entrydate='2020-01-01';

最终修改后的结果为:

删除数据delete

delete from 表名 [where 条件]

删除女性员工

delete from emp where gender = ‘女’;

删除所有员工:

delete from emp;

总结

DQL
  1. 语法

  1. 基础查询
  1. 查询多个字段

select 字段1,字段2,字段3,字段4...

from 表名;

2、查询全部字段

select  *  from 表名;

select 全部字段 from 表名;

3、为查询到的字段设置别名

select 字段1 as 别名1,字段2 as 别名2,字段3  as 别名3

from 表名;

4、去除重复记录

 select distinct 字段列表 from 表名;

获取员工入职日期有哪些?

  1. 条件查询

select 字段列表 from 表名 where 条件列表;

where后可以跟的条件

insert into emp values

(1,'0001','张无忌','男',23,'1556662x','1348-01-01'),

(2,'0002','赵敏','女',23,'1556662x','1348-01-01'),

(3,'0003','白眉鹰王殷天正','男',46,'1556662x','1328-01-01'),

(4,'0004','金毛狮王谢逊','男',45,'1556663x','1328-012-01'),

(5,'0005','青翼蝠王韦一笑','男',44,'1556664x','1328-03-01'),

(6,'0006','蛛儿','女',18,null,'1328-03-01'),

(7,'0007','张三丰','男',88,'1556664x','1260-03-01'),

(8,'0008','张翠山','男',22,null,'1328-03-01'),

(9,'0009','殷素素','女',18,null,'1328-03-01'),

(10,'00010','杨逍','男',40,'1556664x','1328-03-01'),

(11,'00011','杨不悔','女',20,'1556664x','1328-03-01');

条件查询练习

  1. 查询年龄等于 88 的员工

2.查询年龄小于 20 的员工信息

3.查询年龄小于等于 20 的员工信息

 4  查询没有身份证号的员工信息

 5. 查询有身份证号的员工信息

6.查询年龄不等于 88 的员工信息

7.查询年龄在15岁(包含) 到 20岁(包含)之间的员工信息

8.查询性别为 女 且年龄小于 25岁的员工信息

 9.查询年龄等于18 或 20 或 40的员工信息

10.查询姓名为两个字的员工信息

11.查询身份证号最后一位是X的员工信息

  1. 聚合查询

聚合函数:将一列数据作为一个整体,进行纵向计算

常见聚合函数

函数

功能

count

统计总量

max

最大值

min

最小值

avg

平均值

sum

求和

语法:

select 聚合函数(字段列表) from 表名;

练习题:

- 1. 统计该企业员工数量

- 2. 统计该企业员工的平均年龄

- 3. 统计该企业员工的最大年龄

- 4. 统计该企业员工的最小年龄

5. 所有男性员工的年龄之和

注意:所有null值不参与聚合函数的运算

  1. 分组查询

1、语法:

select 字段列表

from 表名

[where 条件]

GROUP by 分组字段名

[having 分组后过滤条件]

2、where与having的区别

执行时机不同:  where是分组之前进行过滤,不满足where条件,不参与分组;而having是分组之后对结果进行过滤

判断条件不同:  where不能对聚合函数进行判断,而having可以。

3、练习题

1) 根据性别分组 ,统计男性员工 和 女性员工的数量

2).根据性别分组,统计男性员工 和 女性员工的平均年龄

3)查询年龄小于45的员工 , 并根据入职日期分组 ,获取员工数量大于等于3的入职日期

  1. 排序查询

语法

select 字段列表

from 表名

order by 字段1 排序方式,字段2 排序方式;

练习

  1. 根据年龄对公司的员工进行升序排序

2.根据入职时间,对员工进行降序排序

              降序 desc  且不可省略

3. 根据年龄对公司的员工进行升序排序年龄相同 ,再按照入职时间进行降序排序

  1. 分页查询

语法:

select 字段

from 表名

limit 起始索引,查询记录数;

练习:

  1. 查询第1页员工数据,每页展示10条记录

这里的起始索引0可以省略,因为默认为0。

2..查询第2页员工数据,每页展示10条记录

因为一共11条,第二页就1条

  1. 执行顺序

  1. 总结

DCL

用来管理数据库用户、控制数据库访问权限

用户管理 

了解即可工作中你是没有权限操作的这是DBA的事

查询用户   

USE mysql;

select * from user;

创建用户

create user ‘用户名’ @ ‘主机名’ identified by ‘密码’;

修改用户密码

alter user ‘用户名’ @ ‘主机名’ identified with mysql_native_password by ‘新密码’

删除用户

drop user ‘用户名’ @ ‘主机名’

权限控制

了解即可工作中没有权限操作这是DBA的事

总结

标签:comment,01,数据库,MySQL,基础,查询,字段,表名,员工
From: https://blog.csdn.net/2301_81937222/article/details/140934470

相关文章

  • 大模型入门教程(非常详细)从零基础入门到精通,看完这一篇就够了
    人人都看得懂的大模型简介大模型就像一座庞大的图书馆,里面有非常多的书籍。但与普通图书馆不同的是,这座图书馆中的每本书都是关于不同事物的描述和知识。而这些书籍中的每一页都代表了这个事物的一些特征或细节。现在,想象一下,你是一个研究员,你想了解各种各样的话题,比如天气......
  • 数论基础知识(下)
    目录欧拉函数n的分解质因数求欧拉函数试除法求欧拉函数值积性函数筛法朴素筛埃氏筛欧拉筛(线性筛)线性筛欧拉函数快速幂同余欧拉定理费马小定理乘法逆元欧拉函数互质:∀a,b∈N,若gcd(a,b)=1,则a,b互质。定义: :1∼n......
  • Mac开发基础26-NSOpenPanel和NSSavePanel
    NSOpenPanel和NSSavePanel是macOS应用中的两个重要控件,分别用于文件和文件夹的选择(打开)以及文件的保存(保存)。NSOpenPanelNSOpenPanel是用于展示系统的打开文件对话框的类,用户可以通过它来选择文件或文件夹。基本使用Objective-C#import<Cocoa/Cocoa.h>//创建并配置......
  • MySQL——SQL语句
    文章目录什么是SQL?SQL通用语法SQL分类DDL:操作数据库、表3.1操作数据库:CRUD3.2操作表CRUDDML:增删改表中数据1.添加数据:2.删除数据:3.修改数据:DQL:查询表中的记录1.语法:2.基础查询3.条件查询4.排序查询其他函数5.聚合函数6.分组查询7.分页查询:DCL:管理用户,授权1.管理用......
  • Mac开发基础24-NSToolbar
    NSToolbar是macOS应用中的一个重要控件,用于创建窗口顶部的工具栏。工具栏通常包含按钮和其他控件,用户可以通过这些控件快速访问常用功能。NSToolbar和NSToolbarItem协同工作,NSToolbar是工具栏容器,而NSToolbarItem是工具栏项。下面我们详细介绍NSToolbar的常见API和基......
  • Mac开发基础25-NSAlert
    NSAlert是macOS应用中的一个重要控件,用于显示警告与通知对话框。NSAlert允许开发者创建和配置弹出窗口,用于通知用户、确认操作或显示错误信息。基本使用创建和显示简单的警告框Objective-C#import<Cocoa/Cocoa.h>//实例化NSAlertNSAlert*alert=[[NSAlertalloc]......
  • Mac开发基础22-NSTabView
    NSTabView是macOS应用中的一个重要控件,用于创建带有多个选项卡的界面,类似于网页浏览器的选项卡功能。它能够将多个视图容器合并到一个控件中,每个视图容器都可以通过选项卡来切换。基本使用创建和初始化Objective-C#import<Cocoa/Cocoa.h>//创建一个NSTabView实例NST......
  • Mac开发基础23-NSMenu
    NSMenu是macOS应用中的一个重要控件,用于创建应用程序的菜单。这些菜单通常出现在屏幕顶部的菜单栏中,但也可以作为上下文菜单出现。NSMenu和NSMenuItem协同工作,NSMenu是菜单容器,而NSMenuItem是菜单项。本指南将详细介绍NSMenu的常见API和基础技巧。基本使用创建和初......
  • Springboot计算机毕业设计电商订单管理系统(程序+源码+数据库)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表用户,商品分类,商家,商品信息开题报告内容摘要本文旨在设计并实现一个高效、易用的电商订单管理系统,以满足现代电商企业对订单处理、库存控制、物流跟踪及财务......
  • Springboot计算机毕业设计电脑商城购物系统(数据库、调试部署、开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表用户,商品分类,商品品牌,商品信息开题报告内容1.选题背景及意义1.1选题背景随着计算机和网络的普及,电子商务已经成为现代社会不可或缺的一部分。特别是在21......