玩转MySQL(二)SQL基础

超详细的Java知识点路线图


在这里插入图片描述


前言

做数据库开发,要掌握的最基础也是最重要的东西就是SQL语言了,下面我们开始掌握这门语言。


SQL的概述

Structured Query Language 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。
各种主流的数据库系统都对SQL规范作了某些编改和扩充。所以,实际上不同数据库系统之间的SQL不能完全相互通用,但大部分是相同的,后面我们学习的是MySQL的版本,掌握SQL主要语法之后,要迁移到其它数据库也是比较容易的。

SQL的分类

SQL按用途分为:
一、DQL(数据查询语言) 用于查询数据
二、DML(数据操作语言)用于添加、删除、更新数据
三、TPL(事务处理语言)包括事务相关的启动、提交、回滚等操作。
四、DCL(数据控制语言)包含用户、用户组的权限控制
五、DDL(数据定义语言)包括数据库、表、视图、索引等对象的定义和删除操作
六、CCL(游标控制语言)控制数据库的游标操作
我们最常用的应该是DQL、DML和DDL,本章我们主要介绍的是DDL和DML。

MySQL数据库的操作

创建数据库的基本语法是:

create database 数据库名;

还可以给数据库指定默认的字符集以及排序规则:

create database 数据库名
default character set 字符集 collate 排序规则;

选择数据库

use 数据库名;

修改数据库的字符集和排序规则:

alter database 数据库名
default character set  字符集 collate 排序规则;

删除数据库:

drop database 数据库名;

删除时检查数据库是否存在:

drop database if exists 数据库名; 

代码示例:

-- 删除数据库
drop database if exists mydb;
-- 创建数据库
create database mydb
default character set utf8mb4
collate utf8mb4_general_ci;
-- 使用数据库
use mydb;

MySQL常见的数据类型

创建好数据库后,我们就需要建表,建表我们需要设置字段的数据类型,我们先来了解MySQL中常见的数据类型。

  1. 整数类型
    在这里插入图片描述

  2. 小数类型
    在这里插入图片描述

  3. 日期/时间类型
    在这里插入图片描述

  4. 字符串类型
    在这里插入图片描述

  5. 二进制类型
    在这里插入图片描述

表的操作

创建表:

create table 表名
(
字段名 数据类型 [约束],
字段名 数据类型 [约束],
....
)

约束不是必须的,主要的约束类型有:
1、primary key 主键,表中只能有一个,不能重复,不能为空
2、not null 非空,必须填写
3、unique 唯一,不能重复
4、auto_increment 自动增长,必须是整数类型,不需要手动插入
5、foreign key 外键,建立表之间的引用关系

删除表:

drop table 表名;

删除表时进行检查:

drop table if exists 表名;

修改表,添加字段:

alter table 表名 add column 字段名 数据类型;

修改表,删除字段:

alter table 表名 drop column 字段名;

查看表结构:

desc 表名;

代码示例:

-- 删除表
drop table if exists tb_student;
-- 创建学生表
create table tb_student
(
	stu_id int primary key auto_increment,
	stu_name varchar(20) not null,
	stu_age int not null,
	stu_gender varchar(1) not null,
	stu_address varchar(200)
);

数据操作语言DML

数据操作语言有插入、删除和更新语句组成。
单行插入:

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

多行插入

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

将一张表数据插入另一张表

insert into 表1(字段名,字段名,字段名..) 
select 字段名,字段名,字段名 from 表2;

删除所有数据

delete from 表名;

清空表

truncate table 表名;

带条件的删除

delete from 表名 [where 条件];

更新

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

代码示例:

-- 插入一行学生记录
insert into tb_student(stu_name,stu_age,stu_gender,stu_address)
values('赵六',30,'男','上海');
-- 插入多行学生
insert into tb_student(stu_name,stu_age,stu_gender,stu_address)
values('陈七',20,'男','武汉'),('陈大七',28,'男','上海'),('陈小七',18,'男','北京');
-- 删除学号为3的学生
delete from tb_student where stu_id = 3;
-- 全部删除
delete from tb_student;
-- 清空表
truncate table tb_student;
-- 更新陈七的年龄为23,性别为女
update tb_student set stu_age = 23,stu_gender = '女' where stu_name = '陈七';

总结

本章我们学习了SQL语言中的DDL和DML,能实现建表建表和数据的增删改操作,还有一个重要的查询操作,也就是DQL,会在下章介绍。如果内容对你有帮助,麻烦点个赞:)


大家如果需要学习其他Java知识点,戳这里 超详细的Java知识点汇总

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恒哥~Bingo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值