数据库(学习笔记 10) ------ 数据库中表的关系以及如何用javabean实现

目录:

什么是1:n

什么是n:m

这两种关系在数据库中怎么实现的(外键/第三张表)

如何用javabean实现?

如何用hibernate实现?(参考:待更新)


数据库中表的关系就是三种:1:1  1:n  n:m

针对1:1在此处不会详细说明,可以参考:https://blog.csdn.net/lengjinghk/article/details/52140276


1、1:n

1.1 什么是1:n关系,就是一对多关系,就好像一个老师管理多个学生,一个人有多台车。其中老师和人就是1那方,但是学生和车就是n的那方。如果用一个表把1:n的关系表示出来,就会出现冗余数据,因此需要两个表,在多的一方创建一个外键连接两个表。

如果一个表表示车和人的关系如图:

数据存在冗余,所以应该分成person和car两个表格,并且用person_id作为关联。


用两个表表示如图:


1.2 sql语句如下:



解释:在car的一方设置了一个外键。就可以实现表的一对多的关系。

具体关于外键的讲解在这篇文章中,有关外键的创建和如何插入数据。

参考:https://blog.csdn.net/qq_36098284/article/details/79733501


1.3 javabean实现(两个class没有写构造函数)

你要搞明白,是给谁的class增加了set集合。是给1的那方增加了一个set集合,如果要给一个car添加一个所有者,就是要先有一个person对象的实例,然后person.getCar().add(new car());  添加成功。可以在数据库中测试。




2、n:m

2.1 什么是n:m关系?

      就是多对多关系。比如一个学生可以选多门课,课程可以由不同的学生选择。课程和学生的这两个实体就是多对多的关系。

       在表的实现上,需要借助第三张表关联。而这第三张表有两个特殊的要求

        第一:第三张表的主键必须包含两边表的主键。(就是sc的主键必须包含学生表和课程表的主键的id)。

        第二:引入的表要引入两边表的主键作为外键。


2.2 sql语句








2.3 javabean的实现----在student和course中,分别添加了set<T>集合。用于显示有多少学生选择了这门课和一个学生选择了多少门课。要注意最后的test.java。

(我另一个文章在写hibernate如何实现表的关系时会贴出自己的代码,现在引用一个人写好的代码。是正确的。)

