现在的世界,是大数据时代,得数据库者得天下,像很多岗位也是需要精通数据库,数据库是所有软件体系中最核心的存在:DBA
数据库(DB,DataBase)
概念:是一个数据仓库,也就是一个软件,安装在操作系统(windows、Linux、mac...)之上!可以存储大量的数据(500万以下);
作用:存储数据,管理数据;
MySQL是一个关系型数据库管理系统;
由瑞典MySQLAB公司出品,现属于Oracle公司旗下产品;
MySQL是最好的RDMS(Relational Database Management System,关系数据库管理系统)应用软件之一。开源的数据库软件!
体积小、速度快、总体拥有成本低,适用于中小型网站或者大型网站,集群!
官网下载地址:https://dev.mysql.com/downloads/mysql/
安装建议:
1、尽量不要使用exe
2、尽可能使用压缩包安装;
安装MySQL,安装SQLyog并连接数据库!
操作数据库-->操作数据库中的表-->操作数据库中表的数据
MySQL关键字不区分大小写
1、创建数据库
CREATE DATABASE IF NOT EXISTS westos;
2、删除数据库
DROP DATABASE IF EXISTS westos;
3、使用数据库
sql -- tab键的上面,如果你的表名或者字段名是一个特殊字符,就需要`` USE `school` 4、查看数据库
sql
SHOW DATABSES --查看所有的数据库
```
2.2、数据库的列类型
数值
数值名称 | 数据说明 | 字节数 |
---|---|---|
tinyint | 十分小的数据 | 1个字节 |
smallint | 较小的数据 | 2个字节 |
mediumint | 中等大小的数据 | 3个字节 |
int | 标准的数据 | 4个字节 (常用int) |
bight | 较大的整数 | 4个字节 |
float | 浮点数 | 4个字节 |
double | 浮点数 | 8个字节(精度问题) |
decimal | 字符串形式的浮点数 | 金融计数的时候,一般都是使用decimal |
字符串
名称 | 数据说明 | 大小 |
---|---|---|
char | 字符串固定大小 | 0-255 |
varchar | 可变字符串 | 0-65535(常用) |
tinytext | 微型文本 | 2^8-1 |
text | 文本串 | 2^16-1 保存文本大小 |
时间日期
名称 | 格式 | 说明 |
---|---|---|
date | YYYY-MM-DD | 日期格式 |
time | HH:mm:ss | 时间格式 |
datetime | YYYY-MM-DD HH:mm:ss | 最常用的时间格式 |
timestamp | 时间戳 | 1970.1.1到现在的毫秒数! |
year | 年份表示 |
null
注意:不要使用null进行运算,结果为NULL
unsigned:
zerofill:
自增:
默认
/* 每一个表,都必须存在以下五个字段!表示一个记录存在意义!
id 主键
`version` ? 乐观锁
is_delete ? 伪删除
gmt_create 创建时间
gmt_update 修改时间
*/
-- 目标 : 创建一个school数据库
-- 创建学生表(列,字段) 使用SQL 创建
-- 学号int ,登录密码varchar(20) ,姓名VARCHAR(30) ,性别varchar(2),出生日期(datatime),家庭住 址,email
-- 注意点,使用英文 () , 表的名称 和 字段 尽量使用 `` 括起来
-- AUTO_INCREMENT 自增 -- 字符串使用 单引号括起来!
-- 所有的语句后面加 , (英文的),后一个不用加
-- PRIMARY KEY 主键,一般一个表只有一个唯一的主键!
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 '性别',
`birthdate` DATETIME DEFAULT NULL COMMENT '出生日期',
`address` VARBINARY(20) DEFAULT NULL COMMENT '地址',
`email` VARBINARY(20) 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 -- 显示表的结构
-- 关于数据库引擎
/*
INNODB 默认使用
MYISAM 早些年使用的
*/
- | MYSIAM | INNODB |
---|---|---|
事务支持 | 不支持 | 支持 |
数据行锁定 | 不支持 | 支持 |
外键约束 | 不支持 | 支持 |
全文索引 | 支持 | 不支持 |
表空间的大小 | 较小 | 较大,约为2倍 |
常规使用操作:
在物理空间存在的位置
所有的数据库文件都存在data目录下,一个文件夹就对应一个数据库
本质上还是文件的存储!
MySQL引擎在物理文件上的区别
设置数据库表字符集编码
CHARSET = =utf8
不设置的画,会是MySQL默认的字符集编码(不支持中文)
MySQL的默认编码是Latin1,不支持中文
在MySQL文件夹中的my.ini文件中配置默认的编码
character-set-server=utf8
修改
-- 修改表名:alter rable 旧表名 rename as 新表名
ALTER TABLE student RENAME AS person;
-- 增加表的字段:ALTER TABLE person ADD 字段名 类属性
ALTER TABLE person ADD age INT(3);
-- 修改表的字段
-- ALTER TABLE person CHANGE 旧名 新名 列属性[]
ALTER TABLE person CHANGE age age1 INT(1);
-- 删除表的字段 ALTER TABLE 表名 DROP 字段名
ALTER TABLE person DROP age1
删除
-- 删除表(如果表存在)
DROP TABLE IF EXISTS student
注意点:
字段名
,要这样写原文:https://www.cnblogs.com/lmx-181028/p/12286699.html