MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
- 数据库: 数据库是一些关联表的集合。
- 数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。
- 列: 一列(数据元素) 包含了相同类型的数据, 例如邮政编码的数据。
- 行:一行(=元组,或记录)是一组相关的数据,例如一条用户订阅的数据。
- 冗余:存储两倍数据,冗余降低了性能,但提高了数据的安全性。
- 主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。
- 外键:外键用于关联两个表。
- 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引。
- 索引:使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构。类似于书籍的目录
分享下面的简单实例,使用终端操作mysql数据库,并对数据进行基本的增删改查,筛选以及计数。(学生表和成绩表)
下面上表:
A.查询姓王的学生的个数 B.查询数学比语文成绩高的所有学生的学号
用管理员身份运行cmd
运行数据库:net start mysql
连接本地数据库:mysql -u root -p 输入密码连接
展示数据库:show databases;(sql语句一定要+分号,且符号一定要使用英文格式)
选择数据库:use 数据库名;
展示表:show tables;
查询表:select * from 表名;(*在这里表示所有字段)
1.增:insert into 表名(字段1,字段2,字段3)values(值1,值2,值3);必填字段必须写。
2.删:delete from 表名 where 字段=值;
3.改: update 表名 set 字段1 = 值,字段2 = 值 where 条件; (条件写明你要改哪一条数据)
4.查:select * from 表名;(*代表所有的字段名)
5.判断符: = != >= <= in is between like (均可以取反not)
In(在不在一个集合内)select * from 表名 where 字段 in(值);
is(判断类型 一般判断是否为空null)select * from 表名 where 字段 is null;
between(介于两者之间,数字) select * from 表名 where 字段 not between 值 and 值
like(范围,包含或不包含,仅字符串)select * from 表名 where 字段 like 值;(%)
- 某某% 某某开头
- %某某 某某结束
- %某某% 包含某某
6.逻辑链接符: and or (可以取反 not)
7.多表联查:select * from 表1 join 表2 on 表1.字段1=表2.字段2;
8.聚合函数: count 计数 Avg 求平均 MAX 最大值 MIN 最小值 Sum 求和
在对表进行查询以及增删改的操作后,我们主要来完成筛选和计数,也就是查的操作
A.查询姓王的同学的个数
输入:select count(*) from t_student where sname like ('王%'); 查询表中姓王的同学,并对其进行计数。这里结合了聚合函数和查询的命令
B.查询数学比语文成绩高的学生的学号
这里可以将成绩表和学生表进行一个多表联查
输入:select * from t_student join t_grade on tstudent.id = t_grade.sid;(学生表中的id,就是成绩表中的sid)
在其中筛选数学比语文成绩高的同学.
输入:select * from t_student join t_grade on t_student.id = t_grade.sid where math > chinese;
这里只需要学号,所以我们将*(所有字段)改成只显示学生表的id字段.同时附带他们的语文数学成绩.
输入: select t_student.id,t_grade.math,t_grade.chinese from t_student join t_grade on t_student.id = t_grade.sid where math > chinese;
这里如果觉得命令太长的话,有一个小技巧,可以用as给表取别名:表名+as+别名 (as可以省略)那么上一条命令就变成了
select a.id,b.math,b.chinese from t_student a join t_grade b on a.id = b.sid where math > chinese;(是不是短了一点~)
萌新一枚,欢迎大佬指错~~~