1、将 E-R 图转换为关系模型的转换规则如下:1) 实体集转换为关系实体集对应于一个关系关系名:与实体集同名。属性:实体集的所有属性。主码:实体集的主码。2) 联系转换为关系联系转换成为关系模式。联系转换成为关系模式时,要根据联系方式的不同采用不同的转换方式1:1 联系的转换方法a) 将 1:1 联系转换为一个独立的关系:与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,且每个实体的码均是该关系的候选码。b) 将 1:1 联系与某一端实体集所对应的关系合并,则需要在被合并关系中增加属性,其新增的属性为联系本身的属性和与联系相关的另一个实体集的码。 1:n 联系的转换方法a)一种方法是
2、将联系转换为一个独立的关系,其关系的属性由与该联系相连的各实体集的码以及联系本身的属性组成,而该关系的码为 n 端实体集的码;b)另一种方法是在 n 端实体集中增加新属性,新属性由联系对应的 1 端实体集的码和联系自身的属性构成,新增属性后原关系的码不变。 m:n 联系的转换方法产1产产 品 号 产 品 名 价 格1产职 工 号 姓 名 年 龄产 品 号 产 品 名 价 格职 工 号 姓 名 年 龄 第一步:联系形成的关系独立存在:职工表(职工号,姓名,年龄)主码:职工号产品表(产品号,产品名,价格)主码:产品号负责(职工号,产品号)主码:职工号或产品号合并方案 1:“负责”与“职工” 两关系
3、合并:职工(职工号,姓名,年龄,产品号)产品(产品号,产品名,价格)合并方案 2:“负责”与“产品” 两关系合并:职工(职工号,姓名,年龄)产品(产品号,产品名,价格,职工号)产n产产 品 号 产 品 名 价 格1产仓 库 号 地 点 面 积 数 量产 品 号 产 品 名 价 格仓 库 号 地 点 面 积 数 量 步骤一:联系形成的关系独立存在。 仓库(仓库号,地点,面积) 主码:仓库号产品(产品号,产品名,价格) 主码:产品号仓储(仓库号,产品号,数量)主码:产品号合并后方案:联系形成的关系与 n 端对象合并。仓库(仓库号,地点,面积) 产品(产品号 ,产品名,价格,仓库号,数量)在向关系模
4、型转换时,一个 m:n 联系转换为一个关系。转换方法为:与该联系相连的各实体集的码以及联系本身的属性均转换为关系的属性,新关系的码为两个相连实体码的组合(该码为多属性构成的组合码) 。import java.awt.*;import java.awt.event.*;import javax.swing.*;public class CalculatorJFrame extends JFrame implements ActionListenerprivate JTextField text; /显示计算结果的文本行private char op; /当前运算符private float va
5、lue; /当前计算结果值private boolean first; /表示是否为数值的第 1 个数字public CalculatorJFrame()super(“计算器“);this.setSize(280,210);this.setLocation(300,240);this.display(); /显示图形用户界面this.setDefaultCloseOperation(EXIT_ON_CLOSE);this.setVisible(true);op=+;value=0.0f;first=true;private void display() /图形用户界面text = new JT
6、extField(“0.“,30);text.setHorizontalAlignment(JTextField.RIGHT); /设置对齐方式,右对齐text.setEditable(false); /只能显示,不允许编辑this.getContentPane().add(text,“North“);学 生课 程课 程 号 学 分 课 程 名成 绩mn姓 名 性 别学 生 年 龄选 课学 生课 程课 程 号 学 分 课 程 名成 绩姓 名 性 别学 生 年 龄选 课 该模型包含两个实体集(学生、课程)和一个 m:n 联系该模型可转换为三个关系模式:学生(学号,姓名,性别,年龄)主码:学号-课
7、程( 课程号 ,课程名,学分)主码:课程号选课(学号,课程号,成绩)主码:学号+课程号JPanel panel = new JPanel(new GridLayout(5,4,5,5);/面板采用网格布局this.getContentPane().add(panel);String str=“sqrt“,“+/-“,“Backspace“,“C“,“7“,“8“,“9“,“/“,“4“,“5“,“6“,“*“,“1“,“2“,“3“,“-“,“0“,“.“,“=“,“+“;JButton buttons = new JButtonstr.length;for (int i=0; i=0 fir
8、st = false;text.setText(text.getText()+current);elseSystem.out.print(“+value+op+text.getText()+“=“);switch (op)case +: value += Float.parseFloat(text.getText();break; /转换成浮点数后运算 case -: value -= Float.parseFloat(text.getText();break;case *: value *= Float.parseFloat(text.getText();break;case /: value /= Float.parseFloat(text.getText();break; System.out.println(“+value);text.setText(“+value);op = current.charAt(0); /字符串中取第 1 个字符first = true;public static void main(String arg)new CalculatorJFrame();