import java.util.*;  
  2  // 定义学生类 
  3 class Student {    
  4         private String name ; 
  5         private int age ;    
  6         private List<Course> allCourses ;   // 定义集合保存全部课程  
  7         public Student(){// 无参构造  
  8             this.allCourses = new ArrayList<Course>() ;// 实例化List集合  
  9         }  
 10         public Student(String name,int age){ // 通过构造设置属性内容  
 11             this() ; // 调用无参构造  
 12             this.setName(name) ;   // 设置name属性内容  
 13             this.setAge(age) ; // 设置age属性内容  
 14         }  
 15         public String getName() {
 16             return name;  
 17         }  
 18         public void setName(String name) {
 19             this.name = name;  
 20         }  
 21         public int getAge() {
 22             return age;  
 23         }  
 24         public void setAge(int age) {
 25             this.age = age;  
 26         }  
 27         public List<Course> getAllCourses() { // 取得全部课程  
 28             return allCourses;  
 29         }  
 30         public String toString(){ // 覆写toString()方法  
 31             return "学生姓名:" + this.name + ";年龄:" + this.age ;  
 32         }  
 33     } 
 34 
 35 
 36 //在学生类中存在一个allCourses的List集合,这样在程序运行时,一个学生类中可以保存多个Course对象。
 37 
 38 //定义课程类
 39 class Course {  
 40         private String name ;   // 
 41         private int credit ;      // 定义学分  
 42         private List<Student> allStudents ; // 定义集合保存多个学生  
 43         public Course(){    // 无参构造方法  
 44             this.allStudents = new ArrayList<Student>() ;// 实例化List集合  
 45         }  
 46         public Course(String name,int credit){   // 
 47             this() ;  
 48             this.setName(name) ; 
 49             this.setCredit(credit) ;   
 50         }  
 51         public String getName() {   
 52             return name;  
 53         }  
 54         public void setName(String name) {    
 55             this.name = name;  
 56         }  
 57         public int getCredit() {     
 58             return credit;  
 59         }  
 60         public void setCredit(int credit) {  
 61             this.credit = credit;  
 62         }  
 63         public List<Student> getAllStudents() {  // 得到全部学生  
 64             return allStudents;  
 65         }  
 66         public void setAllStudents(List<Student>allStudents) {// 设置全部学生  
 67             this.allStudents = allStudents;  
 68         }  
 69         public String toString(){   
 70             return "课程名称:" + this.name + ";课程学分" + this.credit ;  
 71         }  
 72     } 
 73 
 74 //课程类与学生类一样,都定义了一个List集合,用于保存多个学生信息。
 75 
 76 
 77 
 78    
 79     public class TestMore {  
 80         public static void main(String args[]) {  
 81             Course c1 = new Course("英语", 3); // 实例化课程对象  
 82             Course c2 = new Course("计算机", 5); 
 83             Student s1 = new Student("张三", 20);  // 实例化学生对象  
 84             Student s2 = new Student("李四", 21);  
 85             Student s3 = new Student("王五", 22);   
 86             Student s4 = new Student("赵六", 23); 
 87             Student s5 = new Student("孙七", 24);  
 88             Student s6 = new Student("钱八", 25);  
 89             // 第一门课程有3个人参加,向课程中增加3个学生信息,同时向学生中增加课程信息  
 90             c1.getAllStudents().add(s1);  // 向课程增加学生信息  
 91             c1.getAllStudents().add(s2);  
 92             c1.getAllStudents().add(s6); 
 93             s1.getAllCourses().add(c1);  // 向学生中增加课程信息  
 94             s2.getAllCourses().add(c1);  
 95             s6.getAllCourses().add(c1);
 96             // 第二门课程有6个人参加,向课程中增加6个学生信息,同时向学生中增加课程信息  
 97             c2.getAllStudents().add(s1); // 向课程增加学生信息  
 98             c2.getAllStudents().add(s2);    
 99             c2.getAllStudents().add(s3);
100             c2.getAllStudents().add(s4); 
101             c2.getAllStudents().add(s5); 
102             c2.getAllStudents().add(s6); 
103             s1.getAllCourses().add(c2);// 向学生中增加课程信息  
104             s2.getAllCourses().add(c2);
105             s3.getAllCourses().add(c2); 
106             s4.getAllCourses().add(c2);  
107             s5.getAllCourses().add(c2); 
108             s6.getAllCourses().add(c2); 
109             // 输出一门课程的信息,观察一门课程有多少个学生参加  
110             System.out.println(c1); // 输出第一门课程信息  
111             Iterator<Student> iter1 = c1.getAllStudents().iterator();  
112             while (iter1.hasNext()) { // 迭代
113                 Student s = iter1.next();// 取出学生对象  
114                 System.out.println("\t|- " + s); // 输出学生信息  
115             }  
116             // 输出一个学生参加的课程信息,观察有多少门课程  
117             System.out.println(s6); // 输出学生信息  
118             Iterator<Course> iter2 = s6.getAllCourses().iterator();  
119             while (iter2.hasNext()) {  // 迭代
120                 Course c = iter2.next(); // 取得所参加的课程  
121                 System.out.println("\t|- " + c); // 输出课程信息  
122             }  
123         }  
124     }
125 ---------- java ----------
126 课程名称:英语;课程学分3
127     |- 学生姓名:张三;年龄:20
128     |- 学生姓名:李四;年龄:21
129     |- 学生姓名:钱八;年龄:25
130 学生姓名:钱八;年龄:25
131     |- 课程名称:英语;课程学分3
132     |- 课程名称:计算机;课程学分5
133 
134 输出完成 (耗时 0 秒) - 正常终止
复制代码


参考:https://www.cnblogs.com/xscn/archive/2013/08/09/3249274.html


  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值