mysql基础
1、SQL的概念
1.1 什么是sql
Structured Query Language结构化查询语言
1.2 SQL语句分类
- Data Definition Language(DDL数据定义语言)如:建库,建表
- Data Manipulation Language(DML数据操纵语言),如:对表中的记录操作增删改
- Data Query Language(DQL数据查询语言),如:对表中的查询操作
- Data Control Language(DCL数据控制语言),如:对用户权限的设置
2.DDL操作数据库
2.1 创建数据库
2.1.1 创建数据库的几种方式
- 创建数据库
CREATE DATABASE数据库名; - 判断数据库是否已经存在,不存在则创建数据库
CREATE DATABASE IF NOT EXISTS数据库名; - 创建数据库并指定字符集
CREATE DATABASE 数据库名 CHARACTER SET 字符集;
2.1.2 具体操作
--直接创建数据库db1
create database db1;
--判断是否存在,如果不存在则创建数据库db2
create database if not exists db2;
--创建数据库并指定字符集为gbk
create database db3 default character set gbk;
2.2 查看数据库
按tab键可以自动补全关键字
--查看所有的数据库
show databases;
--查看某个数据库的定义信息
show create database db3;
show create database db1;
2.3 修改数据库
2.3.1修改数据库默认的字符集
ALTER DATABASE 数据库名 DEFAULT CHARACTER SET 字符集;
2.3.2 具体操作:
将db3数据库的字符集改成utf8
alter database db3 character set utf8;
2.4 删除数据库
2.4.1 删除数据库的语法
DROP DATABASE 数据库名;
2.4.2具体操作:
每行SQL语句需要选中再执行,可以按F9
删除db2数据库
drop database db2;
2.5 使用数据库
2.5.1 查看正在使用的数据库
SELECT DATABASE();
使用的一个mysql中的全局函数
2.5.2 使用/切换数据库
USE 数据库名;
2.5.3 具体操作
--查看正在使用的数据库
select database();
--改变要使用的数据库
use db4;
3、DDL操作表结构
3.1 创建表
3.1.1 创建表的格式
CREATE TABLE 表名(
字段名1 字段类型1,
字段名2 字段类型2
);
3.1.2 关键字说明:
3.2 MySQL数据类型
3.2.1常使用的数据类型如下:
3.2.2 详细的数据类型如下
2.2.3 具体操作:
创建student表包含id,name,birthday字段
create table student(
id int,--整数
name varchar(20),--字符串
birthday date--生日,最后没有逗号
);
3.3查看表
3.3.1查看某个数据库中的所有表
SHOW TABLES;
3.3.2 查看表结构
DESC 表名;
3.3.3 查看创建表的SQL语句
SHOW CREATE TABLE 表名;
3.3.4具体操作:
- 查看day21数据库中的所有表
use day21;
show tables;
- 查看student表的结构
desc student;
- 查看student的创建表SQL语句
show create table student;
3.4快速创建一个表结构相同的表
3.4.1语法
CREATE TABLE 新表名 LIKE 旧表名;
3.4.2具体操作:
- 创建s1表,s1表结构和student表结构相同
--创建一个s1的表与student结构相同
create table s1 like student;
desc s1;
3.5 删除表
3.5.1 直接删除表
DROP TABLE 表名;
3.5.2 判断表是否存在,如果存在则删除表
DROP TABLE IF EXISTS 表名;
3.5.3 具体操作
--直接删除表s1表
drop table s1;
--判断表是否存在并删除s1表
drop table if exists s1;
3.6 修改表结构
3.6.1 添加表列ADD
ALTER TABLE 表名 ADD 列名 类型;
- 为学生表添加一个新的字段remark,类型为varchar(20)
alter table student add remark varchar(20);
3.6.2 修改列类型MODIFY
ALTER TABLE 表名 MODIFY 列名 新的类型;
- 将student表中的remark字段的改成varchar(100)
alter table student modify remark varchar(100);
3.6.3 修改列名CHANGE
ALTER TABLE 表名 CHANGE 旧列名 新列名 类型;
- 将student表中的remark字段名改成intro,类型varchar(30)
alter table student change remark intro varchar(30);
3.6.4 删除列DROP
ALTER TABLE 表名 DROP 列名;
- 删除student表中的字段intro
alter table student drop intro ;
3.6.5 修改表名
RENAME TABLE 表名 TO 新表名;
- 将学生表student改名成student2
rename table student to student2;
3.6.6 修改字符集characterset
ALTER TABLE 表名 character set 字符集;
- 将student2表的编码修改成gbk
alter table student2 character set gbk;
4、DML操作表中的数据
用于对表中的记录进行增删改操作
4.1插入记录
INSERT [INTO] 表名 [字段名] VALUES (字段值)
--INSERT INTO表名:表示往哪张表中添加数据
--(字段名1,字段名2,…):要给哪些字段设置值
--VALUES(值1,值2,…):设置具体的值
8.1.1插入全部字段
- 所有的字段名都写出来
INSERT INTO 表名
(字段名1,字段名2,字段名3…)
VALUES(值1,值2,值3);
- 不写字段名
INSERT INTO 表名 VALUES (值1,值2,值3…);
4.1.2 插入部分数据
INSERT INTO 表名(字段名1,字段名2,...)VALUES(值1,值2,...);
注:没有添加数据的字段会使用NULL
8.1.3具体操作:
- 插入所有的列,向学生表中
insert into student (id,name,age,sex) values (1,'孙悟空',20,'男');
insert into student (id,name,age,sex) values (2,'孙悟天',16,'男');
- 向表中插入所有字段
--插入所有列
insert into student values(3,'孙悟饭',18,'男','龟仙人洞中');
--如果只插入部分列,必须写列名
insert into student values(3,'孙悟饭',18,'男');
4.2 乱码问题的解决
- 当我们使用DOS命令行进行SQL语句操作如有有中文会出现乱码
4.2.1insert的注意事项:
- 插入的数据应与字段的数据类型相同
- 数据的大小应在列的规定范围内,例如:不能将一个长度为80的字符串加入到长度为40的列中。
- 在values中列出的数据位置必须与被加入的列的排列位置相对应。在mysql中可以使用value,但不建议使用,功能与values相同。
- 字符和日期型数据应包含在单引号中。MySQL中也可以使用双引号做为分隔符。
- 不指定列或使用null,表示插入空值。
4.2.2乱码产生的原因
4.2.3查看MySQL内部设置的编码
- 查看包含character开头的全局变量
show variables like 'character%';
4.2.4解决方案
- 修改client、connection、results的编码为GBK,保证和DOS命令行编码保持一致
- 同时设置三项
set names gbk;
注意:退出DOS命令行就失效了,需要每次都配置
4.3 蠕虫复制
4.3.1 什么是蠕虫复制
将一张已经存在的表中的数据复制到另一张表中。
4.3.2 语法格式
- 将表名2中的所有的列复制到表名1中
INSERT INTO 表名1 SELECT * FROM 表名2 ;
- 只复制部分列
INSERT INTO 表名1 (列1,列2) SELECT 列1,列2 FROM student;
4.3.3 具体操作
--创建student2表,student2结构和student表结构一样
drop table student2;
create table student2 like student;
--将student表中的数据添加到student2表中
insert into student2 select * from student;
--如果只想复制student表中name,age字段数据到student2表中,两张表都写出相应的列名
insert into student2 (name,age) select name,age from student;
4.4 更新表记录
UPDATE 表名 SET 列名 = 值 [WHERE 条件表达式]
--UPDATE:需要更新的表名
--SET:修改的列值
--WHERE:符合条件的记录才更新
--你可以同时更新一个或多个字段。
--你可以在WHERE子句中指定任何条件。
4.4.1 不带条件修改数据
UPDATE表名SET字段名=值;--修改所有的行
4.4.2 带条件修改数据
UPDATE 表名 SET 字段名=值 WHERE 字段名=值;
4.4.3 具体操作
--不带条件修改数据,将所有的性别改成女
update student set sex='女';
--带条件修改数据,将id号为2的学生性别改成男
update student set sex='男' where id=2;
--一次修改多个列,把id为3的学生,年龄改成26岁,address改成北京
update student set age=26,address='北京' where id=3;
4.5 删除表记录
DELETE FROM 表名[ WHERE 条件表达式 ]
--如果没有指定WHERE子句,MySQL表中的所有记录将被删除。
--你可以在WHERE子句中指定任何条件
4.5.1 不带条件删除数据
DELETE FROM 表名;
4.5.2 带条件删除数据
DELETE FROM 表名 WHERE 字段名=值;
4.5.3使用truncate删除表中所有记录
TRUNCATE TABLE 表名;
4.5.4 truncate和delete的区别
truncate 相当于删除表的结构,再创建一张表。相当于ddl
delete 只是删除表里面的记录数据,相当于dml
4.5.5 具体操作
--带条件删除数据,删除id为1的记录
delete from student where id=1;
--不带条件删除数据,删除表中的所有数据
delete from student;
5、DQL查询表中的数据
- 查询不会对数据库中的数据进行修改.只是一种显示数据的方式
SELECT 列名 FROM 表名 [WHERE条件表达式]
--SELECT命令可以读取一行或者多行记录。
--你可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据
--你可以使用WHERE语句来包含任何条件。
5.1简单查询
5.1.1查询表所有行和列的数据
- 使用*表示所有列
SELECT * FROM 表名;
- 查询所有的学生:
select * from student;
5.1.2查询指定列
- 查询指定列的数据,多个列之间以逗号分隔
SELECT 字段名1,字段名2,字段名3,...FROM表名;
- 查询student表中的name和age列
select name,age from student;
5.2指定列的别名进行查询
5.2.1使用关键字
- 使用别名的好处:显示的时候使用新的名字,并不修改表的结构。
5.2.2语法:
- 对列指定别名
SELECT 字段名1 AS 别名,字段名2 AS 别名...FROM表名;
- 对列和表同时指定别名
SELECT 字段名1 AS 别名,字段名2 AS 别名...FROM 表名 AS 表别名;
5.3.2 具体操作
--使用别名
select name as 姓名,age as 年龄 from student;
--表使用别名
select st.name as 姓名,age as 年龄from student as st
表使用别名的原因:用于多表查询操作
5.3清除重复值
5.3.1查询指定列并且结果不出现重复数据
SELECT DISTINCT 字段名 FROM 表名;
5.3.2具体操作:
- 查询学生来至于哪些地方
--查询学生来至于哪些地方
select address from student;
--去掉重复的记录
select distinct address from student;
5.4 查询结果参与运算
5.4.1 某列数据和固定值运算
SELECT 列名1 +固定值 FROM 表名;
5.4.2 某列数据和其他列数据参与运算
SELECT 列名1+列名2 FROM 表名;
注意:参与运算的必须是数值类型
5.5条件查询
SELECT 字段名 FROM 表名 WHERE 条件;
- 运算符
- 逻辑运算符
- in关键字
SELECT 字段名 FROM 表名 WHERE 字段 in(数据1,数据2...);
-- in里面的每个数据都会作为一次条件,只要满足条件的就会显示
- 范围查询
BETWEEN 值1 AND 值2
--表示从值1到值2范围,包头又包尾
- like关键字
--LIKE表示模糊查询
SELECT * FROM 表名 WHERE 字段名 LIKE '通配符字符串';
- MySQL通配符