MySQL入门教程-CRUD

3、MySQL数据管理

3.1、外键

外键概念

如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。由此可见,外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。

在实际操作中,将一个表的值放入第二个表来表示关联,所使用的值是第一个表的主键值(在必要时可包括复合主键值)。此时,第二个表中保存这些值的属性称为外键(foreign key)。

外键作用:

保持数据一致性,完整性,主要目的是控制存储在外键表中的数据,约束。使两张表形成关联,外键只能引用外表中的列的值或使用空值。

目标:学生表(student)的gradeid字段 要去引用年级表(grade)的 gradeid字段

创建外键

方式一:在创建表的时候增加约束

 /*
     1. 定义外键key
     2. 给外键添加约束(执行引用)references 引用
 */
 CREATE TABLE IF NOT EXISTS `student`(
     `id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
     `name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
     `pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
     `sex` VARCHAR(2)    NOT NULL DEFAULT '女' COMMENT '性别',
     `birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
     `address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
     `email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
     `gradeid` INT(10) NOT NULL COMMENT '学生的年级',
     PRIMARY KEY (`id`),
     KEY `FK_gradeid` (`gradeid`),
     CONSTRAINT `FK_gradeid` FOREIGN KEY (`gradeid`) REFERENCES `grade`(`gradeid`)
 )ENGINE=INNODB DEFAULT CHARSET=utf8
 ​
 -- 创建年级表
 CREATE TABLE `grade`(
     `gradeid` INT(10) NOT NULL COMMENT '年级id',
     `gradename` VARCHAR(50) NOT NULL COMMENT '年纪名称',
     PRIMARY KEY (`gradeid`)
 )ENGINE=INNODB DEFAULT CHARSET=utf8

删除有外键关系的表的时候,必须要先删除引用别人的表(从表),再删除被引用的表(主表)


方法二:创建表成功后,添加外键约束

 /*
     1. 定义外键key
     2. 给外键添加约束(执行引用)references 引用
 */
 CREATE TABLE IF NOT EXISTS `student`(
     `id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
     `name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
     `pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
     `sex` VARCHAR(2)    NOT NULL DEFAULT '女' COMMENT '性别',
     `birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
     `address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
     `email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
     `gradeid` INT(10) NOT NULL COMMENT '学生的年级',
     PRIMARY KEY (`id`)
 )ENGINE=INNODB DEFAULT CHARSET=utf8
 ​
 -- 创建表的时候没有外键关系
 ALTER TABLE `student`
 ADD CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`);
 ​
 -- 创建年级表
 CREATE TABLE `grade`(
     `gradeid` INT(10) NOT NULL COMMENT '年级id',
     `gradename` VARCHAR(50) NOT NULL COMMENT '年纪名称',
     PRIMARY KEY (`gradeid`)
 )ENGINE=INNODB DEFAULT CHARSET=utf8

数据库就是用来单纯的表,只用来存数据,只有行(数据)和列(属性)

推荐:

 -- 创建表的时候没有外键关系
 ALTER TABLE `student`
 ADD CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`);

3.2、DML语言

Data Manipulation Luaguge:数据操作语言

添加 insert
 -- 普通用法
 INSERT INTO `student`(`name`) VALUES ('zsr');
 ​
 -- 插入多条数据
 INSERT INTO `student`(`name`,`pwd`,`sex`) VALUES ('zsr','200024','男'),('gcc','000421','女');
 ​
 -- 省略字段
 INSERT INTO `student` VALUES (5,'Bareth','123456','男','2000-02-04','武汉','1412@qq.com',1); 

语法:

 INSERT INTO 表名([字段1,字段2..])VALUES('值1','值2'..),[('值1','值2'..)..];

注意

  1. 字段和字段之间使用英文逗号隔开

  2. 字段是可以省略的,但是值必须完整且一一对应

  3. 可以同时插入多条数据,VALUES后面的值需要使用逗号隔开

修改 update
 -- 修改学员名字,指定条件
 UPDATE `student` SET `name`='zsr204' WHERE id=1;
 ​
 -- 不指定条件的情况,会改动所有表
 UPDATE `student` SET `name`='zsr204';
 ​
 -- 修改多个属性
 UPDATE `student` SET `name`='zsr',`address`='湖北' WHERE id=1;
 ​
 -- 通过多个条件定位数据
 UPDATE `student` SET `name`='zsr204' WHERE `name`='zsr' AND `pwd`='200024';

