一文读懂navicat for mysql基础知识


Posted in MySQL onMay 31, 2021

一、数据库的操作

1、新建数据库

一文读懂navicat for mysql基础知识

2、打开数据库

右键或者双击就可以了。

3、删除数据库

右键?>删除数据库

4、修改数据库

右键?>数据库属性

二、数据类型

1、常用的数据类型

整数:int
小数:decimal
字符串:varchar
日期时间:datatime

2、约束条件

主键:物理上储存的顺序(主键唯一、不能为空,所以允许空值的勾得去掉,不然不能新建或保存,还可以选择下面注释中得自动递增节省工作量)

一文读懂navicat for mysql基础知识

非空:此字段不允许填空值
唯一:此字段不允许重复

默认值:当不填写时会使用默认值,如果填写以填写的值为止。
外键:维护两个表之间的关联关系

三、备份和恢复

备份:右键?>转储为SQL文件
恢复:右键运转SQl文件

一文读懂navicat for mysql基础知识

三、操作动作

1、简单查询

语法:

select 字段 form 表名 where 条件;

通过as给表和字段取别名:select name as n from students as s;

消除重复行:select distinct * from students;

比较运算符:

等于:=
大于:>
大于等于:>=
小于: <
小于等于:<=
不等于:!=或<>

逻辑运算符:

与:and
或:or
非:not

模糊查询:

like
%表示任意多个任意字符
表示一个任意字符
例1:查询姓孙的学生
select * from students where name like ‘孙%';
例2:查询姓孙且名字是一个字的学生
select * from students where name like '孙
'

范围查询:

