一、了解表与表之间的关系
存在:没有关系、一对一的关系(学生与学号)、一对多或多对一的关系、多对多的关系。
一对一的关系关联字段会设计在任意一张表当中;
一对多的关系关联字段会设计在关系表当中;自拟建表尝试查询
DROP TABLE IF EXISTS `class`;
CREATE TABLE `class` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`class_num` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '班级号',
`class_name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '班级名称',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin ROW_FORMAT = Compact;
-- ----------------------------
-- Records of class
-- ----------------------------
INSERT INTO `class` VALUES (1, '20201001', '软件工程');
INSERT INTO `class` VALUES (2, '20201002', '计算机科学');
INSERT INTO `class` VALUES (3, '20201003', '网络工程');
INSERT INTO `class` VALUES (4, '20201005', '数学');
-- ----------------------------
-- Table structure for course
-- ----------------------------
DROP TABLE IF EXISTS `course`;
CREATE TABLE `course` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '选课表',
`cno` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '课程号',
`gradeName` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '课程名称',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin ROW_FORMAT = Compact;
-- ----------------------------
-- Records of course
-- ----------------------------
INSERT INTO `course` VALUES (1, '1001', '数学');
INSERT INTO `course` VALUES (2, '1002', '语文');
INSERT INTO `course` VALUES (3, '1003', '英语');
-- ----------------------------
-- Table structure for relationship
-- ----------------------------
DROP TABLE IF EXISTS `relationship`;
CREATE TABLE `relationship` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`sno` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '学号',
`cno` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '课程号',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 39 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin ROW_FORMAT = Compact;
-- ----------------------------
-- Records of relationship
-- ----------------------------
INSERT INTO `relationship` VALUES (1, '202001', '1001');
INSERT INTO `relationship` VALUES (2, '202001', '1002');
INSERT INTO `relationship` VALUES (3, '202001', '1003');
INSERT INTO `relationship` VALUES (4, '202002', '1001');
INSERT INTO `relationship` VALUES (5, '202002', '1002');
INSERT INTO `relationship` VALUES (6, '202003', '1003');
INSERT INTO `relationship` VALUES (7, '202004', '1001');
INSERT INTO `relationship` VALUES (8, '202004', '1002');
INSERT INTO `relationship` VALUES (9, '202004', '1003');
INSERT INTO `relationship` VALUES (10, '202005', '1001');
INSERT INTO `relationship` VALUES (11, '202005', '1002');
INSERT INTO `relationship` VALUES (12, '202006', '1003');
INSERT INTO `relationship` VALUES (13, '202006', '1001');
INSERT INTO `relationship` VALUES (14, '202006', '1002');
INSERT INTO `relationship` VALUES (15, '202007', '1003');
INSERT INTO `relationship` VALUES (16, '202009', '1001');
INSERT INTO `relationship` VALUES (17, '202009', '1002');
INSERT INTO `relationship` VALUES (18, '202009', '1003');
INSERT INTO `relationship` VALUES (19, '202010', '1001');
INSERT INTO `relationship` VALUES (20, '202010', '1002');
INSERT INTO `relationship` VALUES (21, '202010', '1003');
INSERT INTO `relationship` VALUES (22, '202011', '1001');
INSERT INTO `relationship` VALUES (23, '202012', '1002');
INSERT INTO `relationship` VALUES (24, '202012', '1003');
INSERT INTO `relationship` VALUES (25, '202013', '1001');
INSERT INTO `relationship` VALUES (26, '202013', '1002');
INSERT INTO `relationship` VALUES (27, '202014', '1003');
INSERT INTO `relationship` VALUES (28, '202014', '1001');
INSERT INTO `relationship` VALUES (29, '202014', '1002');
INSERT INTO `relationship` VALUES (30, '202015', '1003');
INSERT INTO `relationship` VALUES (31, '202015', '1001');
INSERT INTO `relationship` VALUES (32, '202016', '1002');
INSERT INTO `relationship` VALUES (33, '202016', '1003');
-- ----------------------------
-- Table structure for student
-- ----------------------------
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL,
`sex` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL,
`age` int(11) NOT NULL,
`sno` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL COMMENT '学号',
`class_num` varchar(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin DEFAULT NULL COMMENT '班级号',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 17 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin ROW_FORMAT = Compact;
-- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES (1, '张三', '男', 20, '202001', '20201001');
INSERT INTO `student` VALUES (2, '李四', '男', 21, '202002', '20201001');
INSERT INTO `student` VALUES (3, '王五', '男', 20, '202003', '20201001');
INSERT INTO `student` VALUES (4, '张安', '女', 23, '202004', '20201001');
INSERT INTO `student` VALUES (5, '萨达', '女', 21, '202005', '20201001');
INSERT INTO `student` VALUES (6, '阿斯蒂芬', '女', 22, '202006', '20201002');
INSERT INTO `student` VALUES (7, '广大儒风', '男', 20, '202007', '20201002');
INSERT INTO `student` VALUES (8, '安顺', '男', 20, '202008', '20201002');
INSERT INTO `student` VALUES (9, '东方', '女', 20, '202009', '20201002');
INSERT INTO `student` VALUES (10, '咖啡', '男', 20, '202010', '20201002');
INSERT INTO `student` VALUES (11, '回顾', '女', 20, '202011', '20201003');
INSERT INTO `student` VALUES (12, '同意', '男', 20, '202012', '20201003');
INSERT INTO `student` VALUES (13, '规划局', '女', 20, '202013', '20201003');
INSERT INTO `student` VALUES (14, '各环节', '男', 20, '202014', '20201003');
INSERT INTO `student` VALUES (15, '空格', '女', 20, '202015', '20201003');
INSERT INTO `student` VALUES (16, '发送到', '男', 22, '202016', '20201004');
SET FOREIGN_KEY_CHECKS = 1;
基本查询、CURD
1.查询学生的姓名
select name from student
2.查询学生姓名和性别
select name,sex from student
3.查询学生全部信息
select * from student
SELECT是关键字,表示将要执行一个查询,*表示“所有列”,FROM表示将要从哪个表查询
注意:查询结果也是一个二维表,它包含列名和每一行的数据。
4. 条件查询----->>where语句:
#查询班级号为 20201001 的学生
select * from student where classnum='20201001';
#查询id为1的学生
select *from student where id =1;
#查询出年龄不是20岁的学生
SELECT name FROM student where age <> 20;
SELECT name FROM student where age != 20;
#查询出年龄小于21岁的学生
SELECT name FROM student where age <21;
5. 分组函数/聚合函数:
#求学生年龄的总和
select sum(age) sum_age from student;
#查询出学生的平均年龄
select avg(age)from student;
#查询出年龄最大的同学 max()min()
SELECT max(age)from student;
#查询所有的学生数量
SELECT count(*) from student;
SELECT count(class_num) from student;
#count(*)表示取得当前査询表所有记录 2、count(字段名称),不会统计为nu11的记录
分组查询:group by
#求各个班的平均年龄
select class_num,avg(age) avg_age from student GROUp BY class_num;
#查询出各个班年龄的最大值
select class_num,max(age) max_age from student GROUp BY class_num;
6. 分页查询(限制查询):
#LIMIT 限定查询的条数 OFFSET 从第几条数据开始去查询(和数组一样:下标从0开始)
SELECT * FROM Student LIMIT 3 OFFSET 0;
SELECT * FROM student LIMIT 3 OFFSET 3;
SELECT * FROM Student LIMIT 3 OFFSET 6;
# LIMIT 从第几条数据开始去查询 , 限定查询的条数
SELECT * FROM student LIMIT 0,3;
SELECT * FROM student LIMIT 3,3;
SELECT * FROM student LIMIT 6,3;
#在实际使用的时候:浏览器会给我们提供两个数值:pagesize:每个显示的条数pageIndex:页码数#
# SELECT * FROM student LIMIT pageSize OFFSET (pageIndex-1) * pageSize;
7. 链表查询:
#selectxxxfromA表名joinB表名 on 表的连接条件;
select student.*,class.class_name from student left join class on student.class_num = class.class_num;
select student.*,class.class_name from student right join class on student.class_num = class.class_num;
select student.*,class.class_name from student inner join class on student.class_num = class.class_num;
8. 数据插入 insert--->> 在设计表的时候id字段要设计自动递增!! 这样我们在插入值的时候不需要插入id
#INSERT INT0 student(列表1,列表2,列表3,列表4,列表5,列表6) VALUE (值1,值1,值1, 值1, 值1,值1);
INSERT into student(name,sex,age,sno,class_num) VALUE ('hah','男',18,'202017','20201004');
#INSERT INT0 student(列表1,列表2,列表3,列表4,列表5,列表6) VALUES (值1,值1,值1,值1),(值2,值2 ,值2 ,值2 ,值2,值2),(值3,值3值1、值1,值3.值3,值3 ,值3);
INSERT into student(name,sex,age,sno,class_num) value ('hah1','男',18,'202017','2020104'),('hah2','男',18,'202017','2820104'),('hah2','男',18,'202017','20201004');
9. update修改操作:
#update 表名 set 列名=新值, 列名=新值 where 条件列值 =值;
UPDATE student set name='张三安',age = 20,sno='123456' WHERE id = 1;
UPDATE student set name='张三安',age = 20,sno='123456';
10. delete删除操作:
#delete from 表名 where 条件列 =值;
delete from student where id = 1;
delete from student; #一行行删除
#TRUNCATE table 表名 删除这张表,但是还是会创建一个和原始表结构一样的新表
### DROP table 表名---->彻底删除这张表
二、Tomcat介绍
bin:
bin目录主要是用来存放tomcat的命令,主要有两大类,一类是以.sh结尾的(linux命令),另一类是以.bat结尾的(windows命令)很多环境变量的设置都在此处,例如可以设置JDK路径、tomcat路径。
修改catalina可以设置tomcat的内存。
startup 用来启动tomcat
shutdown 用来关闭tomcat
另外最重要的是关于启动,若点击startup出现闪退情况,那么是没有启动成功,有如下原因:
(1)首先需要确认java环境是否配置正确,jdk是否安装正确(大概率问题出在这里)
win+R打开cmd,输入java 或者 javac
确认Tomcat的环境变量配置
对于免安装版的Tomcat来说,在启动Tomcat时,需要读取环境变量和配置信息,缺少了这些信息,就不能登记环境变量,导致闪退。
解决方法:
1:在已解压的tomcat的bin文件夹下找到startup.bat,右击->编辑。在文件的最上面加入下面两行:
注意: 后面的路径根据自己的安装路径来复制
SET JAVA_HOME=D:\jdk1.8.0_131 (java jdk目录)
SET TOMCAT_HOME=D:\Tomcat\apache-tomcat-9.0.40-windows-x64\apache-tomcat-9.0.40 (解压后的tomcat文件目录)
2.在已解压的tomcat的bin文件夹下找到shutdown.bat,右击->编辑。在文件头加入下面两行:
注意: 后面的路径根据自己的安装路径来复制
SET JAVA_HOME=D:\jdk1.8.0_131 (java jdk目录)
SET TOMCAT_HOME=D:\Tomcat\apache-tomcat-9.0.40-windows-x64\apache-tomcat-9.0.40 (解压后的tomcat文件目录)
(2)端口占用问题
在确定环境变量配置没有问题的情况下,可能是端口被占用。
一般Tomcat的默认端口是8080,查看tomcat默认端口在conf目录下的server.xml中
对于Windows系统,win+R打开cmd,在命令行中输入
netstat -ano | findstr 8080
来查看当前是否有进程占用了端口,
可以看到端口被占用,则可以根据PID(进程Id号)来查看占用端口的是哪个程序,在命令行中输入
tasklist | findstr PID
注意:PID是最后一列的数,输入命令时不要忘了空格
找到占用端口的进程之后,在命令行中输入
taskkill /f /t /im 进程名
注意:斜杠之前的空格,进程名就是刚刚查到的进程名称
至此,占用端口的进程就被结束了。此时再双击start.bat,应该就没有什么问题了,正常启动显示如下: