zoukankan      html  css  js  c++  java
  • MySQL:多表概述

    1.  多表简述

          实际开发中,一个项目通常需要很多张表才能完成。

          例如一个商城项目的数据库,需要有很多张表:用户表、分类表、商品表、订单表.... 

    2.  单表的缺点 

    数据准备

    1) 创建一个数据库 db3

    CREATE DATABASE db3 CHARACTER SET utf8;

    2) 数据库中 创建一个员工表 emp

      包含如下列 eid, ename, age, dep_name, dep_location

      eid 为主键并 自动增长, 添加 5 条数据

    -- 创建emp表 主键自增 
    CREATE TABLE emp(
        eid INT PRIMARY KEY AUTO_INCREMENT,
        ename VARCHAR(20),
        age INT , 
        dep_name VARCHAR(20), 
        dep_location VARCHAR(20) 
    );
    -- 添加数据  
    INSERT INTO emp (ename, age, dep_name, dep_location) VALUES ('张百万', 20, '研发部', '广州'); 
    INSERT INTO emp (ename, age, dep_name, dep_location) VALUES ('赵四', 21, '研发部', '广州');  
    INSERT INTO emp (ename, age, dep_name, dep_location) VALUES ('广坤', 20, '研发部', '广州');  
    INSERT INTO emp (ename, age, dep_name, dep_location) VALUES ('小斌', 20, '销售部', '深圳');  
    INSERT INTO emp (ename, age, dep_name, dep_location) VALUES ('艳秋', 22, '销售部', '深圳');  
    INSERT INTO emp (ename, age, dep_name, dep_location) VALUES ('大玲子', 18, '销售部', '深圳'); 

    3) 单表的问题

         冗余, 同一个字段中出现大量的重复数据

      

     

    3. 解决方案 

    设计为两张表

    <1> 多表方式设计

        department  部门表 :  id,   dep_name, dep_location 

        employee 员工表:   eid,  ename,  age,  dep_id

    <2> 删除emp表, 重新创建两张表

    -- 创建部门表 
    -- 一方,主表 
    CREATE TABLE department(
         id INT PRIMARY KEY AUTO_INCREMENT,
         dep_name VARCHAR(30),
         dep_location VARCHAR(30) 
    );
    
    -- 创建员工表 
    -- 多方 ,从表 
    CREATE TABLE employee(
        eid INT PRIMARY KEY AUTO_INCREMENT, 
        ename VARCHAR(20),
        age INT,
        dept_id INT 
    );

    <3> 添加部门表数据

    -- 添加2个部门 
    INSERT INTO department VALUES(NULL, '研发部','广州'),(NULL, '销售部', '深圳'); 
    SELECT * FROM department;

    <4> 添加员工表数据

    -- 添加员工,dep_id表示员工所在的部门 
    INSERT INTO employee (ename, age, dept_id) VALUES ('张百万', 20, 1); 
    INSERT INTO employee (ename, age, dept_id) VALUES ('赵四', 21, 1); 
    INSERT INTO employee (ename, age, dept_id) VALUES ('广坤', 20, 1); 
    INSERT INTO employee (ename, age, dept_id) VALUES ('小斌', 20, 2); 
    INSERT INTO employee (ename, age, dept_id) VALUES ('艳秋', 22, 2); 
    INSERT INTO employee (ename, age, dept_id) VALUES ('大玲子', 18, 2); 
    SELECT * FROM employee;

    <5> 表关系分析   

    部门表与员工表的关系

       1) 员工表中有一个字段dept_id 与部门表中的主键对应,员工表的这个字段就叫做 外键   

       2) 拥有外键的员工表 被称为 从表 , 与外键对应的主键所在的表叫做 主表

     

    4. 目前的多表设计的问题    

        当我们在 员工表的 dept_id 里面输入不存在的部门id ,数据依然可以添加!

        显然,这是不合理的.

    -- 插入一条 不存在部门的数据 
    INSERT INTO employee (ename,age,dept_id) VALUES('无名',35,3);

    •  实际上我们应该保证,员工表所添加的 dept_id , 必须在部门表中存在. 

    解决方案:

    •   使用外键约束,约束 dept_id ,必须是 部门表中存在的id 
  • 相关阅读:
    捷微商城小程序上线啦~
    JEECG 新版在线文档WIKI正式发布
    https 详解
    css 3 新特性
    js 基础(一)
    BFC
    .Net、C# 汉字转拼音,简体繁体转换方法
    丰富“WinForms” 的一个别样"项目"(学生管理)
    学生管理系统1
    学生管理系统
  • 原文地址:https://www.cnblogs.com/JasperZhao/p/15014735.html
Copyright © 2011-2022 走看看