我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容。

前言:此随笔主要是Java基础中的基础,相信大家对这方面肯定有着自己的理解和认识,具体详解可以参照万能的baidu,有的我就一笔带过,希望在我的学习之路上能够有大牛进行指导,也有更多的小伙伴共勉。

1.Junit单元测试

我们在编程的时候会写一些功能,但是总不可能就是说没写一个功能来进行测试就要对整个项目重新启动,这样第一效率不高,第二页不方便编译,在这里我们就可以进行单元测试Junit。

测试分为黑盒测试和白盒测试。

两者的区别就是黑盒测试是看不到中间测试的过程,主要注重于结果是否正确,而白盒测试,便是需要对代码进行编译来看是否编译内容出现错误,而这里的白盒测试就是我们Junit的单元测试,但是对于Junit单元测试的结果来说,并不一定是说结果是肯定正确的,这里的单元测试只是用来测试代码是否能够实现这个功能,是否编译局部出错,就好比要进行一个加法运算的功能,但是里面写的是减法语法,编译不会报错,说明是可以运算的,代码的操作没有问题,内容出错可以对代码进行修改从而达到想要的目的。如果说有期望 值,那么可以使用Assert.assertEquals进行传参对比,看是否能达到使用的功能。这里使用Junit单元测试,只需要在需要测试的代码没块前加@Junit注释,然后进行测试。而这里还要学到两个注释一个是@before 一个是@after是指在单元测试前后要执行的代码。而对于Junit需要导入依赖环境来使用Junit测试。

2.MySql

这里是后台的重中之重了,后台程序员必须要熟练掌握SQL语句对数据库的数据进行使用,从而在前端能够很好的运用数据库的内容进行展示。

什么是数据库呢?就是用来存储和管理数据的仓库。Database简称DB。

数据库的安装和卸载就不做赘述了,baidu有很多操作方式。这里需要了解数据库的启动就是启动和关闭数据库,还有进入数据库。

数据库的启动和关闭在cmd中services.msc服务直接启动或者是通过输入指令

启动数据库:net start mysql;

关闭数据库:net stop mysql;

数据库的登录:-u用户名 -p用户登录密码

数据库的退出:exit / quit

而SQL语句分为四种分别是DDL、DML、DQL、DCL

DDL用来操作数据库的,DML用来对表进行增和删,DQL用来对数据库表中内容进行查找,DCL是对数据库访问权限的修改。我们主要学的就是对数据库变着花样的进行查询。

DDL:操作数据库和表

数据库的创建:

CREAT database 数据库名称;

CREAT database if not exists 数据库名称;

CREAT databse 数据库名称 character set 字符集名;

数据库的查询:

SHOW database ;

SHOW CREAT database 数据库名称; 查询创建数据库的语句

数据库的修改:

alter database 数据库名称 character set 字符集;

数据库的删除:

drop database 数据库名称;

drop database if exists 数据库名称;

使用数据库:

SELECT database();

use 数据库名称;

表的创建:

Create table 表名(

  列名1 数据类型1;

  列名2 数据类型2;

  列名3 数据类型3;

);

数据类型: int ,double, date, datetime, timestamp, varchar。

表的复制:

create table 表名 liike 被复制的表名;

表的查询:

show tables;

desc 表名;查询表的结构

表的修改:

alter table 表名 rename to 新的表名;

alter table 表名 character set 字符集名称;

alter table 表名 add列名 数据类型;

alter table 表名 change 列名 新类别 新类型数据;

alter table 表名 modify 列名 新数据类型;修改列名称和列类型

alter table 表名 drop 列名;删除列

表的删除:

drop table 表名;

drop table if exists 表名;

DML:增删改表中的数据

添加数据。

insert into 表名(列名1,列名2,。。。列名n) values (值1,值2,值n);

删除数据:

delete from 表名 [where 条件];

如果不加条件,则删除表中的所有数据。

TRUNCATE TABLE 表名;先删除表,然后再创建一张一样的表;

修改数据:

update 表名 set 列名1 = 值1 , 列名2=值2 ,。。[where 条件]

DQL:查询表中的记录

select * from 表名;

select 字段列表 from 表明列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 顺序 limit 分页限定

基础查询

1.多个字段的查询 select 字段名1,字段名2.。。from 表名;

2.去除重复distinct

3.ifnull(表达式1,表达式2):null参与的运算,计算结果都为null,表达式1是哦按段那个字段是否为null,表达式2是将null 值替换的值

4.as起别名

条件查询

1.where子句后跟条件;

2.> < <= >= = <> BETWEEN...AND IN(集合) LIKE模糊查询 _:单个任意字符;%:多个任意字符; IS NULL ;and 或&&;or或||;not 或 !

