mysql笔记3(数据库、表和数据的基础操作)
文章目录
- 一、数据库的基础操作
- 1. 显示所有的仓库(数据库)
- 2. 创建数据库
- 注意(命名规范):
- 3. 删除数据库
- 4. 查看创建数据库的SQL
- 5. 创建数据库时跟随字符编码
- 6. 修改数据库的字符编码
- 二、表的基础操作
- 1. 引入表的思维
- 2. 引用数据库
- 3. 查看该数据库下面的表
- 4. 创建表
- ① 初级
- 上述name varchar(30)中30是字符宽度或者说最大字符串长度的限制。实际输入的数据是可以超过这个宽度的,那么超过这个宽度会有什么后果?
- ② 高级(企业在用)
- 5. 查看表结构
- ① show create table 表名;(优点:会显示创建这张表时的sql语句)
- ② desc 表名;(优点:直观、好看)
- 6. 删除表
- 7. 修改表
- ① 添加字段
- ② 删除字段
- ③ 更改字段
- ④ 修改表名
- 三、数据的基础操作
- 1. 插入数据(实际开发过程中不是这样的,但是我们要会这种写法)
- 2. 查看表内数据(基本)
- 3. 更新表内数据
- 4. 删除表内数据
- 5. 清空表
- ① delete from 表名(不推荐:因为它在删除时会遍历整张表,效率非常低)
- ② truncate table 表名(直接销毁这张表,销毁完再创建一张一模一样的表,只是表内的数据已经不在了)
- 四、SQL语句区分
- 五、字符集编码问题
- 六、内容出处
一、数据库的基础操作
CRUD:create、drop、alter、show
1. 显示所有的仓库(数据库)
show databases;
information-schema:存储服务器管理数据库的信息
mysql:提供一些系统的信息,例如:root用户名及密码
performance_schema:存储服务器性能信息
sys:系统文件
test(有的版本没有):测试库
注:
其它的库是我自己建的
2. 创建数据库
一、普通创建:
① create database + 数据库名;
二、如果该数据库已存在就不创建,反之创建(就算该数据库已经存在也能通过,只是会弹出警告):
② create database if not exists + 数据库名;
③ create database if not exists + 数据库名(数据库名写在反引号里);
注意(命名规范):
不能用关键字(如create、database等)作为数据库名、表名、表中的字段名。如果非要用,就得给它们加上反引号。
后续创建和删除普通的数据库(不以关键字作为数据库名)时给数据库名加上反引号可以使代码看起来更高级。
3. 删除数据库
一、普通删除:
① drop database + 数据库名;
二、如果该数据库已存在就不创建,反之创建(就算该数据库已经存在也能通过,只是会弹出警告):
② drop database if exists + 数据库名;
③ drop database if exists + 数据库名(数据库名写在反引号里);
注:
删除一个不存在的数据库会报1008错误。
4. 查看创建数据库的SQL
看一下当时是怎么创建的这些数据库的:
show create database + 数据库名;
5. 创建数据库时跟随字符编码
① create database if not exists student charset=gbk;
② create database if not exists teacher charset=utf8;
注:
① 常用的字符编码:GBK(中文简体)、utf8(国际通用)
② 乱码和字符编码有关
③ cmd的字符编码时gbk,因此可以显示中文
④ 在windows上学习时字符编码可以选择gbk(因为cmd就是gbk),但是在linux、mac上学习时要选择utf8。实际开发过程中也要选择utf8,因为上传到服务器以后大多数人用的都是utf8。
6. 修改数据库的字符编码
alter database + 数据库名 + charset=改成哪种字符编码
二、表的基础操作
CRUD:create(创建表)和alter+add(增加表内字段)、drop(删除表)和alter+drop(删除表内字段)、alter、show和desc
1. 引入表的思维
仓库 -> 数据库
货架 -> 表
物品放在货架上 -> 数据放在表里
2. 引用数据库
可以理解为指定某仓库发货:
use + 数据库名
3. 查看该数据库下面的表
可以理解为查看某仓库的所有货架:
show tables;
4. 创建表
① 初级
上述name varchar(30)中30是字符宽度或者说最大字符串长度的限制。实际输入的数据是可以超过这个宽度的,那么超过这个宽度会有什么后果?
等后面再来看这个问题。
② 高级(企业在用)
auto_increment:自动增长
primary key:主键(主键不可以为空) 写上了这个意味着该字段的数据是唯一的(每个学生的学号不可能重复,靠它来区分学生)关系型数据库的实现也依靠主键
comment:注释(后面的引号是普通的单引号,不是反引号,用反引号会报1064错误)
not null:意思是该字段不能为空
default:默认值
engine=innodb:数据库引擎是innodb。现在mysql里用的最多的数据库引擎就是innodb
5. 查看表结构
① show create table 表名;(优点:会显示创建这张表时的sql语句)
② desc 表名;(优点:直观、好看)
PRI:primary key缩写
extra:额外的规则(限制)
6. 删除表
① drop table 表名;
② drop table if exists 表名;
③ drop table if exists 表名(表名用反引号引起来);
④ 同时删除多张表:drop table if exists 表名, 表名, 表名;
注:
① 删除不存在的表会报1051错误
② 不可以同时删掉多个数据库
7. 修改表
① 添加字段
① 普通添加:alter table 表名 add 字段名 字段类型;
② 在指定位置添加:
alter table 表名 add 字段名 字段类型 after 字段名(想放在哪个字段后面)
没有before这个语法
③ 直接在开头添加:
alter tabel 表名 add 字段名 字段类型 first;
② 删除字段
alter table 表名 drop 字段名;
③ 更改字段
alter table 表名 change 要改的字段名 改成什么
只修改字段的类型:
alter table 表名 modify 要改的字段名 改成什么类型
④ 修改表名
alter table 表名 rename to 改成什么名;
三、数据的基础操作
CRUD:insert、delete、update、select
1. 插入数据(实际开发过程中不是这样的,但是我们要会这种写法)
① insert into 表名 (字段, 字段) values ( 对应的数据, 对应的数据)
表名后面的字段不省略时:字段顺序可以不与建表时的字段顺序一致,只需要让此处的字段顺序与values后面的数据顺序一致即可
② insert into 表名 values (对应的数据, 对应的数据)
表名后面的字段省略时:values后面的数据顺序必须与建表时的字段顺序一致
③ 一次插入多条数据(直接在values后面补充数据即可,数据之间以逗号隔开):
insert into 表名 (字段, 字段) values ( 对应的数据, 对应的数据), ( 对应的数据, 对应的数据);
insert into 表名 values (对应的数据, 对应的数据), ( 对应的数据, 对应的数据);
上面的引号都是普通的单引号
2. 查看表内数据(基本)
其实CRUD中查询是最难的
① select 要查的字段 from 查哪张表里
② 查看某张表里的全部字段(效率不高,性能方面存在缺陷):select * from 表名;
3. 更新表内数据
① 重点在于根据谁去改,改什么。
② 可以一次改多个字段
③ 一定要注意, where后面的条件, SQL注入攻击就跟它有关
① update 表名 set 字段名=改成什么 where 要改谁
② update 表名 set 字段名=改成什么, 字段名=改成什么 where 要改谁 or 要改谁
4. 删除表内数据
一定要特别注意where后面的条件
delete from 表名 where 要改谁
5. 清空表
① delete from 表名(不推荐:因为它在删除时会遍历整张表,效率非常低)
我们可以发现,除非我们特意指定id,否则新插入的数据id会承接该表销毁之前的id序号。
② truncate table 表名(直接销毁这张表,销毁完再创建一张一模一样的表,只是表内的数据已经不在了)
我们可以发现用此种方式清空表后,重新插入数据的id是从1开始的
四、SQL语句区分
数据库无非就是增删改查。我们可以发现数据库、表和数据这三个东西的增删改查都不一样。
① DDL(全称:data definition language, 数据库定义语言):就是给数据库用的语言 – 对数据库而言
CRUD:create、drop、alter、show
② DML(全称:data manipulation language, 数据操纵语言):–对数据而言
CRUD:insert delete update select
③ DCL(全称:data control language, 数据库控制语言):控制不同用户对数据库中表的开发权限
五、字符集编码问题
查看字符集编码:show variables like ‘character_set_%’;
① 由于character_set_client(终端) character_set_results(返回值) 都是gbk,因此上述数据可以用中文输入。
② 如果其它平台想用中文输入,把character_set_client和character_set_results改成gbk即可。
命令:set character_set_client=gbk;
③ 实际开发过程中一定是utf8,符合国际标准。这也是为什么windows相对而言没那么适合做开发,不过微软这些年一直在方便开发者的工作而努力。
六、内容出处
mysql