MySql笔记Ⅰ
MySql
part 1:
数据库概念
- 数据库:(DataBase, 简称DB):数据库中的数据按一定的数据模型组织、描述和储存,具有较小的冗余度、较高的数据独立性和易扩展性,并可为各种 用户共享
- 数据库管理系统(DataBase Management System 简称DBMS):
- 数据库服务器:一台计算机(对内存要求比较高)
- 数据库管理系统:如mysql(是一个软件)
- 数据库:db(即文件夹)
- 表:userinfo, studentinfo,courseinfo(即文件)
- 记录:1 朱葛 13234567890 22(多个字段的信息组成一条记录,即文件中的一行内容)
- 总结:
- 数据库服务器:运行数据库管理软件
- 数据库管理软件:管理-数据库
- 数据库:即:文件夹,用来组织文件/表
- 表:即文件,用来存放多行内容/多条记录
- 记录:即文件中的一行内容
- 关系型数据库 相对慢
- 非关系型数据库 块
- 快递 快递单号
- 视频 电影的id: 电影的内容
mysql的账号操作
mysqld install 安装mysql服务 mysql服务就被注册到操作系统中(已自动启动)
net start mysql 启动mysql服务(之后开机都是自启动)
net stop mysql 关闭mysql服务
先启动服务端 net start mysql(开机自启动)
再启动客户端 mysql -uroot -p(需要自己手动开启)[以root身份进入]
连接别人数据库 mysql -uroot -p123 -h192.168.14.12
进入mysql客户端
$mysql
mysql>select user(); # 查看当前用户
mysql> exit # 也可以用\q quit退出
# 默认用户登陆之后并没有实际操作的权限
# 需要使用管理员root用户登陆
$ mysql -uroot -p # mysql5.6默认是没有密码的
#遇到password直接按回车键
mysql> set password = password('root'); # 给当前数据库设置密码
# 创建账号:
mysql> create user 'eva'@'192.168.10.%' IDENTIFIED BY '123';# 指示网段
mysql> create user 'eva'@'192.168.10.5' # 指示某机器可以连接
mysql> create user 'eva'@'%' #指示所有机器都可以连接
mysql> show grants for 'eva'@'192.168.10.5';查看某个用户的权限
# 远程登入
$ mysql -uroot -p123 -h 192.168.10.3
# 给账号授权
mysql> grant all[可选all,select,insert等] on *.* to 'eva'@'%';
{例如:# grant 权限类型(all,select,insert等) on ftp.* to 'guest'@'192.168.14.%' (userinfo)}
mysql> flush privileges; # 刷新使授权立即生效
# 创建账号并授权
mysql> grant all on *.* to 'eva'@'%' identified by '123'
mysql基础
操作数据库(文件夹)
查看所有数据库 show databases;
创建一个数据库 create database 数据库名;
切换到这个库下 :use 数据库的名字;
查看这个库下有多少表: show tables;
操作表
创建一张表
create table 表名(name char(12),age int);
查看表结构
desc student;
操作数据
插入数据:insert into student values('alex',84);
查询数据: select * from student;
修改数据: update student set age=85 where name='alex';
删除数据: delete from student where name = 'alex';
- 操作文件夹(库)
增:create database db1 charset utf8;
查:show databases;
改:alter database db1 charset latin1;
删除: drop database db1;
- 操作文件(表)
先切换到文件夹下:use db1
增:create table t1(id int,name char);
查:show tables;
改:alter table t1 modify name char(3);
alter table t1 change name name1 char(2);
删:drop table t1;
- 操作文件中的内容(记录)
增:insert into t1 values(1,'egon1'),(2,'egon2'),(3,'egon3');
查:select * from t1;
改:update t1 set name='sb' where id=2;
删:delete from t1 where id=1;
- 清空表:
delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。
truncate table t1;数据量大,删除速度比上一条快,且直接从零开始,
*auto_increment 表示:自增
*primary key 表示:约束(不能重复且不能为空);加速查找
part2:
存储引擎
存储数据的方式
- Innodb存储引擎 ***** mysql5.6之后的默认的存储引擎
数据和索引存储在一起 2个文件
- 数据索引\表结构
数据持久化
支持事务 : 为了保证数据的完整性,将多个操作变成原子性操作 : 保持数据安全
支持行级锁 : 修改的行少的时候使用 : 修改数据频繁的操作
支持表级锁 : 批量修改多行的时候使用 : 对于大量数据的同时修改
支持外键 : 约束两张表中的关联字段不能随意的添加\删除 : 能够降低数据增删改的出错率
- Myisam存储引擎 mysql5.5之前的默认的存储引擎
- 数据和索引不存储在一起 3个文件
- 数据\索引\表结构
- 数据持久化
- 只支持表锁
- Memory存储引擎
- 数据存储在内存中, 1个文件
- 表结构
- 数据断电消失
查看存储引擎:show engines;
- 面试题
你了解mysql的存储引擎么?
你的项目用了什么存储引擎,为什么?
innodb
多个用户操作的过程中对同一张表的数据同时做修改
innodb支持行级锁,所以我们使用了这个存储引擎
为了适应程序未来的扩展性,扩展新功能的时候可能会用到...,涉及到要维护数据的完整性
项目中有一两张xx xx表,之间的外键关系是什么,一张表的修改或者删除比较频繁,怕出错所以做了外键约束
表和数据的基本操作
- 创建表:
create table 表名(
id int,
name char(18),
字段名3 类型[(宽度) 约束条件]
);
放在中括号里的内容可以不写
- 写入数据的方式(三种方式):
insert into 表 values (值1,值2,值3);
这张表有多少的字段,就需要按照字段的顺序写入多少个值
insert into 表 values (值1,值2,值3),(值1,值2,值3),(值1,值2,值3);
一次性写入多条数据
insert into 表 (字段1,字段3 ) values (值1,值3);
指定字段名写入,可以任意的选择表中你需要写入的字段进行
查表中的数据:
select * from 表
查看表结构:
desc 表名;(更加利于查看)
能够查看到有多少个字段\类型\长度,看不到表编码,引擎,具体的约束信息只能看到一部分
show create table 表名;
能查看字段\类型\长度\编码\引擎\约束
数据类型--数字
- int 不约束长度,最多表示10位数
- float(m,n)
- m 一共多少位
- n 小数部分多少位
- 例子:
创建表:
create table t1(
id int, # 默认是有符号的{一般使用int 类型}
age tinyint unsigned # 如果需要定义无符号的使用unsigned[表示非负数]
)
create table t2(
f1 float(5,2), # 保留两位小数,并且四舍五入。 一共5位数,后面小数的位数未2位,前面为3位数。
f2 float # 大部分使用float即可满足要求
f3 double(5,2),
f4 double
)
数据类型--时间
- date 20190620
- time 121953
- datetime 20190620121953
- year
- date
- time
- timestamp
- 例子:
create table t4(
dt datetime,
y year,
d date,
t time,
ts timestamp
);
mysql> create table t5(
-> id int,
-> dt datetime NOT NULL # 不能为空
DEFAULT CURRENT_TIMESTAMP # 默认是当前时间
ON UPDATE CURRENT_TIMESTAMP); # 在更新的时候使用当前时间更新字段
数据类型--字符串
- char
- varchar
char(18) # 最多只能表示255个字符
定长存储,浪费空间,节省时间
'alex' 'alex '
varchar(18) # 最多能表示65535个字符
变长存储,更节省空间,存取速度慢
'alex' 'alex4'
适合使用char
身份证号
手机号码
qq号
username 12-18
password 10-16
银行卡号
适合使用varchar
评论
朋友圈
微博
- 例子:
建表
create table t6(
c1 char, # 默认长度是1
v1 varchar(1), # 必须写长度
c2 char(8),
v2 varchar(8)
);
数据类型--enum和set
- enum 单选
- set 多选
- 例子:
create table t8(
id int,
name char(18),
gender enum('male','female')
);
create table t9(
id int,
name char(18),
hobby set('抽烟','喝酒','烫头')
);
insert into t9 values (1,'alex','抽烟,喝酒');
表的完整性约束
- 约束某一个字段
- 无符号的 int unsigned {unsigned表示非负数}
- 不能为空 not null
- 默认值 default
- 唯一约束 unique
- 联合唯一 unique(字段1,字段2)
- 自增 auto_increment
- 只能对数字有效.自带非空约束
- 至少是unique的约束之后才能使用auto_increment
- 主键 primary key
- 一张表只能有一个
- 如果不指定主键,默认是第一个非空+唯一
- 联合主键 primary key(字段1,字段2)
- 外键 foreign key
- Foreign key(自己的字段) references 外表(外表字段)
- 外表字段必须至少是"唯一"的
- 例子:
create table t10(
id int unsigned
);
create table t11(
id int unsigned not null,
name char(18) not null
);
create table t12(
id int unsigned not null,
name char(18) not null,
male enum('male','female') not null default 'male'
);
- 不能重复 unique 值不能重复,但是null可以写入多个
create table t13(
id1 int unique,
id2 int
)
- 联合唯一 unique
create table t14(
id int,
server_name char(12),
ip char(15),
port char(5),
unique(ip,port)
);
- 非空 + 唯一约束
第一个被定义为非空+唯一的那一列会成为这张表的primary key
一张表只能定义一个主键
create table t15(
id int not null unique,
username char(18) not null unique
);
create table t16(
username char(18) not null unique,
id int not null unique
);
create table t17(
username char(18) not null unique,
id int primary key # 指定主键,不指定的话非空+唯一的第一个就是主键
)
- 联合主键(比较少用)
create table t18(
id int,
server_name char(12),
ip char(15) default '',
port char(5) default '',
primary key(ip,port)
);
create table t19(
id int primary key,
server_name char(12),
ip char(15) not null,
port char(5) not null,
unique(ip,port)
);
- 自增
create table t20(
id int primary key auto_increment,
name char(12)
);
insert into t20(name) values('alex');
- 外键
班级表
create table class(
cid int primary key auto_increment,
cname char(12) not null,
startd date
)
# 学生表
create table stu(
id int primary key auto_increment,
name char(12) not null,
gender enum('male','female') default 'male',
class_id int,
foreign key(class_id) references class(cid)
)
create table stu2(
id int primary key auto_increment,
name char(12) not null,
gender enum('male','female') default 'male',
class_id int,
foreign key(class_id) references class(cid)
on update cascade
on delete cascade # 尽量不用
)
表与表之间的关系
- 分析步骤:
先站在左表的角度去找
是否左表的多条记录可以对应右表的一条记录,如果是,则证明左表的一个字段foreign key 右表一个字段(通常是id)再站在右表的角度去找
是否右表的多条记录可以对应左表的一条记录,如果是,则证明右表的一个字段foreign key 左表一个字段(通常是id)总结:
多对一:
- 如果只有步骤1成立,则是左表多对一右表
- 如果只有步骤2成立,则是右表多对一左表
多对多
- 如果步骤1和2同时成立,则证明这两张表时一个双向的多对一,即多对多,需要定义一个这两张表的关系表来专门存放二者的关系
一对一:
- 如果1和2都不成立,而是左表的一条记录唯一对应右表的一条记录,反之亦然。这种情况很简单,就是在左表foreign key右表的基础上,将左表的外键字段设置成unique即可
MySql笔记Ⅰ的更多相关文章
- MySQL笔记汇总
[目录] MySQL笔记汇总 一.mysql简介 数据简介 结构化查询语言 二.mysql命令行操作 三.数据库(表)更改 表相关 字段相关 索引相关 表引擎操作 四.数据库类型 数字型 字符串型 日 ...
- 涂抹mysql笔记-数据库中的权限体系
涂抹mysql笔记-数据库中的权限体系<>能不能连接,主机名是否匹配.登陆使用的用户名和密码是否正确.mysql验证用户需要检查3项值:用户名.密码和主机来源(user.password. ...
- centos7.2下安装Mysql笔记
centos7.2下安装Mysql笔记 安装 MySQL 适用于 CentOS 7.0 或以后版本: yum install mariadb mariadb-server 适用于 CentOS 6.8 ...
- MySQL笔记(六)游标练习
23.3.1 Trigger Syntax and Examples 意义不明的几道练习,留着备用. 感觉不好写,而且难以调试..不知道以后会不会有实际的应用场景. 环境:MySQL 笔记(三)由 t ...
- mysql 笔记(一)
mysql 笔记 预留 mysql> use mysql; mysql> grant all privileges on *.* to root@'%' identified by &q ...
- 【MySQL笔记】SQL语言四大类语言
SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句, ...
- Mysql 笔记二
Mysql 笔记二 Mysql 笔记二 Table of Contents 1. 前言 2. Master Thread 工作方式 2.1. 主循环(loop) 2.2. 后台循(backgroup ...
- 深入浅出mysql笔记---1、mysql下载安装
深入浅出mysql笔记---1.mysql下载安装 一.总结 一句话总结: linux下rpm安装即可 1.linux的wget命令作用? 下载文件的工具:比如wget http://cn.wordp ...
- 深入浅出mysql笔记---0、序
深入浅出mysql笔记---0.序 一.总结 一句话总结: 心得:买书之前建议先找找电子书,纸质书太难带了 1.开源作用? 开源对mysql的发展至关重要 2.mysql在2002年就全面支持了事务, ...
- 最全mysql笔记整理
mysql笔记整理 作者:python技术人 博客:https://www.cnblogs.com/lpdeboke Windows服务 -- 启动MySQL net start mysql -- 创 ...
随机推荐
- 【Android开发】简单好用的阴影库 ShadowLayout
先来看一张使用 ShadowLayout 库实现的各种阴影的效果图,如下图所示: 如上图所示,通过使用 ShadowLayout 可以控制阴影的颜色.范围.显示边界(上下左右四个边界).x 轴和 y ...
- 【每日日报】第三十四天---Scanner类的应用
1 今天继续看书 Scanner类的应用 1 package File; 2 import java.util.Scanner; 3 4 public class ScannerDemo { 5 pu ...
- Android控件设置半透明+EditText设置默认值+ 控件居中
Android控件设置半透明 效果 代码: android:background="#50FFFFFF" 50表示50%透明 Android:EditText设置默认值 andro ...
- 利用css3渐变效果实现圆环旋转效果
* { margin: 0; padding: 0; } .stage { width: 200px; height: 130px; margin: 100px auto; position: rel ...
- PyQt5 基本语法(四)
目录 2. 输入控件(一) 2.1 纯键盘 2.1.1 QLineEdit 2.1.1.1 描述 2.1.1.2 控件创建 2.1.1.3 输出模式 2.1.1.4 提示字符串 2.1.1.5 清空按 ...
- Struts2-Action的基本流程
1.浏览器发送HTTP请求 2.Web容器调用Struts2过滤器的doFilter()方法 3.通过Struts2的内部处理机制,判断HTTP请求是否与某个Action对象匹配 4.如果有与之匹配的 ...
- 2021.07.09 K-D树
2021.07.09 K-D树 前置知识 1.二叉搜索树 2.总是很长的替罪羊树 K-D树 建树 K-D树具有二叉搜索树的形态,对于每一个分类标准,小于标准的节点在父节点左边,大于标准的节点在父节点右 ...
- 基础的CSS描绘测试
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...
- Intellij IDEA 高效使用教程 (插件,实用技巧) 最好用的idea插件大全
安装好Intellij idea之后,进行如下的初始化操作,工作效率提升十倍. 一. 安装插件 1. Codota 代码智能提示插件 只要打出首字母就能联想出一整条语句,这也太智能了,还显示了每条语句 ...
- [ubuntu18.04 python3.6] 清华源 CondaHTTPError: HTTP 000 CONNECTION
问题 嫌官网源安装jupyter notebook太慢,所以尝试修改为清华源,但每次在Solving environment的时候就报错如下: 解决方法,修改conda配置信息: vim ~/.con ...