第二阶段学习

------------------------day01-----------------------------

一、数据库

–1、概述

数据库database用来存储数据和管理数据的仓库。
分类: 关系型MySQL / 非关系型Redis

–2、使用

1) 安装服务器端: 存数据
设置端口号3306,设置密码root,设置字符集/编码表gbk/utf8
2) 安装客户端: 连接 服务器 ,操作 服务器里的数据,CRUD
DOS窗口: 小黑窗口
可视化工具: Sqlyog软件
3)结构: 数据库 -> 表 -> 数据(字段/字段的值)

二、SQL语言

–1,概述

SQL语言是结构化查询语言,专门用来操作数据库的语言.是一种标准化语言,可以操作各种数据库产品.
分类:
1,DML: 数据操纵语言,是指对数据进行CRUD
2,DDL: 数据定义语言,是指创建的SQL语法
3,DCL: 数据控制语言,是指权限的分配
4,DQL: 数据查询语言,是指对数据的各种查询语法
常用操做:
对数据库的操作,对表的操作,对数据/记录的操作

–2,对数据库的操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

–3,对表的操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

–4,对数据的操作

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

–5,总结
show databases; #查看所有库
create database 库名 default character set utf8 ; #创建库
drop database 库名 ; #删库

use 库名; #使用指定的数据库
create table 表名(字段名 字段类型(字段长度),字段名 字段类型(字段长度)); #新建表
show tables ; #查看表
drop table 表名; #删表
alter table 表名 add column 字段名 字段类型(字段长度) ; #修改表
desc 表名; #描述表的结构

select * from 表名; #查数据
insert into 表名 values(字段1的值,字段2的值,字段3的值,字段4的值) ;#添加数据
update 表名 set 字段名=新值 #改数据
delete from 表名 ; #删数据

三、可视化工具的使用

–1,概述

用sqlyog,连接服务器,操作服务器里的数据库,表, 记录 。
1,新连接:文件 – 新连接 – 输入连接名和密码 – 测试连接 – 连接 --ok
2,创建库: 右键 – 新建数据库 – 输入库名选好utf8-ok
3,创建表:右键 – 创建表-输入表名和选utf8 – 设计字段名字段类型和长度 – 保存
4,表里的记录: 右键 – 打开表 – 新增/删除/保存/刷新

--------------------------day02-------------------------

一、字段约束

–1,概述

当表里的字段值想要添加约束条件时,就可以使用各种字段约束
常见的有: 主键约束 非空约束 唯一约束
通常,在创建表时已经确定了,哪些字段要添加哪种约束

–2,测试
#字段约束
#1.主键约束:给字段添加主键约束时,字段的值必须唯一且非空
  #自增策略:AUTO_INCREMENT把主键的值交给数据库维护,值是自增
CREATE TABLE a(id INT)
CREATE TABLE b(id INT PRIMARY KEY)#主键(唯一+非空)
CREATE TABLE c(id INT PRIMARY KEY AUTO_INCREMENT)#主键且自增
#2.非空约束:not null,给字段加了非空约束,字段值不能为空
CREATE TABLE d(NAME VARCHAR(10))
CREATE TABLE e(NAME VARCHAR(10) NOT NULL)
INSERT INTO e VALUES()#报错,必须有值
INSERT INTO e VALUES(NULL)#报错,必须有值
#3.唯一约束:unique,给字段添加唯一约束,字段的值不能相同
CREATE TABLE f(tel VARCHAR(11))
CREATE TABLE g(tel VARCHAR(11) UNIQUE )

二、函数

–1,概述

为了方便的操作数据库里的数据 , MySQL提供了很多函数.
常见的有: lower upper length substr concat replace 日期函数 小数的函数

–2,测试
SELECT * FROM emp#查所有列,低效
SELECT ename FROM emp#查指定的列(把*换成字段名),高效
SELECT ename,empno FROM emp#查询结果和查询顺序一样的
#基础函数:
#lower:全转小写 upper:全转大写 
SELECT ename,empno,LOWER(ename),UPPER(ename) FROM emp
#length:获取长度,一个字母或数字长度为1,一个汉字长度是3
SELECT * FROM dept
SELECT dname,LENGTH(dname),loc,LENGTH(loc) FROM dept#查部门名称
#concat:拼接字符串,第一个参数是字段名,后面的参数都是要拼接的数据
SELECT dname,CONCAT(dname,'hello') FROM dept
SELECT dname,CONCAT(dname,'hello',123,789) FROM dept
#substr(1,2):截取字符串,1是字段名,2是从哪个字符开始
SELECT dname,SUBSTR(dname,3) FROM dept
#substr(1,2,3):1是字段名,2是从哪个字符开始,3是截取长度
SELECT dname,SUBSTR(dname,5,3) FROM dept
#replace(1,2,3):1是字段名,是要把2换成3
SELECT dname,REPLACE(dname,'a','666') FROM dept
#ifnull(1,2):1是字段名,判断1如果是null就换成2
SELECT comm,IFNULL(comm,200) FROM emp
SELECT * FROM emp
#计算月薪
SELECT sal,comm,sal+IFNULL(comm,0) FROM emp
SELECT sal,comm,sal+IFNULL(comm,0),sal*12+IFNULL(comm,0)*12 FROM emp
#round四舍五入, ceil向上取整 , floor向下取整
SELECT comm,ROUND(comm),CEIL(comm),FLOOR(comm) FROM emp
#日期函数 now当前时间 
#year年 month月 day日 hour时 minute分 second秒
SELECT NOW()#2021-08-26 15:39:18
SELECT YEAR( NOW() )
SELECT YEAR('2020-08-26'),MONTH(NOW()),DAY(NOW())
SELECT HOUR(NOW()),MINUTE(NOW()),SECOND(NOW())
#转义符号\
SELECT 'xi\'an' 
SELECT "xi'an" 

三、条件查询

–1,测试
#条件查询
#1. distinct 去重
SELECT DISTINCT loc  FROM dept
SELECT * FROM dept
#2. where条件
#查询deptno=1的部门信息
SELECT * FROM dept WHERE deptno=1
#查询deptno=2的部门名称
SELECT dname FROM dept WHERE deptno=2
#查询地址在二区的部门名称
SELECT dname FROM dept WHERE loc='二区'
#多个条件可以用and 或者 or连接
#查询地址在二区,编号是2的部门信息
SELECT * FROM dept WHERE loc='二区' OR deptno=2
#查询编号是2的或者编号是3的 部门信息
SELECT * FROM dept WHERE deptno=2 OR deptno=3
SELECT * FROM dept WHERE deptno IN(2,3)#同上等效
#3. like模糊查询
#%通配符,通配了0~n个字符,_通配符,通配了1个字符
#查名称里包含o的部门信息
SELECT * FROM dept WHERE dname LIKE '%o%'#低效
SELECT * FROM dept WHERE dname LIKE 'o%'#以o开始,高效
SELECT * FROM dept WHERE dname LIKE '%o'#以o结束
SELECT * FROM emp WHERE ename LIKE 'l__'#了解
#4. null操作空数据
SELECT * FROM emp WHERE comm IS NULL#查是null的
SELECT * FROM emp WHERE comm IS NOT NULL#查不是null的
#5. between and 区间范围,是包含的关系
SELECT * FROM emp WHERE sal>3000 AND sal<10000
SELECT * FROM emp WHERE sal BETWEEN 3000 AND 10000

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值