数据库基础了解(CURD)Day2

一、了解表与表之间的关系

        存在:没有关系一对一的关系(学生与学号)一对多或多对一的关系多对多的关系

一对一的关系关联字段会设计在任意一张表当中;

一对多的关系关联字段会设计在关系表当中;自拟建表尝试查询

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,应该就没有什么问题了,正常启动显示如下:

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值