本文主要是介绍玩转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中常见的数据类型。
-
整数类型
-
小数类型
-
日期/时间类型
-
字符串类型
-
二进制类型
表的操作
创建表:
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知识点汇总
这篇关于玩转MySQL(二)SQL基础的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!