MySQL

一.什么是数据库

数据库:(DB,DataBase)

概念:数据仓库,软件,安装在操作系统之(windows,Linux。mac)上的!SQL,可以存储大量的数据,500万!

作用:存储数据,管理数据 Excel

1.数据库分类

关系型数据库:(SQL)

​ MySQL, Oracle, sql Server, DB2, SQLite

​ 通过表和表之间,行和列之间的关系进行数据的存储

非关系型数据库:(NoSQL) Not Only SQL

​ Redis, MongDB

​ 非关系型数据库,对象存储,通过对象自身的属性来决定。
**DBMS(数据库管理系统) **

​ 数据库的管理软件,科学有效的管理我们的数据,维护和获取

​ MySQL ,数据管理系统!

2.链接数据库

命令行连接!

mysql -u root -p123456 --连接数据库

update mysql.user set authentication_string=password('123456') where user='root' and Host='localhost';  --修改密码

flush privileges;--刷新权限
--------------------------------------------------
--所有语句使用;结尾--

show databases;--查看所有的数据库

mysql> use school--切换数据库, use 数据库名
Database changed

--

show tables;--查看数据库中所有的表
describe student;--显示数据库中所有的表的信息
create database westos;--创建一个数据库

exit;--退出连接

--单行注释(sql本来注释)
/*
多行注释
*/

二.操作数据库

操作数据库》操作数据库中的表》操作数据库中表的数据

1操作数据库

1.创建数据库

CREATE DATABASE IF NOT EXISTS westos;

2.删除数据库

DROP DATABASE IF EXISTS westos

3.使用数据库

-- ``,如果你的表名或者字段名是一个特殊字符,需要带``

USE 'school'

4.产看数据库

SHOW DATABASES--查看所有数据库
2.数据库列类型

1.数值

​ tinyint 十分小的数据 1个字节

​ smallint 较小的数据 2个字节

​ mediumint 中等大小 3个字节

​ int 标准的整数 4个字节(常用)

​ bigint 较大的数据 8个字节

​ float 浮点数 4个字节

​ double 浮点数 8个字节 (精度问题)

​ decimal 字符串形式的浮点数,金融计算的时候,一般用字符串

2.字符串

​ char 字符串固定大小 0-255

varchar 可变字符串 0-65535(常用)

​ tinytext 微型文本 2^8-1

text 文本串 2^16-1 (保存大文本)

3.时间与日期

​ java.util.Date

​ date YYYY-MM-DD,日期

​ time HH:mm:ss 时间格式

datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式

​ timestamp 时间戳 1970.1.1到现在的毫秒数

​ year 年份表示

4.null

​ 没有值,未知

注意,不要使用null进行运算,结果为null

3.数据库的字段类型(重点)

unsigened:

​ 无符号的整数

​ 声明该列不能声明负数

zerofill:

​ 0填充的

​ 10的长度 1 – 0000000001 不足位数用0 填充

自增:

​ 通常理解为自增,自动在上一条记录的基础上+1

​ 通常用来设计唯一的主键 index,必须是整数类似

​ 可以自定义设置主键自增的起始值和步长

非空 NULL not Null

​ 假设设置为 not null,如何不给他赋值,就会报错

​ NULL 如果不填写,默认为NULL

默认:

​ 设置默认的值!

4.创建数据库表
--目标:创建一个schoo1数据库

--创建学生表(列,字段)使用SQL 创建

--学号int 登录密码varchar(20)姓名,性别varchar(2),出生日期(datatime),家庭住址,emai1--注意点,使用英文(),表的名称和字段尽量使用括起来

-- AUTO_ INCREMENT 自增

--字符串使用单引号括起来!

--所有的语句后面加,(英文的),最后一个不用加

