MySQL基础入门上篇

这篇具有很好参考价值的文章主要介绍了MySQL基础入门上篇。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

MySQL基础

介绍

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

mysql -uroot -p -h127.0.0.1 -P3306

MySQL基础入门上篇,开发,mysql,数据库


项目设计

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
具备数据库一定的设计能力和操作数据的能力。

数据库设计DDL

定义

MySQL基础入门上篇,开发,mysql,数据库

操作

显示所有数据库

show databases;

创建数据库
create database db02;

数据库名唯一,不能重复。
MySQL基础入门上篇,开发,mysql,数据库
查询是否创建成功
MySQL基础入门上篇,开发,mysql,数据库

加入一些判断语句

create database if not exists db02;

存在不会报错,也会不再创建,如果不存就会创建
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库


连接数据库
use db01;

MySQL基础入门上篇,开发,mysql,数据库

删除数据库

drop database db03;

MySQL基础入门上篇,开发,mysql,数据库

这里可以加入条件判断

drop database if exists db03;

小结

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

图形化DDL

MySQL基础入门上篇,开发,mysql,数据库
这边直接使用idea也可以图形化操作

表结构设计

操作

创建
MySQL基础入门上篇,开发,mysql,数据库

-- 创建表结构
create table tb_user(
  id int comment 'ID, 唯一标识',
  username varchar(20) comment '用户名',
  name varchar(10) comment '姓名',
  age int comment '年龄',
  gender char(1) comment '性别'
) comment '用户表'

ps:comment 为备注的意思

MySQL基础入门上篇,开发,mysql,数据库

MySQL基础入门上篇,开发,mysql,数据库

也可以通过idea手动添加

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

约束
定义表结构的时候需要一些约束
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

-- 创建表结构
create table tb_user(
    id int primary key auto_increment comment 'ID, 唯一标识',
    username varchar(20) unique not null comment '用户名',
    name varchar(10) not null comment '姓名',
    age int comment '年龄',
    gender char(1) default '男' comment '性别'
) comment '用户表';

MySQL基础入门上篇,开发,mysql,数据库

实现:
MySQL基础入门上篇,开发,mysql,数据库

案例

图形化操作
MySQL基础入门上篇,开发,mysql,数据库
新建列
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

create table tb_emp (
  id int unsigned primary key auto_increment comment 'ID',
  username varchar(20) not null unique comment '用户名',
  password varchar(32) default '123456' comment '密码',
  name varchar(10) not null comment '姓名',
  gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',
  image varchar(300) comment '图像',
  job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',
  entrydate date comment '入职时间',
  create_time datetime not null comment '创建时间',
  update_time datetime not null comment '修改时间'
) comment '员工表';

表操作(DLL)

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

操作

查表结构和表名
-- 查询表
show tables;

-- 查看指定表结构
desc tb_emp;

-- 查询创建表结构
show create table tb_emp;

查看表
MySQL基础入门上篇,开发,mysql,数据库

查询表结构
MySQL基础入门上篇,开发,mysql,数据库

查看表的建表语句
MySQL基础入门上篇,开发,mysql,数据库

修改表结构

MySQL基础入门上篇,开发,mysql,数据库

-- DDL: 修改表结构
-- 修改:为表添加qq 字段 varchar(11)
alter table tb_emp add qq varchar(11) comment 'QQ字段';

alter table tb_emp modify qq varchar(13) comment 'QQ字段';

alter table tb_emp change qq qq_num varchar(13) comment 'QQ字段';

-- 修改:删除tb_emp 的qq_num字段
alter table tb_emp drop column qq_num;

-- 修改:将tb_emp表名修改为emp
rename table tb_emp to emp;

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
可以用图形化工具进行操作
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

删除表

MySQL基础入门上篇,开发,mysql,数据库

drop table if exists tb_test;

插入测试数据

