数据库Mysql基础

数据库简介
  • 解决问题: 持久存储,优化读写, 保证数据的有效性
  • 当前使用的数据库, 主分为
    • 文档型, 如splite, 就是一个文件, 通过对文件的复制完成数据库的复制
    • 服务型, 如mysql, postgre, 数据存储在一个物理文件中, 但是需要使用终端以tcp/ip协议连接, 进行数据库的读写操作
E -R模型
  • E表示entry, 实体
  • R表示relationship, 关系
  • 一个实体转换为数据库的一个表
  • 关系描述两个实体之间的对应规则,包括
    • 一对一
    • 一对多
    • 多对多
  • 关系转换为数据库表中的一个列"在关系型数据库中的一行,就是一个对象"
三范式
  • 第一范式(1NF): 列不可拆分
  • 第二范式(2NF): 唯一标识
  • 第三范式(3NF): 引用主键
  • 说明: 后一个范式, 都是在前一个范式的基础上建立的
数据完整性
  • 一个数据库就是一个完整的业务单元, 可以包含多张表, 数据被存储在表中
  • 在表中为了更加准确的存储数据, 保证数据的正确有效, 可以在创建表的时候, 为表添加一些强制性的验证,包括数据字段的类型.约束
字段类型
  • 在mysql中包含的数据类型很多,
  • 数字: int, decimal
  • 字符串: char, varchar, text
  • 日期: datetime
  • 布尔: bit
约束
  • 主键 primary key
  • 非空 not null
  • 惟一 unique
  • 默认 default
  • 外键 foreign key
逻辑删除
  • 对于重要数据, 并不希望物理删除,一旦删除,数据无法找回
  • 一般对于重要数据,会设置一个isDelete的列,类型为bit,表示逻辑删除
  • 大于大量增长的非重要数据,可以进行物理删除
  • 数据的重要性,药分局实际开发决定
使用命令连接
  • 打开终端, 运行命令
mysql -uroot -p
回车后输入密码,当前设置的密码为mysql
  • 连接成功后如下图

查看版本: select version()
显示当前时间: select now()

远程连接

mysql -hip地址  -uroot -p
  • 创建数据库
create database 数据库名 charset=utf-8
  • 删除数据库
drop database 数据库名
  • 切换数据库
use 数据库名
  • 查看当前选择的数据库
select database():
  • 查看当前数据库中所有表
show tables;
  • 查看表结构
desc 表名;
  • 创建表
auto_increment表示自动增长
  • 例:创建班级表
create table classes(
    id int unsigned auto_increment primary key not null,
    name varchar(10)
);
  • 例:创建学生表
create table students(
    id int unsigned primary key auto_increment not null,
    name varchar(20) default '',
    age tinyint unsigned default 0,
    height decimal(5,2),
    gender enum('男','女','人妖','保密'),
    cls_id int unsigned default 0
)
  • 修改表-添加字段
alter table 表名 add 列名 类型;
例:
alter table students add birthday datetime;
  • 修改表-修改字段:重命名版
alter table 表名 change 原名 新名 类型及约束;
例:
alter table students change birthday birth datetime not null;
  • 修改表-修改字段:不重命名版
alter table 表名 modify 列名 类型及约束;
例:
alter table students modify birth date not null;
  • 修改表-删除字段
alter table 表名 drop 列名;
例:
alter table students drop birthday;
  • 删除表
drop table 表名;
例:
drop table students;
  • 查看表的创建语句
show create table 表名;
例:
show create table classes;

重点
手写 mysql 语句

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值