MySQL学习笔记

目录

注释

单行注释:#注释文字(没空格)

单行注释:-- 注释文字(有空格)

多行注释:/* 注释文字 */,注意不能够嵌套注释;

1、启动和关闭MYSQL服务

sql 复制代码
net stop mysql
net start mysql

2、库的增删改查

sql 复制代码
-- 查看所有库
show databases;
-- 查看某个库
show create database school_info;
-- 创建库
create database school_info;
-- 创建库指定编码
create database school_info charset utf8;
-- 修改库编码
alter database school_info charset gbk;
-- 删除库
drop database school_info;

3、表的增删改查

3.1 创建表

复制代码
create table 表名(

	列名 列类型,
	列名 列类型,
	。。。
);
sql 复制代码
create table stu(name char(10) not null,sex char(1) not null,age int);

3.2 修改表

sql 复制代码
-- 修改表字段 数据类型 约束条件
alter table stu change name name1 varchar(10) not null;
-- 新增表字段
alter table stu add addr char(20),add addr2 char(20);
-- 指定位置新增
alter table stu add id  int first;
alter table stu add addr3 varchar(10) after name;

3.3 删除

sql 复制代码
-- 删除表字段
alter table stu drop addr2;
-- 删除表
drop table stu;

4、数据类型

4.1 字符串:char(num) 与 varchar(num)的区别

字符串 长度 存储
char 定长 直接存储字符内容
varchar 变长 开头由1-2个字节存储该字符的总长度,后面接着存储字符内容

例如你定义了char(8),则这一列中存储的内容长度都为8,不足8则会用空格补充(但是我们在查询的时候是不会带空格的,mysql会对此进行处理)

总结:

  • char的存取速度很快,但是由于是定长,当大部分内容没有达到规定长度时,会浪费不少空间资源
  • varchar则不会,它根据实际长度存储,但是由于存储的特殊形式造成存取速度不及char,当char存储的内容都为一个定值时,则char不仅不浪费空间还提高存取效果,因为varchar还要留出一部分存储字符串的长度;
  • 很早之前,大家都觉得varchar好,节省资源,但是到现在,磁盘资源已经不成问题,因此我更倾向于选择char,也就是所谓的以空间换时间了。

4.2 整型

int 不需要指定字符的长度

4.3 浮点型

  • decimal double
  • float(m,n) 单精度
  • double(m,n) 双精度
  • decimal(m,n)小数值

例如:float(5,2) 代表的意思是:小数位2,整数位3位的数值,总长度为5位。

sql 复制代码
CREATE TABLE stu_info (
	NAME CHAR ( 8 ) NOT NULL,
	score1 FLOAT ( 5, 2 ),
	score2 DOUBLE ( 5, 2 ),
  score3 DECIMAL ( 5, 2 ));
	
INSERT INTO stu_info
VALUES
	( "李四", 45.3456, 45.3456, 45.3456 );

SELECT * FROM stu_info;
sql 复制代码
-- 使用默认值
create table stu_info1(name char(8) not null,score1 float,score2 double,score3 decimal);
insert into stu_info1 values("张三",80.1234567,80.1234567,80.1234567);
select * from stu_info1;
  • double默认比float更精确 浮点型
  • decimal默认存储的是decimal(10,0) 实际是字符串类型
  • 日常使用float就可以解决大部分的问题了

4.4 日期型

sql 复制代码
CREATE TABLE stu_info3 ( ruxue date, kaixue datetime );

INSERT INTO stu_info3
VALUES
	( "2020-12-01 12:00:34", "2020-12-01 12:00:34" );
	
SELECT * FROM stu_info3;

4.5 枚举型

  • enum 只能单选,例如:男女
  • set 单选或多选,例如:兴趣爱好
sql 复制代码
CREATE TABLE stu_info4 (
	sex enum ( "男", "女" ),
	hobby SET ( "运动", "阅读", "旅行" ));

INSERT INTO stu_info4
VALUES
	( "男", "运动,旅行" ),
	("女","运动" );

select * from stu_info4;
相关推荐
码熔burning1 小时前
MySQL 8.0 新特性爆笑盘点:从青铜到王者的骚操作都在这儿了!(万字详解,建议收藏)
数据库·mysql
猫头虎1 小时前
2025最新OpenEuler系统安装MySQL的详细教程
linux·服务器·数据库·sql·mysql·macos·openeuler
气概3 小时前
法奥机器人学习使用
学习·junit·机器人
Qhumaing3 小时前
C++学习:【PTA】数据结构 7-1 实验7-1(最小生成树-Prim算法)
c++·学习·算法
好大哥呀3 小时前
Java Web的学习路径
java·前端·学习
梦雨羊5 小时前
Base-NLP学习
人工智能·学习·自然语言处理
丝斯20115 小时前
AI学习笔记整理(42)——NLP之大规模预训练模型Transformer
人工智能·笔记·学习
小猪佩奇TONY6 小时前
Linux 内核学习(14) --- linux x86-32 虚拟地址空间
linux·学习
副露のmagic6 小时前
更弱智的算法学习 day28
学习
ha20428941946 小时前
Linux操作系统学习记录之---TcpSocket
linux·网络·c++·学习