一、使用SQLyog创建数据库用来管理学生信息

 #创建数据库student
DROP DATABASE IF EXISTS Myschool;
CREATE DATABASE Myschool; #在数据库中新建四张数据表
USE Myschool; #创建年级表
CREATE TABLE grade(
gradeID INT(4) UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT COMMENT '年级编号',
gradeName VARCHAR(50) NOT NULL COMMENT '年级名称'
)COMMENT="年级表"; #创建学生信息表
CREATE TABLE student(
studentNo INT(4) NOT NULL PRIMARY KEY COMMENT '学号',
loginPwd VARCHAR(20) NOT NULL DEFAULT '' COMMENT '密码',
studentName VARCHAR(50) NOT NULL COMMENT '姓名',
sex CHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
gradeID INT(4) UNSIGNED COMMENT '年级编号',
phone VARCHAR(50) COMMENT '电话',
address VARCHAR(255) DEFAULT '地址不详' COMMENT '地址',
bornDate DATETIME DEFAULT NOW() COMMENT '出生日期',
email VARCHAR(50) DEFAULT 'xx@163.com' COMMENT '邮件账号',
identityCard VARCHAR(18) COMMENT '身份证号'
)COMMENT="学生信息表"; #创建科目表
CREATE TABLE `subject`(
subjectNo INT(4) NOT NULL PRIMARY KEY AUTO_INCREMENT COMMENT '课程编号',
subjectName VARCHAR(50) COMMENT '课程名称',
classHour INT(4) COMMENT '学时',
gradeID INT(4) UNSIGNED COMMENT '年级编号'
)COMMENT="科目表"; #创建成绩表
CREATE TABLE result(
studentNo INT(4) NOT NULL COMMENT '学号',
subjectNo INT(4) NOT NULL COMMENT '课程编号',
examDate DATETIME DEFAULT NOW() NOT NULL COMMENT '考试日期',
studentResult INT(4) NOT NULL COMMENT '考试成绩'
)COMMENT="成绩表"; #为表添加外键(关系) #在student表中添加gradeID外键
ALTER TABLE student
ADD CONSTRAINT fk_student_grade FOREIGN KEY(gradeID)
REFERENCES grade(gradeID); #在subject表中添加gradeID外键
ALTER TABLE `subject`
ADD CONSTRAINT fk_subject_grade FOREIGN KEY(gradeID)
REFERENCES grade(gradeID); #在result表中添加studentNo,subjectNo外键
ALTER TABLE result
ADD CONSTRAINT fk_result_student FOREIGN KEY(studentNo)
REFERENCES student(studentNo); ALTER TABLE result
ADD CONSTRAINT fk_result_subject FOREIGN KEY(subjectNo)
REFERENCES `subject`(subjectNo); #为表添加初始数据 #年级表grade的数据
INSERT INTO grade(gradeID,gradeName)
VALUES(1,'一年级'),(2,'二年级'),(3,'三年级'),(4,'四年级'),(5,'五年级'); #科目表subject的数据
INSERT INTO `subject`(subjectNo,subjectName,classHour,gradeID)
VALUES(1,'Logic Java',220,1),(2,'HTML',160,1),(3,'Java OOP',230,2); #学生信息表student的数据
INSERT INTO student(studentNo,studentName,sex,gradeID,phone,address,bornDate)
VALUES(10000,'郭靖','男',1,13645667783,'天津市河西区','1990-09-08'),
(10001,'李文才','男',1,13645667890,'地址不详','1994-04-12'),
(10002,'李斯文','男',1,13645556793,'河南洛阳','1993-07-23'),
(10003,'张萍','女',1,13642345112,'地址不详','1995-06-10'),
(10004,'韩秋洁','女',1,13812344566,'北京市海淀区','1995-07-15'),
(10005,'张秋丽','女',1,13567893246,'北京市东城区','1994-01-17'),
(10006,'肖梅','女',1,13563456721,'河北省石家庄市','1991-02-17'),
(10007,'秦洋','男',1,13056434411,'上海市卢湾区','1992-04-18'),
(10008,'何睛睛','女',1,13053445221,'广州市天河区','1997-07-23'),
(20000,'王宝宝','男',2,15076552323,'地址不详','1996-06-05'),
(20010,'何小华','女',2,13318877954,'地址不详','1995-09-10'),
(30011,'陈志强','女',3,13689965430,'地址不详','1994-09-27'),
(30012,'李露露','女',3,13685678854,'地址不详','1992-09-27'); #成绩表result的数据
INSERT INTO result(studentNo,subjectNo,examDate,studentResult)
VALUES(10000,1,'2016-02-15',71),
(10000,1,'2016-02-17',60),
(10001,1,'2016-02-17',46),
(10002,1,'2016-02-17',83),
(10003,1,'2016-02-17',65),
(10004,1,'2016-02-17',70),
(10005,1,'2016-02-17',95),
(10006,1,'2016-02-17',93),
(10007,1,'2016-02-17',23),
(20000,3,'2016-07-17',68),
(20010,3,'2016-07-17',90),
(20000,2,'2016-07-17',88),
(20010,2,'2016-07-17',78); ##学生信息数据库备份##