语法

 UPDATE 表名 SET 字段1=值1,[字段2=值2...] WHERE 条件[];

关于WHERE条件语句

img

删除 delete
 -- 删除数据(避免这样写,会全部删除)
 DELETE FROM `student`;
 ​
 -- 删除指定数据
 DELETE FROM `student` WHERE id=1;

语法

 DELETE FROM 表名 [WHERE 条件]
 关于DELETE删除的问题,重启数据库现象:
 ​
 INNODB 自增列会从1开始(存在内存当中,断电即失)
 MYISAM 继续从上一个子增量开始(存在内存当中,不会丢失)
 TRUNCATE

作用:完全清空一个数据库表,表的结构和索引约束不会变!

DELETE和TRUNCATE 的区别

DELETE可以条件删除(where子句),而TRUNCATE只能删除整个表

TRUNCATE 重新设置自增列,计数器会归零,而DELETE不会影响自增

DELETE是数据操作语言(DML - Data Manipulation Language),操作时原数据会被放到 rollback segment中,可以被回滚;而TRUNCATE是数据定义语言(DDL - Data Definition Language),操作时不会进行存储,不能进行回滚。

img

 CREATE TABLE `test`(
     `id` INT(4) NOT NULL AUTO_INCREMENT,
     `coll` VARCHAR(20) NOT NULL,
     PRIMARY KEY (`id`)
 )ENGINE=INNODB DEFAULT CHARSET=utf8;
 ​
 INSERT INTO `test`(`coll`) VALUES('1'),('2'),('3');
 ​
 -- 不会影响自增
 DELETE FROM `test`;
 ​
 -- 会影响自增
 TRUNCATE TABLE `test`;

3.3DQL查询数据

