一、库的基本操作
# 前提: 连接上数据库
1)查看已有数据库
mysql>: show databases;
2)选择某个数据库
mysql>: use 数据库名
3)查看当前所在数据库
mysql>: select database();
4)创建数据库
mysql>: create database 数据库名 [charset=编码格式];
eg>: create database owen;
eg>: create database zero charset=utf8;
5)查看创建数据库的详细内容
mysql>: show create database 数据库名;
eg>: show create database owen;
6) 修改数据库编码集
mysql>: alter database 数据库名 charset="字符集";
eg>: alter database db1 charset="utf8";
6)删除数据库
mysql>: drop database 数据库名;
eg>: drop database db1;
二、表的基本操作
# 前提:先选取要操作的数据库
1)查,查看表信息
纵观所有数据库: show tables;
详细信息: show create table 表名;
查看创建表的结构: desc 表名;
2)增,创建表
mysql>: create table 表名(字段们);
eg>: create table student(name varchar(16), age int);
3)改,修改表结构
修改字段属性: alter table 表名 modify 字段名 字段属性;
eg>: alter table t1 modify name char(20);
修改字段名: alter table 表名 change 旧字段名 新字段名 新字段属性;
eg>: alter table t1 change name usr char(16);
修改表名: alter table 表名 rename 新表名;
eg>: alter table t1 rename t2;
# 添加一个新字段: 根据相对位置添加新字段:
mysql>: alter table 表名 add 字段名 类型[(长度) 约束]; # 末尾
eg>: alter table tf1 add z int unsigned;
mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] first; # 首位
eg>: alter table tf1 add a int unsigned first;
mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] after 旧字段名; # 添加在表已有字段之后
eg>: alter table tf1 add xx int unsigned after x;
# 删除字段
mysql>: alter table 表名 drop 字段名;
eg>: alter table tf1 drop a;
4)删, 删除表
mysql>: drop table 表名;
eg>: drop table teacher;
# 删除表字段
mysql>: alter table 表名 drop 字段名; # 删除字段
eg>: alter table tf1 drop a;
三、字段的基本操作
1)查,查看某个数据库中的某个表的所有记录,如果在对应数据库中,可以直接查找表
mysql>: select * from [数据库名.]表名;
注:*代表查询所有字段
模糊查询:like,_代表任意一个字符,%0个或多个任意字符
mysql>: select * from [数据库名.]表名 where 字段名 like "模糊查询的内容";
eg: select * from t2 where name like "xc%";
2)增,给表的所有字段插入数据
mysql>: insert [into] [数据库名.]表名 values (值1,...,值n);
eg:如果给有name和age两个字段的student表插入数据
1条>:insert into student values ('Bob', 18);
多条>:insert into student values ('张三', 18), ('李四', 20);
指定库>:insert owen.student values ('张三', 18), ('李四', 20);
3)改,根据条件修改指定内容
mysql>: update [数据库名.]表名 set 字段1=新值1, 字段n=新值n where 字段=旧值;
eg:> update student set name='王五', age='100' where name='张三';
注:i) 可以只修改部分字段 ii) 没有条件下,所有记录都会被更新
eg:> update student set name='呵呵';
4)删,根据条件删除记录
mysql>: delete from [数据库名.]表名 where 条件;
eg:> delete from student where age<30;
四、数据库表的引擎:驱动数据的方式 - 数据库优化
可以通过设置myisam来优化数据库
# 前提: 引擎是建表是规定, 提供给表使用的, 不是数据库
# 展示所有引擎
mysql> show engines;
# innodb(默认): 支持事务, 行级锁, 外键
mysql>: create table t11(id int)engine=innodb;
# myisam: 查询效率要优于innodb, 当不需要支持事务, 行级锁, 外键, 可以通过设置myisam来优化数据库
mysql>: create table t12(id int)engine=myisam;
# blackhole:黑洞,存进去的数据都会消失(可以理解不存数据)
mysql>: create table t13(id int)engine=blackhole;
# memory:表结构是存储在硬盘上的,但是表数据全部存储在内存中
mysql>: create table t14(id int)engine=memory;
五、创建表的完整语法
create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
)engine=innodb charset=utf8;
# []可选参数
create table db1.t1(name char(3) not null);
# 数据插入时,name不能为空(null), 且最长只能存放三个字符
# 总结: 宽度和约束条件为可选参数, 用来限制存放数据的规则
六、数据库的模式(**)
# mysql 5.7 以后默认都是安全模式
# mysql 5.6 版本
sql_model=no_engine_substitution # 非安全性,默认
sql_model=strict_trans_tables # 安全性
# 查看当前数据库模式:
show variables like "%sql_mode%"; # %匹配0~n个任意字符 => 模糊查询
# 临时设置为安全模式,服务重启后会被重置
mysql>: set global sql_mode="strict_trans_tables"; # 在root用户登录状态下
# 在设置后,quit断开数据库连接后(服务器不重启)就会进入安全模式
# 安全模式下,非安全模式下sql执行的警告语句,都会抛异常
eg>: create table t1(name char(2));
eg>: insert into t1 values ("ab") # 正常
eg>: insert into t1 values ("owen") # 错误 Data too long for column 'name' at row 1