Mysql数据库基础
初识数据库
为什么要用数据库:
- 第一,将文件和程序存在一起上是很不合理的.
- 第二,操作文件是一件很麻烦的事情.
数据库的优势:
1.程序稳定性:这样任意一台服务所在的机器崩溃了都不会影响数据和另外的服务.
2.数据一致性:所有的数据都存储在一起,所有的程序的数据都是统一的,就不会出现数据不一致的现象
3.并发:数据库可以良好的支持并发,所有的程序操作数据库都是通过网络,而数据库本身支持并发的网络操作,不需要我们自己写socket
4.效率:使用数据库对数据进行增删改查的效率要高出我们自己处理文件很多
初识Mysql
mysql:
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。
MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
sql语句:
- SQL:结构话查询语言,是一种特殊目的的编程语言,是一种数据库查询和程序设计的语言,用于存储数据以及查询.更新和管理关系数据库系统
- SQL语言主要用于存取数据,查询数据,更新数据和管理数据库系统,SQL语言由IBM开发.SQL语言分为3中类型:
- DDL语句:数据库定义语言:数据库,表,试图,索引,存储过程
- DDM语句:数据库操纵语言:插入数据,删除数据,更新数据,查询数据
- DCL语句:数据库控制语言:控制用户的访问权限
简单的sql语句:
1. 操作文件夹(库)
增:create database db1 charset utf8;
查:show databases;
改:alter database db1 charset latin1;
删除: drop database db1;
2. 操作文件(表)
先切换到文件夹下: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;
3. 操作文件中的内容(记录)
增: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;数据量大,删除速度比上一条快,且直接从零开始,
存储引擎:
同样的数据,对你来说也是同样的表,只不过指定不同的存储引擎,代表了数据存储的时候的不同方式不同的存储引擎:
innodb: 支持事务 行级锁 聚焦索引 支持外键 mysql5.6 默认的存储引擎
myisam:不支持事务 行级锁 外键 非聚焦索引 表级锁 mysql5.5默认的存储引擎
memory:只能在内存中存储数据 速度快 但是断电消失
blackhole:不能存储任何数据 只是有一个表结构 用于大数据量背景下做数据分流用的
mysql中的数据类型:
- 数据类型:int 4个字节 bigint 8个字节
- 字符串类型 char varchar
- 集合和枚举类型:set ('1','2','3') 多选 enum ('1','2') 多选1
- 时间类型
基础数据类型:
# 1.数字类型
# tinyint 1个字节 8位
# print(2**8)
# 0 - 255 无符号的情况下
# 2**(8-1) -128-127
# int 4个字节
# int(5)
# create table t1 (id1 int,in2 int(5));
# 我们设置的int后面的长度只是 约束了 显示宽度
# 所以我们输入的数字的长度可以是范围内任意的数字而不必担心宽度的设置
# 但是如果我们放入了超出范围的数字,那么只能写入当前范围内能描述的最大值
# float(一共m位,小数部分占n位)
# 保留n位小数,并且四舍五入保留
# 2.时间类型
# date 年月日 可以为空 没有默认值 表示时间范围长
# datetime 年月日时分秒 可以为空 没有默认值 表示时间范围长
# timestamp年月日时分秒 不能为空 默认插入当前时间 并且随update语句更新字段 表示时间范围短
# date支持的写入 insert into 表名 values('2018-12-17')
# datetime\ timestamp支持的写入
# insert into 表名 values('2018-12-17 11:56:20')
# insert into 表名 values('20181217115620')
# insert into 表名 values(20181217115620)
# 3.字符串类型
# char 定长,存在空间浪费,速度快
# char(12) 长度比较固定的内容 : 身份证号 手机号码 银行卡号 用户名 密码
# 'abc' --> 'abc '
# 'abcdef'--> 'abcde'
# varchar 不定长,不浪费空间,速度慢
# varchar(255) 评论
# 'abc' --> 'abc3' 占4个字节
# 'abcde' --> 'abcde5'占6个字节
# 4.set和enum
# enum
# 单选
# 选错不生效
# set
# 多选
# 选错不写入
# 自动去重