Data Query Language 数据查询语言

 SELECT [ALL | DISTINCT]
 {* | table.* | [table.field1[as alias1][,table.field2[as alias2]][,...]]}
 FROM table_name [as table_alias]
   [left | right | inner join table_name2]  -- 联合查询
   [WHERE ...]  -- 指定结果需满足的条件
   [GROUP BY ...]  -- 指定结果按照哪几个字段来分组
   [HAVING]  -- 过滤分组的记录必须满足的次要条件
   [ORDER BY ...]  -- 指定查询记录按一个或多个条件排序
   [LIMIT {[offset,]row_count | row_countOFFSET offset}]; -- 指定查询的记录从哪条至哪条
  • 查询数据库数据 , 如SELECT语句

  • 简单的单表查询或多表的复杂查询和嵌套查询

  • 是数据库语言中最核心,最重要的语句

  • 使用频率最高的语句

    前提配置

     -- 创建学校数据库
     CREATE DATABASE IF NOT EXISTS `school`;
     ​
     -- 用school数据库
     USE `school`;
     ​
     -- 创建年级表grade表
     CREATE TABLE `grade`(
         `GradeID` INT(11) NOT NULL AUTO_INCREMENT COMMENT '年级编号',
         `GradeName` VARCHAR(50) NOT NULL COMMENT '年纪名称',
         PRIMARY KEY (`GradeID`)
     )ENGINE=INNODB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
     ​
     -- 给grade表插入数据
     INSERT INTO `grade`(`GradeID`,`GradeName`) 
     VALUES (1,'大一'),(2,'大二'),(3,'大三'),(4,'大四');
     ​
     -- 创建成绩result表
     CREATE TABLE `result`(
         `StudentNo` INT(4) NOT NULL COMMENT '学号',
         `SubjectNo` INT(4) NOT NULL COMMENT '考试编号',
         `ExamDate` DATETIME NOT NULL COMMENT '考试日期',
         `StudentResult` INT(4) NOT NULL COMMENT '考试成绩',
         KEY `SubjectNo` (`SubjectNo`)
     )ENGINE=INNODB DEFAULT CHARSET=utf8;
     ​
     -- 给result表插入数据
     INSERT INTO `result`(`StudentNo`,`SubjectNo`,`ExamDate`,`StudentResult`) 
     VALUES (1000,1,'2019-10-21 16:00:00',97),(1001,1,'2019-10-21 16:00:00',96),
     (1000,2,'2019-10-21 16:00:00',87),(1001,3,'2019-10-21 16:00:00',98);
     ​
     -- 创建学生表student
     CREATE TABLE `student`( 
         `StudentNo` INT(4) NOT NULL COMMENT '学号',
         `LoginPwd` VARCHAR(20) DEFAULT NULL,
         `StudentName` VARCHAR(20) DEFAULT NULL COMMENT '学生姓名',
         `Sex` TINYINT(1) DEFAULT NULL COMMENT '性别,取值0或1',
         `GradeID` INT(11) DEFAULT NULL COMMENT '年级编号',
         `Phone` VARCHAR(50) NOT NULL COMMENT '联系电话,允许为空,即可选输入',
         `Adress` VARCHAR(255) NOT NULL COMMENT '地址,允许为空,即可选输入',
         `BornDate` DATETIME DEFAULT NULL COMMENT '出生时间',
         `Email` VARCHAR(50) NOT NULL COMMENT '邮箱账号,允许为空,即可选输入',
         `IdentityCard` VARCHAR(18) DEFAULT NULL COMMENT '身份证号',
         PRIMARY KEY (`StudentNo`),
         UNIQUE KEY `IdentityCard` (`IdentityCard`),
         KEY `Email` (`Email`)
     )ENGINE=MYISAM DEFAULT CHARSET=utf8;
     ​
     -- 给学生表插入数据
     INSERT INTO `student`(`StudentNo`,`LoginPwd`,`StudentName`,`Sex`,`GradeID`,`Phone`,`Adress`,`BornDate`,`Email`,`IdentityCard`) 
     VALUES (1000,'1241','dsaf',1,2,'24357','unknow','2000-09-16 00:00:00','1231@qq.com','809809'),
     (1001,'1321','dfdj',0,2,'89900','unknow','2000-10-16 00:00:00','5971@qq.com','908697');
     ​
     -- 创建科目表
     CREATE TABLE `subject`(
         `SubjectNo` INT(11) NOT NULL AUTO_INCREMENT COMMENT '课程编号',
         `SubjectName` VARCHAR(50) DEFAULT NULL COMMENT '课程名称',
         `ClassHour` INT(4) DEFAULT NULL COMMENT '学时',
         `GradeID` INT(4) DEFAULT NULL COMMENT '年级编号',
         PRIMARY KEY (`SubjectNo`)
     )ENGINE=INNODB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8;
     ​
     -- 给科目表subject插入数据
     INSERT INTO `subject`(`SubjectNo`,`SubjectName`,`ClassHour`,`GradeID`) 
     VALUES(1,'高数','96',2),(2,'大物','112',2),(3,'程序设计',64,3);
     ​
     SELECT 字段 FROM 表;
基础查询

语法

 SELECT 查询列表 FROM 表名;
  • 查询列表可以是:表中的(一个或多个)字段,常量,变量,表达式,函数

  • 查询结果是一个虚拟的表格

 -- 查询全部学生
 SELECT * FROM student;
 ​
 -- 查询指定的字段
 SELECT `LoginPwd`,`StudentName` FROM student;
 ​
 -- 别名 AS(可以给字段起别名,也可以给表起别名)
 SELECT `StudentNo` AS 学号,`StudentName` AS 学生姓名 FROM student AS 学生表;
 ​
 -- 函数 CONCAT(str1,str2,...)
 SELECT CONCAT('姓名',`StudentName`) AS 新名字 FROM student;
 ​
 -- 查询系统版本(函数)
 SELECT VERSION();
 ​
 -- 用来计算(计算表达式)
 SELECT 100*53-90 AS 计算结果;
 ​
 -- 查询自增步长(变量)
 SELECT @@auto_increment_increment;
 ​
 -- 查询有哪写同学参加了考试,重复数据要去重
 SELECT DISTINCT `StudentNo` FROM result;
条件查询

where 条件字句:检索数据中符合条件的值