二、使用SQLyog创建数据库制作图书馆管理系统

 #建立一个图书馆管理系统的数据库来存放图书馆的相关信息,包括图书的基本信息、图书借阅的信息和读者的信息

 #创建数据库Library
CREATE DATABASE IF NOT EXISTS Library;
USE Library;
#创建实体表
#图书信息表book
CREATE TABLE book(
bookId VARCHAR(50) PRIMARY KEY NOT NULL COMMENT '图书编号',
bookName VARCHAR(255) NOT NULL COMMENT '图书名称',
author VARCHAR(50) COMMENT '作者姓名',
pubComp VARCHAR(50) COMMENT '出版社',
pubDate DATE COMMENT '出版日期',
bookCount INT(4) COMMENT '现存数量',
price DOUBLE COMMENT '单价'
)COMMENT="图书信息表"; #读者信息表reader
CREATE TABLE reader(
readerId VARCHAR(50) PRIMARY KEY NOT NULL COMMENT '读者编号',
readerName VARCHAR(50) NOT NULL COMMENT '读者姓名',
lendNum INT(4) COMMENT '已借书数量',
readerAddress VARCHAR(255) COMMENT '联系地址'
)COMMENT="读者信息表"; #图书借阅表borrow
CREATE TABLE borrow(
readerId VARCHAR(50) NOT NULL COMMENT '读者编号',
bookId VARCHAR(50) NOT NULL COMMENT '图书编号',
lendDate DATETIME DEFAULT NOW() NOT NULL COMMENT '借阅日期',
willDate DATE COMMENT '应归还日期',
returnDate DATE COMMENT '实际归还日期'
)COMMENT="图书借阅表"; #罚款记录表penalty
CREATE TABLE penalty(
readerId VARCHAR(50) NOT NULL COMMENT '读者编号',
bookId VARCHAR(50) NOT NULL COMMENT '图书编号',
pDate DATE NOT NULL COMMENT '罚款日期',
pType INT COMMENT '罚款类型:1-延期,2-损坏,3-丢失',
amount DOUBLE COMMENT '罚款金额'
)COMMENT="罚款记录表"; #删除信息表
USE Library;
DROP TABLE IF EXISTS book;
DROP TABLE IF EXISTS reader;
DROP TABLE IF EXISTS borrow;
DROP TABLE IF EXISTS penalty; #给borrow添加复合主键
ALTER TABLE borrow
ADD CONSTRAINT pk_borrow PRIMARY KEY(readerId,bookId,lendDate); #给penalty添加复合主键
ALTER TABLE penalty
ADD CONSTRAINT pk_penalty PRIMARY KEY(readerId,bookId,pDate); ##删除borrow和penalty的主键
ALTER TABLE borrow
DROP PRIMARY KEY;
ALTER TABLE penalty
DROP PRIMARY KEY;
##删除borrow和penalty的外键
ALTER TABLE borrow
DROP FOREIGN KEY fk_borrow_book;
ALTER TABLE borrow
DROP FOREIGN KEY fk_borrow_reader;
ALTER TABLE penalty
DROP FOREIGN KEY fk_penalty_book;
ALTER TABLE penalty
DROP FOREIGN KEY fk_penalty_reader; #给borrow添加外键
ALTER TABLE borrow
ADD CONSTRAINT fk_borrow_book FOREIGN KEY(bookId)
REFERENCES book(bookId);
ALTER TABLE borrow
ADD CONSTRAINT fk_borrow_reader FOREIGN KEY(readerId)
REFERENCES reader(readerId); #给penalty添加外键
ALTER TABLE penalty
ADD CONSTRAINT fk_penalty_book FOREIGN KEY(bookId)
REFERENCES book(bookId);
ALTER TABLE penalty
ADD CONSTRAINT fk_penalty_reader FOREIGN KEY(readerId)
REFERENCES reader(readerId);