-- 插入数据
-- 因为设计表时create_time, update_time两个字段不能为NULL,所以也做为要插入的字段
insert into tb_emp(username, name, gender, create_time, update_time)
values ('wuji', '张无忌', 1, now(), now());
insert into tb_emp(id, username, password, name, gender, image, job, entrydate, create_time, update_time)
values (null, 'zhirou', '123', '周芷若', 2, '1.jpg', 1, '2010-01-01', now(), now());
insert into tb_emp(username, name, gender, create_time, update_time)
values ('weifuwang', '韦一笑', 1, now(), now()),
       ('fengzi', '张三疯', 1, now(), now());

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

DML(UPDATE,更新数据)

MySQL基础入门上篇,开发,mysql,数据库

update tb_emp set name='张三',update_time=now() where id=1;

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

-- 修改全部的数据,update_time=now()为当前时间
update tb_emp set entrydate='2010-01-01',update_time=now();

MySQL基础入门上篇,开发,mysql,数据库

DML(DELETE)

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

-- 语法
-- delete from 表名  [where  条件] ;

-- 删除tb_emp表中id为1的员工
delete from tb_emp where id=1;

-- 删除tb_emp表中所有员工
delete from tb_emp;


MySQL基础入门上篇,开发,mysql,数据库

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

小结

MySQL基础入门上篇,开发,mysql,数据库

查询(DQL)

定义

MySQL基础入门上篇,开发,mysql,数据库

语法

MySQL基础入门上篇,开发,mysql,数据库

插入测试数据

-- 创建数据
create database db02;


-- 添加测数据
-- 员工管理(带约束)
create table tb_emp (
                        id int unsigned primary key auto_increment comment 'ID',
                        username varchar(20) not null unique comment '用户名',
                        password varchar(32) default '123456' comment '密码',
                        name varchar(10) not null comment '姓名',
                        gender tinyint unsigned not null comment '性别, 说明: 1 男, 2 女',
                        image varchar(300) comment '图像',
                        job tinyint unsigned comment '职位, 说明: 1 班主任,2 讲师, 3 学工主管, 4 教研主管',
                        entrydate date comment '入职时间',
                        create_time datetime not null comment '创建时间',
                        update_time datetime not null comment '修改时间'
) comment '员工表';