语法

 select 查询列表 from 表名 where 筛选条件;
 -- 查询考试成绩在95~100之间的
 SELECT `StudentNo`,`StudentResult` FROM result
 WHERE `StudentResult`>=95 AND `StudentResult`<=100;
 -- &&
 SELECT `StudentNo`,`StudentResult` FROM result
 WHERE `StudentResult`>=95 && `StudentResult`<=100;
 -- BETWEEN AND
 SELECT `StudentNo`,`StudentResult` FROM result
 WHERE `StudentResult`BETWEEN 95 AND 100;
 ​
 -- 查询除了1000号以外的学生
 SELECT `StudentNo`,`StudentResult` FROM result
 WHERE `StudentNo`!=1000;
 -- NOT
 SELECT `StudentNo`,`StudentResult` FROM result
 WHERE NOT `StudentNo`=1000;
 ​
 -- 查询名字含d的同学
 SELECT `StudentNo`,`StudentName` FROM student
 WHERE `StudentName` LIKE '%d%';
 ​
 -- 查询名字倒数第二个为d的同学
 SELECT `StudentNo`,`StudentName` FROM student
 WHERE `StudentName` LIKE '%d_';
 ​
 -- 查询1000,1001学员
 SELECT `StudentNo`,`StudentName` FROM student
 WHERE `StudentNo` IN (1000,1001);
分组查询

语法

 select 分组函数,分组后的字段
 from 表
 【where 筛选条件】
 group by 分组的字段
 【having 分组后的筛选】
 【order by 排序列表】

区别

img

 -- 查询不同科目的平均分、最高分、最低分且平均分大于90
 -- 核心:根据不同的课程进行分组
 SELECT SubjectName,AVG(StudentResult),MAX(`StudentResult`),MIN(`StudentResult`)
 FROM result r
 INNER JOIN `subject` s
 on r.SubjectNo=s.SubjectNo
 GROUP BY r.SubjectNo
 HAVING AVG(StudentResult)>90;
连接查询

 -- 查询学员所属的年级(学号,学生姓名,年级名称)
 SELECT `StudentNo`,`StudentName`,`GradeName`
 FROM student s
 INNER JOIN grade g
 ON s.GradeID=g.GradeID;
 ​
 -- 查询科目所属的年级
 SELECT `SubjectName`,`GradeName`
 FROM `subject` s
 INNER JOIN `grade` g
 ON s.GradeID=g.GradeID;
 ​
 -- 查询列参加程序设计考试的同学信息(学号,姓名,科目名,分数)
 SELECT s.`StudentNo`,`StudentName`,`SubjectName`,`StudentResult`
 FROM student s
 INNER JOIN result r
 on s.StudentNo=r.StudentNo
 INNER JOIN `subject` sub
 on r.SubjectNo=sub.SubjectNo
 where SubjectName='课程设计';

自连接

自己的表和自己的表连接,核心:一张表拆为两张一样的表即可

 -- 创建一个表
 CREATE TABLE `course` (
 `courseid` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '课程id',
 `pid` INT(10) NOT NULL COMMENT '父课程id',
 `courseName` VARCHAR(50) NOT NULL COMMENT '课程名',
 PRIMARY KEY (`courseid`)
 ) ENGINE=INNODB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8
 ​
 -- 插入数据
 INSERT INTO `course` (`courseid`, `pid`, `courseName`)
 VALUES('2','1','信息技术'),
 ('3','1','软件开发'),
 ('4','3','数据库'),
 ('5','1','美术设计'),
 ('6','3','web开发'),
 ('7','5','ps技术'),
 ('8','2','办公信息');

将该表进行拆分:

img

 SELECT a.`courseid` AS '父课程',b.`courseid` AS '子课程'
 FROM course AS a,course AS b
 WHERE a.`courseid`=b.`pid`;

img

排序和分页

排序

语法

 select 查询列表
 from 表
 where 筛选条件
 order by 排序列表 asc/desc

order by的位置一般放在查询语句的最后(除limit语句之外)

img

 SELECT `StudentNo`,`StudentName`,`GradeName`
 FROM student s
 INNER JOIN grade g
 ON s.GradeID=g.GradeID
 ORDER BY `StudentNo` DESC;

分页

语法

 select 查询列表
 from 表
 limit offset,pagesize;
  • offset代表的是起始的条目索引,默认从0开始

  • size代表的是显示的条目数

  • offset=(n-1)*pagesize

 -- 第一页 limit 0 5
 -- 第二页 limit 5,5
 -- 第三页 limit 10,5
 -- 第n页  limit (n-1)*pagesize,pagesize
 -- pagesize:当前页面大小
 -- (n-1)*pagesize:起始值
 -- n:当前页面
 -- 数据总数/页面大小=总页面数
 -- limit n 表示从0到n的页面
子查询