【学习笔记】使用SQLyog连接MySQL数据库的更多相关文章

  1. 使用SQLyog连接MySQL数据库

    [学习笔记]使用SQLyog连接MySQL数据库 一.使用SQLyog创建数据库用来管理学生信息 复制代码 1 #创建数据库student  2 DROP DATABASE IF EXISTS Mys ...

  2. 一步一步跟我学习hadoop(7)----hadoop连接mysql数据库运行数据读写数据库操作

        为了方便 MapReduce 直接訪问关系型数据库(Mysql,Oracle).Hadoop提供了DBInputFormat和DBOutputFormat两个类.通过DBInputFormat ...

  3. python web开发——django学习(一)第一个连接mysql数据库django网站运行成功

    1.新建一个项目 2.新建一些文件夹方便管理 3.新建一个项目叫message  4.连接数据库 python web开发Django连接mysql 5.在数据库里自动生成django的表  6.运行 ...

  4. 【PHP+MySQL学习笔记】php操作MySQL数据库中语句

    1.连接 MYSQL 服务器的函数 mysql_connect();<?php $con = mysql_connect("localhost","root&quo ...

  5. [知了堂学习笔记]_Java代码实现MySQL数据库的备份与还原

    通常在MySQL数据库的备份和恢复的时候,多是采用在cmd中执行mysql命令来实现. 例如: mysqldump -h127.0.0.1 -uroot -ppass test > d:/tes ...

  6. Android学习笔记————利用JDBC连接服务器数据库

    /******************************************************************************************** * auth ...

  7. R基础学习(一)-- 连接mysql数据库

    测试环境:win10+RStudio (1)在Console加载两个插件 >install.packages('DBI') Installing package into ‘C:/Users/l ...

  8. Linux学习笔记09—Sqlyog链接mysql配置

    第一步打开Linux命令窗口,进入超级用户.命令:[test@localhost ~]$ suPassword:输入超级用户密码第二步启动Mysql服务命令:[root@localhost test] ...

  9. 数据库学习笔记(二)MySQL数据库进阶

    MySQL 进阶 关于连表 左右连表: join 上下连表: union #自动去重 (当两张表里的数据,有重复的才会自动去重) union all #不去重 #上下连表示例: select sid, ...

随机推荐

  1. 【转】WinForm时间选择控件(DateTimePicker)如何选择(显示)时分秒

    源地址:https://www.cnblogs.com/EvanFan/p/7826160.html 注意:年月日时分秒的大小写格式,如果错了数据就错了,如果能显示当前时间说明设置正确

  2. SignalR-001

    SignalR 是什么? ASP.NET Core SignalR 是一个开放源代码库,它简化了向应用添加实时 web 功能. 实时 web 功能立即使服务器端代码能够将内容推送到客户端. 一.有这么 ...

  3. JS编程模式之初始化分支与惰性初始

    不同的浏览器对于相同或相似的方法可能有不同的实现.这时,您需要依据当前的浏览器的支持方法来选择对应的执行分支.这类分支有可能与很多,因此可能会减缓脚本的执行速度.但非要等到运行时才能分支吗?我们完全可 ...

  4. I/O(输入/输出)---字节流与字符流

    流: 分为输入流和输出流,输入/输出是相对计算机内存来说的,数据输入到内存是输入流,数据从内存中输出是输出流. 流对象构造的时候会和数据源联系起来. 数据源分为:源数据源和目标数据源.输入流联系的是源 ...

  5. Unity小知识---第三人称中设置摄像机的简单跟随

    第三人称中设置摄像机的简单跟随 private Transform player; private Vector3 offect; private float smooothing = 3f; //插 ...

  6. 修复win10无法双击打开txt文档.reg

    Windows Registry Editor Version 5.00[HKEY_CLASSES_ROOT\.txt]@="txtfile""Content Type& ...

  7. day--40 mysql-视图,触发器,存储过程,函数总结

    视图,触发器,存储过程,函数总结 一:视图 01:介绍 视图是一个虚拟表(非真实存在),是跑到内存中的表,真实表是硬盘上的表,怎么就得到了虚拟表,就是你查询的结果,只不过之 前我们查询出来的虚拟表,从 ...

  8. 008 Android activity实现多个界面的相互跳转(主要利用Intent)

    1.activity介绍 一个activity就把他理解成一个页面 2.新建activity流程 如图所示在com.lucky.test06的目录下,右击new--->Activity---&g ...

  9. ubuntu设置静态 ip

    查看ip和DNS 终端输入ifconfig获取ip,子网掩码.输入nm-tool获取网关,DNS 修改配置文件/etc/network/interfaces root@ubuntu:~# sudo g ...

  10. C++_类入门2-使用类

    进一步探讨类的特征,重点是类设计技术,而不是通用原理.一些特性很容易,一些特性很微妙. 运算符重载 目的是使C++操作更美观,更接近于内置类型的操作. 隐藏了内部的实现机理,并强调了实质. 格式:op ...