-- 准备测试数据
INSERT INTO tb_emp (id, username, password, name, gender, image, job, entrydate, create_time, update_time) VALUES
                                                                                                               (1, 'jinyong', '123456', '金庸', 1, '1.jpg', 4, '2000-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:35'),
                                                                                                               (2, 'zhangwuji', '123456', '张无忌', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:37'),
                                                                                                               (3, 'yangxiao', '123456', '杨逍', 1, '3.jpg', 2, '2008-05-01', '2022-10-27 16:35:33', '2022-10-27 16:35:39'),
                                                                                                               (4, 'weiyixiao', '123456', '韦一笑', 1, '4.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:35:41'),
                                                                                                               (5, 'changyuchun', '123456', '常遇春', 1, '5.jpg', 2, '2012-12-05', '2022-10-27 16:35:33', '2022-10-27 16:35:43'),
                                                                                                               (6, 'xiaozhao', '123456', '小昭', 2, '6.jpg', 3, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:45'),
                                                                                                               (7, 'jixiaofu', '123456', '纪晓芙', 2, '7.jpg', 1, '2005-08-01', '2022-10-27 16:35:33', '2022-10-27 16:35:47'),
                                                                                                               (8, 'zhouzhiruo', '123456', '周芷若', 2, '8.jpg', 1, '2014-11-09', '2022-10-27 16:35:33', '2022-10-27 16:35:49'),
                                                                                                               (9, 'dingminjun', '123456', '丁敏君', 2, '9.jpg', 1, '2011-03-11', '2022-10-27 16:35:33', '2022-10-27 16:35:51'),
                                                                                                               (10, 'zhaomin', '123456', '赵敏', 2, '10.jpg', 1, '2013-09-05', '2022-10-27 16:35:33', '2022-10-27 16:35:53'),
                                                                                                               (11, 'luzhangke', '123456', '鹿杖客', 1, '11.jpg', 2, '2007-02-01', '2022-10-27 16:35:33', '2022-10-27 16:35:55'),
                                                                                                               (12, 'hebiweng', '123456', '鹤笔翁', 1, '12.jpg', 2, '2008-08-18', '2022-10-27 16:35:33', '2022-10-27 16:35:57'),
                                                                                                               (13, 'fangdongbai', '123456', '方东白', 1, '13.jpg', 1, '2012-11-01', '2022-10-27 16:35:33', '2022-10-27 16:35:59'),
                                                                                                               (14, 'zhangsanfeng', '123456', '张三丰', 1, '14.jpg', 2, '2002-08-01', '2022-10-27 16:35:33', '2022-10-27 16:36:01'),
                                                                                                               (15, 'yulianzhou', '123456', '俞莲舟', 1, '15.jpg', 2, '2011-05-01', '2022-10-27 16:35:33', '2022-10-27 16:36:03'),
                                                                                                               (16, 'songyuanqiao', '123456', '宋远桥', 1, '16.jpg', 2, '2010-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:05'),
                                                                                                               (17, 'chenyouliang', '12345678', '陈友谅', 1, '17.jpg', null, '2015-03-21', '2022-10-27 16:35:33', '2022-10-27 16:36:07'),
                                                                                                               (18, 'zhang1', '123456', '张一', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:09'),
                                                                                                               (19, 'zhang2', '123456', '张二', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:11'),
                                                                                                               (20, 'zhang3', '123456', '张三', 1, '2.jpg', 2, '2018-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:13'),
                                                                                                               (21, 'zhang4', '123456', '张四', 1, '2.jpg', 2, '2015-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:15'),
                                                                                                               (22, 'zhang5', '123456', '张五', 1, '2.jpg', 2, '2016-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:17'),
                                                                                                               (23, 'zhang6', '123456', '张六', 1, '2.jpg', 2, '2012-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:19'),
                                                                                                               (24, 'zhang7', '123456', '张七', 1, '2.jpg', 2, '2006-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:21'),
                                                                                                               (25, 'zhang8', '123456', '张八', 1, '2.jpg', 2, '2002-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:23'),
                                                                                                               (26, 'zhang9', '123456', '张九', 1, '2.jpg', 2, '2011-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:25'),
                                                                                                               (27, 'zhang10', '123456', '张十', 1, '2.jpg', 2, '2004-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:27'),
                                                                                                               (28, 'zhang11', '123456', '张十一', 1, '2.jpg', 2, '2007-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:29'),
                                                                                                               (29, 'zhang12', '123456', '张十二', 1, '2.jpg', 2, '2020-01-01', '2022-10-27 16:35:33', '2022-10-27 16:36:31');

基本查询语法

MySQL基础入门上篇,开发,mysql,数据库

-- DQL 查询
-- 1.查询指定字段 name,entrydate 并返回
select name,entrydate from tb_emp;

-- 2,查询返回所有字段
-- 不推荐(不直观,性能低)
select * from tb_emp;

-- 推荐
select id, username, password, name, gender, image, job, entrydate, create_time, update_time from tb_emp;

-- 3,查询所有员工的name,entrydate,并起别名(姓名、入职日期)
select name as "姓 名",entrydate as '入职   日期' from tb_emp;
select name  姓名,entrydate  入职日期 from tb_emp;

-- 4,查询已有的员工关联了那几种职位(不要重复)
select job from tb_emp;
select distinct job  from  tb_emp;


MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

条件查询

MySQL基础入门上篇,开发,mysql,数据库

-- 条件查询
-- 案例1:查询 姓名 为 杨逍 的员工
select * from tb_emp where name = '杨逍';

-- 案例2:查询 id小于等于5 的员工信息
select * from tb_emp where id <= 5;

-- 案例3:查询 没有分配职位 的员工信息
select * from tb_emp where job is null;

-- 案例4:查询 有职位 的员工信息
select * from tb_emp where  job is not null;

-- 案例5:查询 密码不等于 '123456' 的员工信息
select * from tb_emp where password != '123456';

-- 案例6:查询 入职日期 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间的员工信息
select * from tb_emp where entrydate between '2000-01-01' and   '2010-01-01';
select * from tb_emp where entrydate >= '2000-01-01' and entrydate <= '2010-01-01';


-- 案例7:查询 入职时间 在 '2000-01-01' (包含) 到 '2010-01-01'(包含) 之间 且 性别为女 的员工信息
select *
from tb_emp where entrydate between '2000-01-01' and '2010-01-01' and gender = 2;

-- 案例8:查询 职位是 2 (讲师), 3 (学工主管), 4 (教研主管) 的员工信息
select id, username, password, name, gender, image, job, entrydate, create_time, update_time from tb_emp where job = 2 || job = 3 || job =4 ;
select *
from tb_emp where job in(2,3,4);
-- 案例9:查询 姓名 为两个字的员工信息
select *
from tb_emp where name like '__';

-- 案例10:查询 姓 '张' 的员工信息
select *
from tb_emp where name like '张%';


MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

分组查询

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

-- 分组查询,常见的聚合函数

-- 案例1:统计该企业员工数量聚合函数
select count(username) from tb_emp;
select count(id) from tb_emp;
select count(job) from tb_emp;

-- count 参量
select count('a') from tb_emp;

-- count(*)  --推荐使用count(*)
select count(*) from tb_emp;

-- 案例2:统计该企业最早入职的员工
select min(entrydate) from tb_emp;

-- 案例3:统计该企业最迟入职的员工
select max(entrydate) from tb_emp;

-- 案例4:统计该企业员工 ID 的平均值
select avg(id) from tb_emp;

-- 案例5:统计该企业员工的 ID 之和
select sum(id) from tb_emp;

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

分组查询小结

MySQL基础入门上篇,开发,mysql,数据库

分页查询

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

排序查询

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

-- 排序查询
-- 案例1:根据入职时间, 对员工进行升序排序
select * from tb_emp order by entrydate ASC;

-- 案例2:根据入职时间,对员工进行降序排序
select * from tb_emp order by entrydate DESC;

-- 案例3:根据入职时间对公司的员工进行升序排序,入职时间相同,再按照更新时间进行降序排序
select * from tb_emp order by entrydate ASC , update_time DESC;


MySQL基础入门上篇,开发,mysql,数据库

综合案例

案例一

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库

select * from tb_emp where name like '张%' and gender = 1 and entrydate between '2000-01-01' and '2015-12-31' order by update_time desc limit 0,10;

MySQL基础入门上篇,开发,mysql,数据库

ctrl+alt+L 可以将一句变短
MySQL基础入门上篇,开发,mysql,数据库

案例二

MySQL基础入门上篇,开发,mysql,数据库

-- 完成员工性别统计
-- if(条件表达式, true取值, false取值)
select if(gender = 1, '男性员工' ,'女性员工') AS '性别',count(*) from tb_emp group by gender;

-- AS可以省略
select if(gender = 1, '男性员工' ,'女性员工') '性别',count(*) '数量' from tb_emp group by gender;

MySQL基础入门上篇,开发,mysql,数据库

select case job
           when 1 then '班主任'
           when 2 then '讲师'
           when 3 then '学工主管'
           when 4 then '教研主管'
           else '未分配职位' end, count(*)
from tb_emp
group by job;

MySQL基础入门上篇,开发,mysql,数据库
MySQL基础入门上篇,开发,mysql,数据库文章来源地址https://www.toymoban.com/news/detail-852100.html

参考文章

https://www.bilibili.com/video/BV1m84y1w7Tb

到了这里,关于MySQL基础入门上篇的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Mysql数据库从0到1】-入门基础篇--用户与权限管理

    Mysql 用户分为root用户和普通用户,其中root用户是数据库超级管理员,拥有所有权限(创建、删除、修改密码、授权等管理权限),普通用户只拥有被授予的权限。 Mysql数据库的安全性通过账户管理来保障。 1.1 🍃 Mysql服务器登录 🍀 简单使用 🍀 复杂使用 1.2 🍃 用户创建

    2024年02月07日
    浏览(54)
  • 【JAVA】Eclipse+MYSQL数据库+JSP+基础Servlet开发JavaWeb学生信息管理系统

    目录 前言 一、搭建环境  二、功能实现、 1、   登陆界面 注册按钮 2、学生信息管理系统主界面 3、dao包  4、用户的信息展示,添加,删除,修改功能(只展示添加代码) 5、学生的信息展示,添加,删除,修改功能(只展示添加代码) 6、成绩的信息展示,添加,删除,修

    2024年02月05日
    浏览(46)
  • 【MySQL】 MySQL数据库基础

    🎄本节目标: 🚩数据库的操作:创建数据库、删除数据库 🚩常用数据类型 🚩表的操作:创建表、删除表 SHOW DATABASES; 使用如下: 🎈语法: 🎈语法说明 大写的表示 [] 是可选项 CHARACTER SET: 指定数据库采用的字符集 COLLATE: 指定数据库字符集的校验规则 🎈示例: 🛫

    2024年02月08日
    浏览(41)
  • MySQL数据库基础之MySQL查询基础

    从今天开始,本系列内容就带各位小伙伴学习数据库技术 。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。 非常适合零基础的小伙伴来学习。 全文大约【 1212】 字,不说废话,只讲可以让你学到技术、

    2024年02月06日
    浏览(41)
  • MYSQL数据库基础(数据库)

    用户在客户端输入SQL语句 客户端会把SQL通过网络发送给服务器 服务器会执行这个SQL,把结果返回给客户端 客户端接收到结果后,显示到界面上 1.创建数据库 1.1 语法 1.2 解析 已经有了数据库,为何还要创建 计算机中,不同的词有不同的含义,如一门学科、一类软件、某个具

    2024年02月07日
    浏览(40)
  • MySQL基础入门上篇

    具备数据库一定的设计能力和操作数据的能力。 数据库设计DDL 定义 操作 显示所有数据库 创建数据库 数据库名唯一,不能重复。 查询是否创建成功 加入一些判断语句 存在不会报错,也会不再创建,如果不存就会创建 连接数据库 删除数据库 这里可以加入条件判断 小结 图

    2024年04月15日
    浏览(16)
  • MySQL入门:如何创建数据库?

    本文详细概述了如何使用不同的方法和工具(包括用于MySQL的命令行,工作台和dbForge Studio)在MySQL中创建数据库。 MySQL是基于SQL的关系数据库管理系统。它是由Oracle Corporation开发,分发和支持的。MySQL是免费的开源软件,由于其可靠性,兼容性,成本效益和全面的支持,它正

    2024年02月03日
    浏览(39)
  • MySQL - 第1节 - MySQL数据库基础

    目录 1.数据库的概念 2.主流数据库 3.基本使用 3.1.连接服务器 3.2.服务器管理 3.3.数据库服务器,数据库,表关系 3.4.使用案例 3.4.1.数据存储路径 3.4.2.创建/删除数据库 3.4.3.使用数据库 3.4.4.创建数据库表 3.4.5.表中插入数据 3.4.6.查询表中的数据 3.5.数据逻辑存储 4.MySQL架构 5.SQ

    2024年02月09日
    浏览(41)
  • 数据库MySQL基础

     相关概念 版本       数值型   字符型   日期型        SQL语句可以单行或多行书写,以分号结尾。 SQL语句可以使用空格/缩进来增强语句的可读性。 MySQL数据库的SQL语句不区分大小写,建议使用大写。 注释: 单行注释:--注释内容或#注释内容(MySQL特有) 多行注释:/*注

    2024年02月13日
    浏览(30)
  • 【MySQL】数据库基础

    存储数据用文件就可以了,为什么还要弄个数据库呢? 文件保存数据有以下几个缺点: 文件的安全性问题 文件不利于数据查询和管理 文件不利于存储海量数据 文件在程序中控制不方便 数据库存储介质: 磁盘 内存 为了解决上述问题,专家们设计出更加利于管理数据的东西—

    2024年02月02日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包