我的学习阶段是跟着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. [BZOJ3080]Minimum Variance Spanning Tree/[BZOJ3754]Tree之最小方差树

    [BZOJ3080]Minimum Variance Spanning Tree/[BZOJ3754]Tree之最小方差树 题目大意: 给定一个\(n(n\le50)\)个点,\(m(m\le1000 ...

  2. Android MediaCodec的数据处理方式分析

    *由于工作需要,需要利用MediaCodec实现Playback及Transcode等功能,故在学习过程中翻译了Google官方的MediaCodec API文档,由于作者水平限制,文中难免有错误和不 ...

  3. C#键盘事件处理父窗体子窗体

    :                             :                             MessageBox.Show(, , Keys.F1);            ...

  4. WinPcap权威指南(一)

    WinPcap是一个开源的网络抓包模块,顾名思义,它只能工作在Windows下,但本文介绍的知识并不局限于任何操作系统和开发语言,因为网络协议本身是没有这些区别的.阅读本指南之前,请先下载WinPca ...

  5. C++11 多线程编程 使用lambda创建std::thread (生产/消费者模式)

    要写个tcp server / client的博客,想着先写个c++11多线程程序.方便后面写博客使用. 目前c++11中写多线程已经很方便了,不用再像之前的pthread_create,c++11中 ...

  6. tmux分屏幕

    1. tmux  a  -t  fly 连接上tmux 2. 左右分屏幕,ctrl+a ,再按% 上下分屏: ctrl+a, 再按“ 切换屏幕: ctrl+a, 再按o 关闭终端: ctrl+a, 再 ...

  7. 基于redis 实现分布式锁(二)

    https://blog.csdn.net/xiaolyuh123/article/details/78551345 分布式锁的解决方式 基于数据库表做乐观锁,用于分布式锁.(适用于小并发) 使用me ...

  8. MySQL中的insert ignore into, replace into用法总结

    MySQL replace into 有三种形式: 1. replace into tbl_name(col_name, ...) values(...) 2. replace into tbl_na ...

  9. 五种常见的ASP.NET安全缺陷

    保证应用程序的安全应当从编写第一行代码的时候开始做起,原因很简单,随着应用规模的发展,修补安全漏洞所需的代价也随之快速增长.根据IBM的系统科学协会(SystemsSciencesInstitute) ...

  10. (原)IOU的计算

    转载请注明出处: http://www.cnblogs.com/darkknightzh/p/9043395.html 参考网址: https://github.com/deepinsight/ins ...