本质:在 where子句中嵌套一个子查询语句

 -- 查询‘课程设计’的所有考试结果(学号,科目编号,成绩)降序排列
 ​
 -- 方式一:使用连接查询
 SELECT `StudentNo`,r.`SubjectNo`,`StudentResult`
 FROM result r
 INNER JOIN `subject` s
 on r.StudentNo=s.SubjectNo
 WHERE SubjectName='课程设计'
 ORDER BY StudentResult DESC;
 -- 方式二:使用子查询(由里到外)
 SELECT StudentNo,SubjectNo,StudentResult
 from result
 WHERE SubjectNo=(
     SELECT SubjectNo FROM `subject`
     WHERE SubjectName='课程设计'
 )

  • 32
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
建立环境实验和数据库/表 实验学时:2学时 实验类型:验证 实验要求:必修 一、实验目的 通过本实验的学习,使学生熟悉SQL Server 2014的集成环境,帮助学生掌握数据库、表的建立方法以及SQL Server的数据导入方法 二、实验内容    (一)、SQL Server 2014的安装 SQL Server2014的安装过程与 SQL Server 2008、SQL Server2012的安装过程类似,都提供了一个功能树以用来安装所有 SQL Server 组件,包括计划、安装、维护、工具、资源、高级、选项等功能。下面是各功能选项中所包含的内容,如图3-1所示。 图3-1 安装计划中的内容 (1)选择“安装”功能,因为要创建SQL Server 2014的全新安装,单击“全新SQL Server 2014独立安装或向现有安装添加功能”选项,如图3-2所示。 图3-2 “安装”功能中的内容 (2)在“产品密匙”页上,选择相应的单选按钮,这些按钮指示是安装免费版本的SQL Server还是具有产品密匙的产品版本,如果使指免费的评估版,只有180天的试用期限,如图3-3所示。 图3-3 “产品密钥”界面 (3)在“许可条款”页上阅读许可协议,然后选中相应的复选框以接受许可条款和条件。如图3-4所示。 图3-4 “许可条款”界面 (4)系统进行安装程序支持规则检查,以确定安装SQL Server安装程序支持文件时可能发生的问题。必须更正所有的失败,安装程序才能继续。如图3-5所示。 图3-5 “安装规则”界面 (5)在“设置角色”页上选择SQL Server功能安装,如图3-6所示。 图3-6 “设置”角色界面 (6)在“功能选择”页上选择要安装的组件。选择功能名称后,右侧窗体中会显示每个组件的说明。可以根据实际需要,选中一些功能,如图3-7所示。一般应用可选择“数据库引擎服务”、“客户端工具连接”、“SQL客户端连接”和“管理工具”等选项。 图3-7“功能选择”界面 (7)在“实例配置”页上制定是安装默认实例还是命名实例,对于默认实例,实例的名称和ID都是MSSQLSERVER,也可以自己“命名实例”安装实例,如图3-8所示。SQL Server支持多个实例,即支持在同一台计算机上同时运行多个SQL Server数据库引擎实例,每个SQL Server数据库引擎实例各有一套不为其它实例共享的系统及用户数据库。应用程序连接同一台计算机上的SQL Server数据库引擎实例的方式与连接其它计算机上运行的SQL Server数据库引擎的方式基本相同。 图3-8 “实例配置”界面 (8)在“服务器配置”页上指定SQL Server服务的登录帐户。SQL Server提供了多种服务,可以为所有SQL Server服务分配相同的登录账户,也可以分别配置每个服务账户。还可以指定服务是自动启动、手动启动还是禁用。Microsoft建议对各服务账户进行单独配置,以便为每项服务提供最低特权,即向SQL Server服务授予它们完成各自任务所需的最低权限,如图3-9所示。SQL Server中的每个服务代表一个进程或一组进程,每个进程需要有访问SQL Server相关文件和系统注册表的权限,为了能让SQL Server服务在操作系统中正常的启动和运行,就需要指定SQL Server的服务帐户,所以服务帐户指的是Windows操作系统中的帐户。 图3-9 “服务器配置”界面 (9)在“数据库引擎配置”的“服务器配置”页上指定身份验证模式、用户名、密码,如图3-10所示。这里的用户身份验证指的是登录到服务器使用的身份验证模式及用户名和密码。身份验证模式分为“Windows身份验证模式”和“混合模式(SQL Server身份验证和Windows身份验证)”。如果选择“Windows身份验证模式”表示则只能使用Windows的帐号登录,即使用当前登录到操作系统的帐号进行登录,通过这种方式用户登录到SQL Server中时不再需要输入帐号和密码。如选择“混合模式(SQL Server身份验证和Windows身份验证)”表示除了可以用使用登录到Windows的帐号作为登录的依据外,还可以使用SQL Server系统的帐号登录,这里必须为内置SQL Server系统管理员账户(SA)提供一个强密码。必须至少为SQL Server实例指定一个系统管理员。若要添加用以运行SQL Server安装程序账户,则要单击“添加当前用户”按钮。若要向系统管理员列表中添加账户或从中删除账户,则单击“添加…”或“删除…”按钮,然后编辑将拥有SQL Server实例的管理员特权的用户、组或计算机列表。 图3-10 设置身份验证模式和管理员 (10)在“准备安装”页显示安装过程中的安装选项的树视图,如图3-11所示。若要继续,单击“安装”按钮。在安装过程中,“安装进度”页会提供相应的状态,因此可以在安装过程中监视安装进度。 图3-121“准备安装”界面 (11)安装完成后,“完成”页提供指向安装日志文件摘要以及其他重要说明的链接。如图3-12所示。 图3-12 “安装完成”界面 (二)、建库建表练习      1、利用语句建库和建表: 创建学生数据库StuDB,文件名和位置自定,在此数据库中创建如下三张表: 学生表(student) (   学号(sno) 普通编码定长字符类型,长度9,主码,   姓名(sname) 普通编码定长字符类型,长度10,非空,   性别(ssex) 统一编码定长字符类型,长度2,   年龄(sage) 微整型,   所在系(sdept) 统一编码可变长字符类型,长度20 ) 课程表(course) (   课程号(cno) ,通编码定长字符类型,长度4,主码,   课程名(cname) 统一编码定长字符类型,长度,40,非空,   开课学期(Semester) 短整数, 学分(credit) 短整数 ) 修课表(sc)(   学号(sno) 普通编码定长字符类型,长度7,主码,外码   课程号(cno) 普通编码定长字符类型,长度6,主码,外码   成绩(grade) 小整型,   修课类别(ctype)普通编码定长字符类型,长度4 ) 2、建立“汽车”数据库,文件名和位置自定,在此数据库中创建如下三张表: 汽车表(CarT),结构如下:   汽车序号(CId) 整型 主关键字,   汽车名称(CName) 普通编码定长字符类型 长度为10  非空,   型号(CType)普通编码变长字符类型 长度为60  非空,   价格(CPrice) 整型,   车身眼色(Ccolor)普通编码变长字符类型 长度为20。 部门表(DepartT),结构如下:   部门序号(DId)整型 主关键字,   部门名(DName)普通编码定长字符类型 长度为20   非空,   负责人名(DLead)普通编码定长字符类型 长度为10  非空,   人数(DAmount) 整型。 汽车出厂表(FacT),结构如下:   汽车序号(CID) 整型 非空,   部门序号(DId) 整型 非空,   出厂日期(FDate)小日期时间型 非空,   出厂数量(FAmount) 整型,   出厂价格(FPrice) 整型。   其中:主关键字为(汽车序号,部门序号,出厂日期)   “汽车序号”为引用汽车表的“汽车序号”的外部关键字; “部门序号”为引用部门表的“部门序号”的外部关键字。 3、使用数据库的可视化工具建库建表 建立银行贷款表,具体要求同课堂教学的建库建表一致。 银行表(BankT)( 银行代码(Bno) 主键 银行名称(Bname) 非空 电话(Tel) ) 法人表(LET)( 法人代码(Eno)主键 法人名称(Ename)取值唯一 经济性质(Enature) 注册资金(Ecapital) 法定代表人(Erep) ) 贷款表(LoanT)( 法人代码(Eno) 银行代码(Bno) 贷款日期(Ldata) 贷款金额(Lamount) 贷款期限(Lterm) )        (三)、数据导入练习 将“学生数据库数据.xls”中的数据导入到学生数据库的三张表中。 将“银行贷款数据.xls”中的数据导入到银行贷款数据库的三张表中。 三、实验报告 将实验结果反映在实验报告中,并对实验中遇到的问题及解决方案、进行整理、分析总结,提出实验结论或自己的看法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

射手座的程序媛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值