in表示在一个非连接的范围内;
例1:查询家乡是北京或上海或广东的学生
select * from students where hometown in(‘北京',‘上海',‘广东');
between…and…表示在一个连续的范围内
例2:查询年龄为18至28的学生
select * from students where age between 18 and 28;
空判断:
注意:null与''是不同的
判断is null
例1:查询没有填写身份证的学生
select * from students where card is null;
判非空is not null
select * from students where card is not null;

排序:

语法:select * from 表名 order by 列1 asc|desc,列1 asc|desc…;
默认按照列值从小到大排列
asc从小到大排序,即升序。
desc从大到小排序,即降序。

聚合函数:

1、count(*)表示计算总行数,括号中写星和列名结果一样。
聚合函数不能再where中使用
例1:查询学生总数
select count(*) from students;
2、max(列)表示求此列的最大值
例2:查询女生的最小年龄
select max(age) from students where sex=‘女';
3、min(列)表示此列最小值
例:查询1班最大的年龄
select min(age) from students where 班级=‘1'
4、sum(列)表示求此列的和
select sum(age) from students
5、avg(列)表示求此列的平均值
select avg(age) from students

分组:

1、按照字段分组,表示此字段相同的数据会被放到一个组中
2、分组后,分组的依据列会显示在结果集中,其他列不会显示在结果集中
3、可以对分组后的数据进行统计,做聚合运算
语法:
select 列1,列2,count(*) from 表名 group by/having 列1,列2
having后面的条件运算符与where的相同
对比where与having
1、where是对from后面指定的表进行数据筛选,属于对原始数据的筛选
2、having是对group by 的结果进行筛选

分页查询:获取部分行

1、当数据过大时,在一页中查看数据是一件非常麻烦的事情
2、语法:
select * from limit start,count;
2.1 从start开始,获取count条数据。
2.2 start索引从0开始
例1:查询前3行学生信息
select * from students limit 0,3;
分页:
1、已知:每页显示m条数据,求:显示第n页的数据
select * from students limit (n-1)*m,m;
2、求总页数
查询总条数p1
使用p1除以m得到p2
如果整除则p2为总数页
如果不是整数则p2+1为总页数

连接查询:

1、当查询结果得列来自于多张表时,需要将多张表连接成一个大的数据集,再选择合适的列返回
2、等值连接查询:查询的结果为两个表匹配到的数据
3、左连接查询:查询结果为两个表匹配到的数据加左表特有的数据,对于右表中不存在的数据使用null
4、右连接查询:查询结果为两个表匹配到的数据加右表特有的数据,对于左表中不存在的数据使用null

等值连接:

方式1:select * from 表1,表2 where 表1.列=表2.列;
方式2(又称内连接): select * from 表1 inner join 表2 on 表1.列=表2.列;
方式3(表内连接):select * from 表1,表2,表3 where 表1.列=表2.列 and 表2=表3;
方式4(又称左连接): select * from 表1 left join 表2 on 表1.列=表2.列;
方式5(又称右连接): select * from 表1 right join 表2 on 表1.列=表2.列;

主查询:

主要查询的对象,第一条select语句

子查询:

在第一个select语句中嵌入了另一个select语句,那么嵌套的select语句称之为子查询

主查询和子查询的关系:

1、子查询时嵌入到主查询中
2、子查询是辅助主查询的,要么充当条件,要么充当数据源
3、子查询是可以独立存在的语句,是一条完整的select语句

子查询分类:

1、标量子查询:子查询返回的结果是一个数据(一行一列)
2、列子查询:返回的结果是一列(一列多行)
3、行子查询:返回的结果是一行(一行多列)
4、表级子查询:返回的结果是多行多列
标量子查询:
例1:查询班级学生的平均年龄
select avg(age) from students;
列子查询:
例1:查询18岁的学生学号
select studentno from students where age=18;
行级查询:
例1:查询男生中年龄最大的学生信息
select max(age) from students where sex=‘男';

2、插入数据

语法:
insert into 表名 values(…)
插入多条:insert into 表名 values(…),(…)

3、删除数据

语法:
delete from 表名 where 条件

4、修改/更新数据

语法:
update 表名 set 列1=值1,列2=值2… where 条件

四、高级

视图:

1、对于复杂的查询,在很多地方被使用,如果需求发生了改变,需要更改sql语句,则需要在多个地方进行修改,维护起来非常麻烦。
2、解决:定义视图。
3、视图本质就是对查询的封装
4、定义视图,建议以V_开头
select view 视图名称 as select 语气;
查看视图:查看表会将所有的视图也列出来

show tables;

删除视图:

drop view 视图名称;

使用:视图的用途就是查询
select * from 视图名称;

索引:

语法:
查看索引:show index from 表名;

外键:

一个外键的值一定是另一个表的主键,在设置主键以前,必须先将两个表选项中的引擎修改为InnoDB:

一文读懂navicat for mysql基础知识

然后设置外键:

一文读懂navicat for mysql基础知识

注意:外键所在的表不能设置主键

唯一:

设置唯一后,数据能出现重复的数据。

一文读懂navicat for mysql基础知识

输入重复的数据就会报错:

一文读懂navicat for mysql基础知识

五、知识补充

ctr+/ 注释作用
笛卡尔积=两个表数据个数相乘

以上就是一文读懂navicat for mysql基础知识的详细内容,更多关于navicat mysql基础的资料请关注三水点靠木其它相关文章!

MySQL 相关文章推荐
MySQL8.0.24版本Release Note的一些改进点
Apr 22 MySQL
教你解决往mysql数据库中存入汉字报错的方法
May 06 MySQL
Unity连接MySQL并读取表格数据的实现代码
Jun 20 MySQL
浅谈MySQL之浅入深出页原理
Jun 23 MySQL
MySQL非空约束(not null)案例讲解
Aug 23 MySQL
MySQL令人大跌眼镜的隐式转换
Aug 23 MySQL
解决Mysql多行子查询的使用及空值问题
Jan 22 MySQL
面试中老生常谈的MySQL问答集锦夯实基础
Mar 13 MySQL
MySQL创建表操作命令分享
Mar 25 MySQL
MySQL磁盘碎片整理实例演示
Apr 03 MySQL
MySQL创建管理HASH分区
Apr 13 MySQL
MySQL自定义函数及触发器
Aug 05 MySQL
Mysql数据库索引面试题(程序员基础技能)
MySQL CHAR和VARCHAR该如何选择
May 31 #MySQL
带你学习MySQL执行计划
May 31 #MySQL
MySQL完整性约束的定义与实例教程
MySQL注入基础练习
解决Navicat for MySQL 连接 MySQL 报2005错误的问题
MYSQL(电话号码,身份证)数据脱敏的实现
May 28 #MySQL
You might like
php中使用base HTTP验证的方法
2015/04/20 PHP
详细分析PHP 命名空间(namespace)
2020/06/30 PHP
JavaScript 判断指定字符串是否为有效数字
2010/05/11 Javascript
一个封装js代码-----展开收起效果示例
2013/07/03 Javascript
一段非常简单的js判断浏览器的内核
2014/08/17 Javascript
jQuery插件EnPlaceholder实现输入框提示文字
2015/06/05 Javascript
Angularjs整合微信UI(weui)
2016/03/15 Javascript
jQuery实现的右下角广告窗体跟随效果示例
2016/09/16 Javascript
WebPack基础知识详解
2017/01/16 Javascript
javascript中的面向对象
2017/03/30 Javascript
JS作用域链详解
2017/06/26 Javascript
微信小程序模版渲染详解
2018/01/26 Javascript
webstorm添加*.vue文件支持
2018/05/08 Javascript
17道题让你彻底理解JS中的类型转换
2019/08/08 Javascript
微信小程序实现写入读取缓存详解
2019/08/30 Javascript
使用Vue实现调用接口加载页面初始数据
2019/10/28 Javascript
vue 导航内容设置选中状态样式的例子
2019/11/01 Javascript
python查看FTP是否能连接成功的方法
2015/07/30 Python
python如何实现int函数的方法示例
2018/02/19 Python
修复 Django migration 时遇到的问题解决
2018/06/14 Python
Python第三方库h5py_读取mat文件并显示值的方法
2019/02/08 Python
Python3实现从排序数组中删除重复项算法分析
2019/04/03 Python
python requests证书问题解决
2019/09/05 Python
python__name__原理及用法详解
2019/11/02 Python
PyCharm+Pipenv虚拟环境开发和依赖管理的教程详解
2020/04/16 Python
Python实现自动打开电脑应用的示例代码
2020/04/17 Python
150行python代码实现贪吃蛇游戏
2020/04/24 Python
Python DES加密实现原理及实例解析
2020/07/17 Python
国外平面设计素材网站:The Hungry JPEG
2017/03/28 全球购物
美国奢侈品购物平台:Orchard Mile
2018/05/02 全球购物
小学生作文评语集锦
2014/12/25 职场文书
红色故事汇观后感
2015/06/18 职场文书
篮球赛闭幕式主持词
2015/07/03 职场文书
工作自我评价范文
2019/03/21 职场文书
Go 实现英尺和米的简单单位换算方式
2021/04/29 Golang
Python使用pyecharts控件绘制图表
2022/06/05 Python