接着说昨天语法中提到的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入门 数据库第二天的更多相关文章

  1. Javaweb入门 数据库第一天

    数据库概述 本菜鸟使用的数据库软件为Mariadb,以下内容都是以Mariadb数据库软件来写的学习总结. 数据库 所谓的数据库就是用于存储.管理数据的仓库,数据库根据底层存储数据结构的不同可以分为很 ...

  2. Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD

    原文:Elasticsearch7.X 入门学习第二课笔记----基本api操作和CRUD 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链 ...

  3. Mybatis最入门---数据库的下载与安装

    [一步是咫尺,一步即天涯] 近期.因为工作进度调整,之前的Spring教程就先临时告一段落了,兴许找个时间继续更新,假设有那位看官想了解某个内容的,敬请留言,大家一起学习. 作为数据库工具的使用开篇. ...

  4. JavaWeb学习总结第二篇--第一个JavaWeb程序

    JavaWeb学习总结第二篇—第一个JavaWeb程序 最近我在学院工作室学习并加入到研究生的项目中,在学长学姐的带领下,进入项目实践中,为该项目实现一个框架(用已有框架进行改写).于是我在这里记录下 ...

  5. JavaWeb入门——Tomcat的目录结构

    JavaWeb入门——Tomcat的目录结构 摘要:本文主要了解了Tomcat的目录结构. 目录结构 打开Tomcat的目录,可以看到如下文件和文件夹: bin目录 该目录下存放的是二进制可执行文件. ...

  6. JavaWeb入门——在Linux环境下安装Tomcat服务器

    JavaWeb入门——在Linux环境下安装Tomcat服务器 摘要:本文主要学习了如何在Linux环境下安装Tomcat服务器. 准备工作 检查Java环境变量 检查系统是否配置了Java的环境变量 ...

  7. JavaWeb入门——在Windows环境下安装Tomcat服务器

    JavaWeb入门——在Windows环境下安装Tomcat服务器 摘要:本文主要学习如何在Windows环境中下载并安装Tomcat服务器. 下载 获取安装包 推荐去官网上下载Tomcat: htt ...

  8. JavaWeb入门——背景知识

    JavaWeb入门——背景知识 摘要:本文主要介绍了Web服务器的相关知识. 概念 什么是JavaWeb JavaWeb,是用Java技术来解决相关Web互联网领域的技术的总称.Web包括:Web服务 ...

  9. javaweb和数据库的简易商城系统

    这是一个基于Javaweb和数据库的简易商城系统.为大二夏季小学期完成. 目录结构 主要功能截图为: 一.购买用户 1.首页(除此界面其余界面访问需要登录才能进入) 查看商品 添加购物车 查看购物车 ...

随机推荐

  1. UTM (Urchin Tracking Module) codes

    UTM Codes are a great way to see the results of your offline marketing In today’s day and age, we ar ...

  2. Storm 学习之路(三)—— Storm单机版本环境搭建

    1. 安装环境要求 you need to install Storm’s dependencies on Nimbus and the worker machines. These are: Jav ...

  3. 妹子问我maven是啥?从相亲说起。。

    自从上一篇原创文章: 第一次教妹子安装IDEA 在<java技术之家>公号发表之后,大家的好评如潮,这给了我继续写下去的信心.感谢你们的支持,我会继续努力的. 自从漂亮妹妹加入我们研发团队 ...

  4. 戏说 .NET GDI+系列学习教程(一、Graphics类--纸)

    Graphics类(纸) Graphics类封装一个GDI+绘图图面,提供将对象绘制到显示设备的方法,Graphics与特定的设备上下文关联. 画图方法都被包括在Graphics类中,在画任何对象时, ...

  5. Adboe Flash远程代码执行_CVE-2018-4878漏洞复现

    Adboe Flash远程代码执行_CVE-2018-4878漏洞复现 一.漏洞描述 该漏洞可针对windows用户发起定向攻击.攻击者可以诱导用户打开包含恶意Flash代码文件的Microsoft ...

  6. Linux下docker的安装

    前言: 因为之前在自己的mac上直接使用HomeBrew的包管理安装的,使用brew install docker即可,这种方法简单,但最近想尝试在Linux下安装,费了一些时间,主要是启动docke ...

  7. Appcan 自定义数字加减控件

    DIV部分: *这里的三个ID:as_sub_3.as_now_3.as_add_3里面的“3”可以自定义,这个对于生成任意个数的列表形式很有帮助 *cb 为执行成功后可进行回调 <div cl ...

  8. Appium+python自动化(十五)- Android 这些基础知识,你知多少???(超详解)

    简介 前边具体操作和实战已经讲解和分享了很多了,但是一些android的一些基础知识,你又知道多少了,你都掌握了吗?这篇就由宏哥给小伙伴们既是一个分享,又是对前边的一次总结.为什么要对这些做一个简单的 ...

  9. python连接 elasticsearch 查询数据,支持分页

    使用python连接es并执行最基本的查询 from elasticsearch import Elasticsearch es = Elasticsearch(["localhost:92 ...

  10. wcf服务编程(一)

    步骤一:定义契约 [ServiceContract] //定义服务契约 需要引用System.ServiceModel public interface ICalculator { [Operatio ...