【MySQL】操作数据库
操作数据库 > 操做数据库中的表 > 操作数据库中表的数据
==mysql关键字不区分大小写==
操作数据库
1、创建数据库
create database [if not exists] wostes; -- []代表可选的参数 {}代表必选的参数
2、删除数据库
drop database [if exists] wostes;
3、使用数据库
use `school`;
4、查看数据库
show databases; --查看所有数据库
数据库的列类型
数值
| 类型 | 说明 | 大小 |
|---|---|---|
| tinyint | 十分小的数据 | 1个字节 |
| smallint | 较小的数据 | 2个字节 |
| mediumint | 中等大小的数据 | 3个字节 |
| int | 标准的整数 | 4个字节(常用) |
| bigint | 较大的数据 | 8个字节 |
| float | 浮点数 | 4个字节 |
| double | 浮点数 | 8个字节 |
| decimal | 字符串形式的浮点数:金融计算时,一般使用decimal | 基本没有限制,解决Java的精度问题 |
字符串
| 类型 | 说明 | 大小 |
|---|---|---|
| char | 字符串固定大小的 | 0-255 |
| varchar | 可变字符串 | 0-65535(常用) |
| tinytext | 微型文本 | 2^8^ -1 |
| text | 文本串(保存大文本) | 2^16^-1 |
时间日期
java.util.Date
| 类型 | 说明 |
|---|---|
| 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:==
- 0填充
- 不充足的位数使用0来填充, int(3) — 5 ----> 005
==自增:==
- 通常理解为自增,自动在 上一条记录 的基础上+1(默认)
- 通常用来设计唯一的主键~ index ,必须是整数类型
- 可以定义设计主键自增的起始值和步长
==非空== NULL not null
- 假设设置为 not null ,如果不给它赋值,就会报错!
- NULL,如果不填写值默认就是null
==默认:==
- 设置为默认值
- sex,默认值为 男 ,如果不指定该列的值,则会有默认的值!
/* 每一个表,都必须存在以下五个字段!阿里规范,做项目时使用
id 主键
`version` 乐观锁
is_delete 伪删除
gmt_create 创建时间
gmt_update 修改时间(最后更新时间)
*/
创建数据库表(重点)
-- 目标:创建一个school数据库
-- 创建学生表(列,字段)使用sQL创建
-- 学号int 登录密码varchar(20)姓名,性别varchar(2),出生日期(datatime),家庭住址,emai1
-- 注意点,使用英文(),表的名称和字段尽量使用``括起来
-- 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`)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
格式:
create table [if not exists] `表名`(
`字段名` 列类型 [属性] [索引] [注释],
`字段名` 列类型 [属性] [索引] [注释],
...
`字段名` 列类型 [属性] [索引] [注释]
)[表类型] [字符集设置] [注释]
获取一些信息:
show create database test; -- 查看创建数据库的语句
show create table student; -- 查看student数据表的定义语句
desc student; -- 显示表的结构
数据表的类型
-- 关于数据库的类型
/*
INNODB 默认使用~
MyISAM 早些年使用
*/
| MYISAM | INNODB | |
|---|---|---|
| 事务支持 | 不支持 | 支持 |
| 数据行锁定 | 不支持(锁住整个表) | 支持 |
| 外键约束 | 不支持 | 支持 |
| 全文索引 | 支持 | 不支持 |
| 表空间大小 | 较小 | 较大,约为MyISAM的两倍 |
常规使用操作:
- MYISAM:节约空间,速度较快
- INNODB:安全性高,事务的处理,多表多用户操作
在物理空间存在的位置
- 所有的数据库文件都存贮在data目录下,一个文件夹就对应一个数据库;
- 本质还是文件存储!
MySQL 引擎在物理文件上的区别:
- INNODB 在数据库表中只有一个*.frm文件,以及上级目录下的
ibdata1文件 - MYISAM 对应文件:
- *.frm 表结构的定义文件
- *.MYD 数据文件(data)
- *.MYI 索引文件(index)
设置数据库表的字符集编码
CHARSET=utf8
-
不设置的话,会是MySQL默认的编码集(不支持中文)
-
MySQL的默认编码是Latin1,不支持中文
-
在my.ini中配置默认的编码
character-set-server=utf8
修改表删除表
修改
-- 修改表名 : alter table 旧表名 rename as 新表名;
alter table `teacher` rename as `teacher1`;
-- 增加表的字段:alter table `表名` add 字段名 列属性;
alter table `teacher1` add age int(11);
-- 修改表的字段:(重命名,修改约束)
-- alter table `表名` modify 字段名 列属性;
alter table `teacher1` modify `age` varchar(11); -- 修改约束
-- alter table `teacher1` change `旧名字` `新名字` [列属性];
alter table `teacher1` change `age` `age1` int(1); -- 字段重命名
-- 删除表的字段:alter table `表名` drop `字段名`;
alter table `teacher1` drop `ag1e`;
删除
-- 删除表(如果表存在在删除)
drop table if exists `teacher1`;
==所有的创建和删除操作尽量加上判断,以免报错~==
注意点:
- `` 字段名,使用这个包裹
- 注释:-- 和 /* */
- SQL关键字大小写不敏感,建议写小写
- 所有符号全部用英文(半角)
本文是原创文章,采用 CC BY-NC-ND 4.0 协议,完整转载请注明来自 程序员小航
评论
匿名评论
隐私政策
你无需删除空行,直接评论以获取最佳展示效果