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  .......);

猜你喜欢

转载自www.cnblogs.com/kjs-1998/p/11253324.html