Javaweb入门 数据库第二天
接着说昨天语法中提到的drop,delete和truncate的区别
drop用于删除库和表,不能用于删除表记录
delete和truncate都可以用于删除表记录,不能用于删除库和表
而delete和truncate之间的区别在:
delete可以删除表中的某一部分记录,也可以删除表中的所有记录,而且是一条一条的删除
truncate只能一次删除所有的表记录,删除时不是一条一条的删,而是删除表,再重新创建表
查询时mysql中常见的函数
ifnull(列,值)
对指定列的值判断是否为null,如果为null,就用括号后面的值进行参数替换,查询不会修改表中的值
count(列或者*)
count函数是对指定的列或者所有列统计行数,*代表所有列
max/min(列名)
max(列名)--对指定的列求最大值
min(列名)--对指定的列求最小值
sum(列)
对指定的列求和
avg(列)
对指定的列求平均值
curdate()
获取当前时间 格式:年月日
curtime()
获取当前时间 格式:时分秒
sysdate()/now()
获取当前时间 格式:年月日 时分秒
其它函数
ceil(数值)--向上取整 floor(数值)--向下取整 round(数值)--向下取整 rand(数值)--随机数
外键和表的关系
外键约束
现实生活中有很多数据间往往是有关系,比如员工和部门之间存在一定的关系,学生和老师之间也存在一定的关系,而这些关系需要我们保存起来,那么:
如何在数据库中才能保存两张表数据之间的对应关系?
通常我们可以在其中一张表中添加一个列,用来保存另外一张表的主键,从而来保存两张表的对应关系,而这个列就是这张表的外键
什么是外键
所谓的外键就是用于通知数据库两张表数据之间对应关系的一个列,数据库会通过外键来维护两张表的对应关系
指定某一列外键和不指定外键有什么区别
如果不指定外键,只是在其中一张表中添加了一个列用于保存另外一张表的主键,同样可以保存两张表之间的对应关系,只不过这段关系只有我们开发人员知道,数据库不知道两张表之间是有关系的,因此数据库不会帮我们来维护这段关系
如果指定外键,通过外键通知数据库两张表之间有对应关系,数据库就会帮我们维护这段关系,比如在指定外键后,如果想删除一个部门,数据库会在删除之前检查该部门下是否还有员工,如果有数据库就会阻止删除
添加外键的方法
创建表时添加外键

创建表过后指定外键

删除外键