-- PRIMARY KEY 主键,一般- 一个表只有一个唯一 -的主键!
CREATE DATABASE school
CREATE TABLE IF NOT EXISTS `student` (
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` VARCHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8

格式

CREATE TABLE [IF NOT EXISTS] `表名``字段名` 列类型[属性][索引][注释],
`字段名` 列类型[属性][索引][注释],
...
`字段名` 列类型[属性][索引][注释][表类型][表的字符集设置][注释]

常用命令

SHOW CREATE DATABASE school -- 查看创建数据库的语句
SHOW CREATE TABLE student -- 查看student数据表的定义语句
DESC student -- 显示表的结构

5.数据库表的类型
-- 关于数据库引擎
/*
INNODB 默认使用
MYISAM 早些年使用


*/

MYISAM INNODB
事务支持 不支持 支持
数据行锁定 不支持 支持
外键约束 不支持 支持
全文索引 支持 不支持
表空间的大小 较小 较大,约为MYISAM的两倍

常规使用操作:

​ MYISAM 节约空间,速度较快,

​ INNODB 安全性高,事务处理,多表多用户操作

在物理空间存在的位置

​ 所有的数据库文件都存在data目录下,一个文件夹就对应一个数据库

​ 本质还是文件的存储

MySQL 引擎在物理文件上的区别

​ innoDB 在数据库表中,只有一个*.frm文件,以及上级目录下的ibdata1文件

​ MYISAM 对应的文件

​ *.frm - 表结构的定义文件

​ *. MYD -数据文件

​ *.MYI 索引文件设置数据库字符集编码

设置数据库字符编码

CHARTSET=UTF8

不设置的话,会是mysql默认的字符集编码-(不支持中文)

可以在my.ini中配置默认的编码

character-set-server=utf8
6.修改删除表

修改

-- 修改表名 ALTER TABLE 旧表面 AS 新表名
ALTER TABLE student RENAME  AS student1
-- 增加表的字段 ALTER TABLE 表名 ADD 字段名 列属性
ALTER TABLE student1 ADD age INT(11)
-- 修改表的字段(重命名,修改约束)
ALTER TABLE student1 MODIFY age VARCHAR(11)  -- 修改约束
ALTER TABLE student1 CHANGE age age1 INT(1)  -- 字段重命名

-- 删除表的字段
ALTER TABLE student1 DROP age1


删除

-- 删除表
DROP TABLE IF EXISTS student1

所有的创建和删除操作尽量加上判断,以免报错

注意点:

  • `` 字段名,使用这个包裹
  • 注释 – /**/
  • sql 关键字大小写不敏感,建议写小写
  • 所有的符号全部用英文

三.MySQL数据管理

1.外键

方式一:在创建表的时候,增加约束(麻烦,比较复杂)

CREATE TABLE `grade`(
`gradeid` INT(10) NOT NULL AUTO_INCREMENT COMMENT '年级id',
`gradename` VARCHAR(50) NOT NULL COMMENT '年级名称',
PRIMARY KEY (`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8

-- 学生表的 gradeid 字段 要去引用年级表的gradeid
-- 定义外键KEY
-- 给这个外键添加约束(执行引用) references 引用
CREATE TABLE IF NOT EXISTS `student` (
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` VARCHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
`gradeid` INT(10) NOT NULL COMMENT '学生年级',
`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`),
KEY `FK_gardeid` (`gradeid`),
CONSTRAINT `FK_gardeid` FOREIGN KEY (`gradeid`) REFERENCES `grade` (gradeid)
)ENGINE=INNODB DEFAULT CHARSET=utf8

删除有外键关系的表的时候,必须先删除引用的表(从表),再删除被引用的表(主表)

方式二: 创建表成功后添加外键

CREATE TABLE `grade`(
`gradeid` INT(10) NOT NULL AUTO_INCREMENT COMMENT '年级id',
`gradename` VARCHAR(50) NOT NULL COMMENT '年级名称',
PRIMARY KEY (`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8

-- 学生表的 gradeid 字段 要去引用年级表的gradeid
-- 定义外键KEY
-- 给这个外键添加约束(执行引用) references 引用
CREATE TABLE IF NOT EXISTS `student` (
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` VARCHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
`gradeid` INT(10) NOT NULL COMMENT '学生年级',
`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)

)ENGINE=INNODB DEFAULT CHARSET=utf8

-- 创建表的时候没有外键关系
ALTER TABLE `student`
ADD CONSTRAINT `FK_gradeid` FOREIGN KEY (`gradeid`) REFERENCES `grade`(`gradeid`);

-- ALTER TABLE`表`  ADD CONSTRAINT 约束名 FOREIGN KEY(作为外键的列) 引用到哪个表的哪个字段

2.DML语言(全记住)

数据库意义:数据存储,数据管理

DML语言:数据操作语言

  • Insert
  • update
  • delete
3.添加

insert

-- 插入语句(添加)
-- nsert into 表名([字段一], [字段二])values('值1'),('值2')

INSERT INTO `grade` (`gradename`) VALUES('大四')

-- 由于主键自增我们可以省略(如何不写表的字段,他会一一匹配)
INSERT INTO `grade` VALUES('大三')
INSERT INTO `grade` (`gradeid`,`gradename`) VALUES ('大三','null')

-- 一般写插入语句,我们一定要数据和字段一一对应。
-- 插入多个字段
INSERT INTO `grade`(`gradename`) VALUES ('大二'),('大一');


INSERT INTO `student`(`name`) VALUES ('张三')

INSERT INTO `student`(`name`,`pwd`,`sex`) VALUES ('张三','aaaaa','男')
INSERT INTO `student`(`name`,`pwd`,`sex`) 
VALUES ('李四','aaaaa','男'),('王五','23232','女')


语法:-- insert into 表名([字段一], [字段二])values(‘值1’),(‘值2’)

注意事项:

1.字段和字段之间用逗号分开

2.字段可以省略,但是后面的值必须一一对应

3.可以同时插入多条数据,VALUES后面的值需要使用,隔开即可

INSERT INTO `student`(`name`,`pwd`,`sex`) 
VALUES ('李四','aaaaa','男'),('王五','23232','女')


4.修改

update 修改谁(条件) set 原来的值=新值

-- 修改学员名字

UPDATE `student` SET `name`='囷' WHERE id =1;
-- 不指定条件的情况下,会改动所有表
UPDATE `student` SET `name`='233'

-- 语法;
-- UPDATE 表名 set column_name,[] = value where 条件


条件:where 子句 运算符 id 等于 某个值,大于某个值,在某个区间内修改

操作符返回布尔值

操作符 含义 范围 结果
= 等于 5=6 false
!= 或<> 不等于 5!=6 t
> 大于
< 小于
>= 大于等于
<= 小于等于
between …and… 在某个范围内,闭合区间
and && 5>1and1>2 f
or || 5>1or1>2 t

注意:

column_name 是数据库的列,带上``

条件,是筛选的条件,如果没有指定,则会修改所有的列

value 是一个具体的值,也可以是一个变量

多个设置的属性之间,使用英文逗号隔开

 UPDATE `student` SET `birthday`=CURRENT_TIME where `name`='李四' AND SEX = '男'
5.删除

delete 命令

语法 delete from 表名 [where 条件]

-- 删除数据 (避免这样写)
DELETE FROM `student`


-- 删除指定
DELETE FROM `student` where id= 1


TRUNCATE 命令

作用:完全清空一个数据库,表的结构和索引不会变

delete 和 TRUNCATE 区别

  • 相同点: 都能删除数据,都不会删除表结构
  • 不同:
    • TRUNCATE 重新设置自增列 计数器会归零
    • TRUNCATE 不会影响事务
-- 测试delete 和 truncate 区别

CREATE TABLE `test`(
`id` INT(4) NOT NULL AUTO_INCREMENT,
`coll` VARCHAR(20) NOT NULL,
PRIMARY KEY (`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8

INSERT INTO `test`(`coll`) VALUES('1'),('2'),('3')

DELETE FROM `test` -- 不会影响自增

TRUNCATE TABLE `test` -- 自增会归零


了解即可:delete删除的问题 重启数据库,现象

  • innoDB 自增列会从1开始(存在内存当中,断电即失)
  • MyISAM 继续从上一个自增量开始(存在文件中,不会丢失)

四.DQL查询数据(最重点)

1.DQL

Data Query Language 数据库查询语言 查询是最重要的
1:所有查询操作都用它 Select
2:简单的查询,复杂的查询,它都能做
3:数据库中最核心的语言,最重要的语言
4: 使用频率最高的语言

首先我们创建一个数据库,以及建立学生表、年级表、科目表、成绩表

CREATE DATABASE IF NOT EXISTS `school`;
-- 创建一个school数据库
USE `school`;-- 创建学生表
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student`(
	`studentno` INT(4) NOT NULL COMMENT '学号',
    `loginpwd` VARCHAR(20) DEFAULT NULL,
    `studentname` VARCHAR(20) DEFAULT NULL COMMENT '学生姓名',
    `sex` TINYINT(1) DEFAULT NULL COMMENT '性别,0或1',
    `gradeid` INT(11) DEFAULT NULL COMMENT '年级编号',
    `phone` VARCHAR(50
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值