3.MySQL

这篇博客详细介绍了如何通过命令行连接和操作MySQL数据库,包括创建、删除数据库,切换、查看数据库以及数据表的创建。同时,文章阐述了各种数据类型,如数值、字符串和时间日期类型,并强调了字段属性的重要性,如非空、默认值和自增。此外,还讨论了数据库引擎的选择,如InnoDB和MyISAM的区别。最后,提到了字符集编码的设置及其对数据库存储的影响。
摘要由CSDN通过智能技术生成

1.7连接数据库

命令行连接

mysql -u root -p123456  --连接数据库

show databases;                           --查看所有数据库
use school                                     --切换到某个数据库
show tables;                                  --查看数据库中所有的表
describe student;                           --查看某个表中的所有数据
create database westos;               --创建一个数据库wetos
exit;                                                -- 退出连接

--    SQL的单行注释
/**/   SQL的多行注释


数据库语言

DDL定义
DML操作
DQL查询
DCL控制

2.操作数据库

操作数据库→操作数据库中的表→操作数据库中的表的数据
mysql关键字不区分大小写

2.1操作数据库

1.创建数据库

CRTEATE DATABASE [IF NOT EXISTS] westos;

2.删除数据库

DROP DATABASE [IF EXISTS] westos

3.使用(切换)数据库

USE `school`

4.查看数据库

SHOW DATABASES   --查看所有数据库

遇到不会的命令可以通过SQLyog可视化操作学习

2.2、数据库的数据类型

数值

tinyint 十分小的数据 1个字节
smallint 较小的数据 2个字节
mediumint 中等大小的数据 3个字节
int 标准大小的整数 4个字节
bigint 较大的数据 8个字节
float 浮点数 4个字节
double 浮点数 8个字节
decimal 字符串形式的浮点数 金融计算的时候一般是使用decimal

字符串

char 字符串固定大小的 0~255
varchar 可变字符串 0~65535 常用的变量对应java里的 String
tintxet 微型文本 2^8-1
text 文本串 2^16-1 保存大文本

时间日期

java.until.Date
date YYYY-MM-DD 日期格式
time HH:mm:ss 时间格式
datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式
timestamp 时间戳 1970.1.1到现在的毫秒数 也较为常用
year 表示年份

null

没有值,未知
注意,不要用NULL经行运算,结果为NULL

2.3、数据库的字段属性(重点)

Unsigned
无符号的整数
声明了该列不能为负数

zerofill
0填充的
不足位数,自动用0来填充,例如int(3),输入5→005

自增
自动在上一条记录的基础上+1
通常用来设计唯一的主键~index,选中类型不许是整数类型
可以自定义设计主键自增的起始值和步长
在这里插入图片描述
在这里插入图片描述

非空 NULL not null
假设设置为not null,如果不给它赋值就会报错。
NULL,如果不填写值,默认就是null

默认:
设置默认的值
sex,默认值为男,如果不指定该列的值,则会有默认的值

拓展:

每一个表都必须存在以下五个字段!未来做项目用的,表示一个记录存在意义!
	id    主键
	`version`    乐观锁
	is_delete    	伪删除
	gmt_create    创建时间
	gmt_update    修改时间

2.4、创建数据库表(重点)

用SQL语句创建学生表

1.选中school数据库
在这里插入图片描述
2.输入命令行

-- 目标:使用SQL创建学生表(列,字段)
-- 学号int ,登录密码varchar(20 姓名),性别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 '性别',
`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY(`id`)

在这里插入图片描述
格式

CREATE TABLE [IF NOT EXISTS] `表名`(
	`字段名`  列类型 [属性] [索引] [注释],
	`字段名`  列类型 [属性] [索引] [注释],
	`字段名`  列类型 [属性] [索引] [注释],
	,,,,,,
	`字段名`  列类型 [属性] [索引] [注释]
	)[表类型][字符集设置][注释]

SQLyog可视化转化成SQL语句的命令

SHOW CREAT DATABASE school  --查看创建数据库的语句
SHOW CREAT TABLE student  --查看student数据表的定义语句
DESC student  --显示表的结构

在这里插入图片描述
在这里插入图片描述
CREATE TABLE 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 ‘性别’,
birthday datetime DEFAULT NULL COMMENT ‘出生日期’,
address varchar(100) DEFAULT NULL COMMENT ‘家庭住址’,
email varchar(50) DEFAULT NULL COMMENT ‘邮箱’,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

2.5、数据表的类型

关于数据库的引擎:
INNODB 在如今默认使用的
MYISAM 早些年使用的

\MYISAMINNODM
事务支持不支持支持
数据行锁定不支持支持
外键约束不支持支持
全文索引支持不支持
表空间的大小较小较大,约为2倍

常规使用操作:
MYISAM 节约空间,书读较快
INNODB 安全性高,支持事务的处理,多表多用户操作

数据库文件在物理空间存在的位置
所有的数据库文件都存在data目录下,一个文件夹对应一个数据库
本质还是文件的存储!

InnoDB 在数据库表中只有一个*.frm文件,以及上级目录下的ibdata1文件
MYISAM 对应文件
	*.frm   表结构的定义文件
	*.MYD    数据文件(data)
	*.MYI    索引文件(index)

设置字符集编码

	1.CHARSET=utf8
不设置的话,会是mysql默认字符集编码(不支持中文)
MySQL默认编码是Latin1,不支持中文
	2.在my.ini中配置默认的编码
character-set-server=utf8(不建议,将代码移植到没有配置过的电脑无法正常编码)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值