表关系
一对一
比如学生在固定教室上课,那么这个教室就只对应这一个班,而这一个班也只对应这一个教室,对于一对一的两张表,可以在任意一张表中添加列,保存另外一张表的主键,从而保存两张表之间的关系
一对多或多对一
比如你对应的父亲只有一个,而你的父亲对应的孩子有几个,对于一对多或多对一的两张表,可以在多的一方添加列,保存另一方的主键,从而保存两张表之间的关系
多对多
比如上课,教你的老师有多个,而一个老师也教多个学生,对于多对多的关系,可以拆分成多张一对多的关系,无法在两张表中添加列保存关系,但我们可以添加一张第三方表(专门保存两张表的关系)保存两张表的主键,从而保存两张表的关系.
关联查询和外连接查询
笛卡尔积查询
同时查询两张表,其中一张表的记录是m条,另一张表的记录是n条,笛卡尔积查询的结果是m*n条,语法:select * from 表名,表名;
由于笛卡尔积查询的结果中包含大量错误数据,因此我们一般不会直接使用这种查询,我们可以从笛卡尔积查询的结果中通过where条件剔除错误的激励,保留正确的记录,就是我们最终想要的结果
关联查询
将两张或两张以上的表按照指定条件查询,将结果显示在一张表中
语法:select 列 from 表名,表名..... where......;
左外连接查询
显示左侧表中的所有记录,如果右侧表中没有对应的记录就显示null
语法:select 列 from a left join b on(a.id=b.id) ; on(a.id=b.id)是条件语句
右外连接查询
显示右侧表中的所有记录,如果左侧表中没有对应的记录就显示null
语法:select 列 from a right join b on(a.id=b.id) ; on(a.id=b.id)是条件语句
子查询
所谓的子查询其实就是将一个查询得出的结果,作为另外一个查询的条件
语法:select ..... from ...... where .....(select ...... from .......);
Javaweb入门 数据库第二天的更多相关文章
- Javaweb入门 数据库第一天
数据库概述 本菜鸟使用的数据库软件为Mariadb,以下内容都是以Mariadb数据库软件来写的学习总结. 数据库 所谓的数据库就是用于存储.管理数据的仓库,数据库根据底层存储数据结构的不同可以分为很 ...
- Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD
原文:Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链 ...
- Mybatis最入门---数据库的下载与安装
[一步是咫尺,一步即天涯] 近期.因为工作进度调整,之前的Spring教程就先临时告一段落了,兴许找个时间继续更新,假设有那位看官想了解某个内容的,敬请留言,大家一起学习. 作为数据库工具的使用开篇. ...
- JavaWeb学习总结第二篇--第一个JavaWeb程序
JavaWeb学习总结第二篇—第一个JavaWeb程序 最近我在学院工作室学习并加入到研究生的项目中,在学长学姐的带领下,进入项目实践中,为该项目实现一个框架(用已有框架进行改写).于是我在这里记录下 ...
- JavaWeb入门——Tomcat的目录结构
JavaWeb入门——Tomcat的目录结构 摘要:本文主要了解了Tomcat的目录结构. 目录结构 打开Tomcat的目录,可以看到如下文件和文件夹: bin目录 该目录下存放的是二进制可执行文件. ...
- JavaWeb入门——在Linux环境下安装Tomcat服务器
JavaWeb入门——在Linux环境下安装Tomcat服务器 摘要:本文主要学习了如何在Linux环境下安装Tomcat服务器. 准备工作 检查Java环境变量 检查系统是否配置了Java的环境变量 ...
- JavaWeb入门——在Windows环境下安装Tomcat服务器
JavaWeb入门——在Windows环境下安装Tomcat服务器 摘要:本文主要学习如何在Windows环境中下载并安装Tomcat服务器. 下载 获取安装包 推荐去官网上下载Tomcat: htt ...
- JavaWeb入门——背景知识
JavaWeb入门——背景知识 摘要:本文主要介绍了Web服务器的相关知识. 概念 什么是JavaWeb JavaWeb,是用Java技术来解决相关Web互联网领域的技术的总称.Web包括:Web服务 ...
- javaweb和数据库的简易商城系统
这是一个基于Javaweb和数据库的简易商城系统.为大二夏季小学期完成. 目录结构 主要功能截图为: 一.购买用户 1.首页(除此界面其余界面访问需要登录才能进入) 查看商品 添加购物车 查看购物车 ...
随机推荐
- 七、Linux磁盘管理及LVM讲解
1.硬盘接口 IDE:家用产品,也部分应用于服务器 SATA:一般使用 SCSI:服务器市场 SAS:高端服务器上,价格昂贵 2.硬盘种类 SATA硬盘: SCSI硬盘: SAS硬盘: 3.分区 ...
- Spring 5.x 、Spring Boot 2.x 、Spring Cloud 与常用技术栈整合
项目 GitHub 地址:https://github.com/heibaiying/spring-samples-for-all 版本说明: Spring: 5.1.3.RELEASE Spring ...
- 10月18日 JS begant
1.JS的本质就是处理数据,数据来自后台的数据库,所以变量起到了临时存储的作用, ES制定了js的数据类型 2.数据类型有哪些? (1)字符串 String (2)数字 Number (3)布尔 B ...
- F#周报2019年第27期
新闻 介绍Femto--使用Fable绑定的自动化npm包解决方案 Babel 7.5.0发布,包含动态导入与F#管道 iOS 13预览版发布 视频及幻灯片 Fabulous--F#用于跨平台移动应用 ...
- js深入(四)万脸懵圈的this指向
作为一个js菜鸡的我而言,在之前讲到过那么多的js链式查找机制,比如说原型链,作用域链等等,想当然的把这个机制带入到了this指向上边,结果就是这个this指向指的我万脸懵逼(标题换字了,担心被河蟹) ...
- ajax 的简单请求,get的加法运算,post加法运算,用户登录认证
视图函数部分 from django.shortcuts import render, HttpResponse import time from app01.models import User i ...
- C语言学习书籍推荐《C Primer Plus(中文版)(第5版)》下载
普拉塔 (Prata S.) (作者), 云巅工作室 (译者) <C Primer Plus(中文版)(第5版)>共17章,介绍了C语言的基础知识,包括数据类型.格式化输入输出.运算符.表 ...
- 利用iisnode模块,让你的Node.js应用跑在Windows系统IIS中
最近比较喜欢用Node.js做一些简单的应用,一直想要部署到生产环境中,但是手上只有一台windows server 2008服务器,并且已经开启了IIS服务,运行了很多.Net开发的网站,80端口已 ...
- 一个超级简单的Jetty实例
Maven: <!-- https://mvnrepository.com/artifact/org.mortbay.jetty/jetty --> <dependency> ...
- Spring Cloud Alibaba | Sentinel: 服务限流基础篇
目录 Spring Cloud Alibaba | Sentinel: 服务限流基础篇 1. 简介 2. 定义资源 2.1 主流框架的默认适配 2.2 抛出异常的方式定义资源 2.3 返回布尔值方式定 ...