判断是否为null 值不能用 where 列名 = NULL ;这样是错误的  只能用IS NULL;

1.排序查询

  order by子句 排序字段1 排序方式1,排序字段2 排序方式2;

如果有多个排序条件,那么只有之前的排序条件值相同时,再会执行之后的排序条件;

2.聚合函数

1.count 计算个数(一般会选择主键)

2.max 计算最大值

3.min 计算最小值

4.sum 计算和

5.avg 计算平均值

注意:聚合函数的值不包括null值,可以选择不包含null值的列或者使用isnull 来进行判断使用

3.分组排序

group by 分组字段;

分组之后查询到字段:分组字段,聚合函数

where 和 having的区别

where是先进行限定不满足条件不参与分组。having是在分组之后进行限定,后面可以跟聚合函数。

4.分页查询

limit 开始的索引,每页显示的条数。

约束

1.主键约束 primary key    添加自增长auto_increment   删除自增长modify    删除主键不能用modify 需要用drop primary

2.外键约束foreign key 删除外键约束 drop foreign key 外键名称  添加外键 add constraint 外键名称 foreign key reference 主表名称

3.非空约束not null 删除非空约束用modify

4.唯一约束unique 删除唯一约束drop index列名

级联操作

级联更新 on update cascade

级联删除 on delete cascade

数据库的设计

分类:一对一 一对多 多对多 多对一

数据库设计的范式

为了减少数据库的冗余从第一范式到第五范式 主键拆分  一般到第三范式

数据库的备份与还原

备份:MySQLdump -u用户名 -p 密码 数据库名称> 保存路劲

还原:登录数据库->创建数据库->使用数据库->执行文件。source 文件路径

#Java学习之路——基础阶段二(第十篇)的更多相关文章

  1. #Java学习之路——基础阶段二(第一篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  2. #Java学习之路——基础阶段二(第九篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  3. #Java学习之路——基础阶段二(第二篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  4. #Java学习之路——基础阶段(第十篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  5. #Java学习之路——基础阶段二(第三篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  6. #Java学习之路——基础阶段二(第八篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  7. #Java学习之路——基础阶段二(第七篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  8. #Java学习之路——基础阶段二(第六篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

  9. #Java学习之路——基础阶段二(第五篇)

    我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...

随机推荐

  1. netty相关

    https://my.oschina.net/jamaly/blog/272385两个客户端之间的交互 http://blog.csdn.net/a953713428/article/details/ ...

  2. 在windows下安装git中文版客户端并连接gitlab

    下载git Windows客户端 git客户端下载地址:https://git-scm.com/downloads 我这里下载的是Git-2.14.0-64-bit.exe版本 下载TortoiseG ...

  3. 图解 HTTP 协议

    原文出处: BYSocket (@BYSocket) 一.技术基石及概述 问:什么是HTTP?答:HTTP是一个客户端和服务器端请求和响应的标准TCP.其实建立在TCP之上的. 当我们打开百度网页时, ...

  4. Spark2.3(三十五)Spark Structured Streaming源代码剖析(从CSDN和Github中看到别人分析的源代码的文章值得收藏)

    从CSDN中读取到关于spark structured streaming源代码分析不错的几篇文章 spark源码分析--事件总线LiveListenerBus spark事件总线的核心是LiveLi ...

  5. Android HandlerThread 源代码分析

    HandlerThread 简单介绍: 我们知道Thread线程是一次性消费品,当Thread线程运行完一个耗时的任务之后.线程就会被自己主动销毁了.假设此时我又有一 个耗时任务须要运行,我们不得不又 ...

  6. Flume采集Nginx日志到HDFS

    下载apache-flume-1.7.0-bin.tar.gz,用 tar -zxvf 解压,在/etc/profile文件中增加设置: export FLUME_HOME=/opt/apache-f ...

  7. 基于Python使用Redis的一些想法和建议

    目录 1关于Redis使用的一点想法 1.1进行缓存前,需考虑 1.2进行缓存后,需考虑 1.3缓存使用一段时间后 2编写Redis数据库层规范建议 2.1选择适合的redis客户端 2.2规范化定义 ...

  8. php调试用的几个小方法

    1.PHP把一个对象转化成json字符串 $json_string = json_encode($object, JSON_FORCE_OBJECT); json_encode($object); / ...

  9. 基于Centos搭建 Firekylin 个人网站

    系统要求: CentOS 7.2 64 位操作系统 安装 Node.js 使用 yum 命令安装 Node.js curl --silent --location https://rpm.nodeso ...

  10. 基于CentOS 搭建 FTP 文件服务

    系统要求: CentOS 7.2 64 位操作系统 一. 安装 VSFTPD (vsftpd 是在 Linux 上被广泛使用的 FTP 服务器,根据其[官网介绍][https://security.a ...