做了6年的Java,mysql去重查询方法
前言:
求职季在即,技巧千万条,硬实力才是关键,听说今年疫情大环境不好,更要好好准备才行。MySQL是Java程序员面向高级的必备技能,很多朋友在面试时经常在这里折戟沉沙,饮恨不已。熟练掌握MySQL知识,在实践中具有很强的操作性,尤其是在互联网行业,不仅要写好代码、实现功能,而且还要在高并发的情况下能够正常运转。
这篇文章总结了许多关于MySQL方面的知识总结,以及面试多家总结出来的常问面试题,希望对大家有所帮助。
JAVA基础
- JAVA异常分类及处理
- 异常分类
- 异常的处理方式
- Throw和throws的区别
- JAVA反射
- 动态语言
- 反射机制概念 (运行状态中知道类所有的属性和方法)
- Java反射API
- 反射使用步骤(获取Class对象、调用对象方法)
- 获取Class对象的3种方法
- 创建对象的两种方法
- JAVA注解
- JAVA内部类
- JAVA泛型
- JAVA序列化(创建可复用的Java对象)
- JAVA复制
JAVA集合
- 接口继承关系和实现
- List
- ArrayList(数组)
- Vector(数组实现、线程同步)
- LinkList(链表)
- Set
- HashSet(Hash表)
- TreeSet(二叉树)
- LinkHashSet(HashSet+LinkedHashMap)
- Map
- HashMap(数组+链表+红黑树)
- JAVA7实现
- JAVA8实现
- ConcurrentHashMap
- Segment段
- 线程安全(Segment 继承 ReentrantLock 加锁)
- 并行度(默认16)
- HashTable(线程安全)
- TreeMap(可排序)
- LinkHashMap(记录插入顺序)
JAVA多线程并发
- JAVA并发知识库
- JAVA线程实现/创建方式
- 4种线程池
- 线程生命周期(状态)
- 终止线程4种方式
- sleep与wait 区别
- start与run区别
- JAVA后台线程
- JAVA锁
- 线程基本方法
- 线程上下文切换
- 同步锁与死锁
- 线程池原理
- JAVA阻塞队列原理
- CyclicBarrier、CountDownLatch、Semaphore的用法
- volatile关键字的作用(变量可见性、禁止重排序)
- 如何在两个线程之间共享数据
- ThreadLocal作用(线程本地存储)
- synchronized和ReentrantLock的区别
- ConcurrentHashMap并发
- Java中用到的线程调度
- 进程调度算法
- 什么是CAS(比较并交换-乐观锁机制-锁自旋)
- 什么是 AQS(抽象的队列同步器)
JVM
- 线程
- JVM内存区域
- JVM运行时内存
- 垃圾回收与算法
- JAVA 四种引用类型
- GC分代收集算法 VS 分区收集算法
- GC垃圾收集器
- JAVA IO/NIO
- JVM 类加载机制
Spring 原理
- Spring 特点
- 轻量级
- 控制反转
- 面向切面
- 容器
- 框架集合
- Spring 核心组件
- Spring 常用模块
- Spring 主要包
- Spring 常用注解
- Spring IOC原理
- Spring APO原理
- Spring MVC原理
- Spring Boot原理
- JPA原理
- Mybatis缓存
- Tomcat架构
微服务
- 服务注册发现
- 客户端注册(zookeeper)
- 第三方注册(独立的服务Registrar)
- 客户端发现
- 服务端发现
- Consul
- Eureka
- SmartStack
- Etcd
- API 网关
- 请求转发
- 响应合并
- 协议转换
- 数据转换
- 安全认证
- 配置中心
- zookeeper配置中心
- 配置中心数据分类
- 事件调度(kafka)
- 服务跟踪(starter-sleuth)
- 服务熔断(Hystrix)
- Hystrix断路器机制
- API管理
Netty 与RPC
- Netty 原理
- Netty 高性能
- 多路复用通讯方式
- 异步通讯NIO
- 零拷贝(DIRECT BUFFERS使用堆外直接内存)
- 内存池(基于内存池的缓冲区重用机制)
- 高效的Reactor线程模型
- 无锁设计、线程绑定
- 高性能的序列化框架
- Netty RPC实现
- 关键技术
- 核心流程
- 消息编解码
- 通讯过程
- RMI实现方式
- 实现步骤
- Protoclol Buffer
- Thrift
分布式缓存
- 缓存雪崩
- 缓存穿透
- 缓存预热
- 缓存更新
- 缓存降级
网络
- 网络7层架构
- TCP/IP原理
- 网络访问层(Network Access Layer)
- 网络层(Internet Layer)
- 传输层(Tramsport Layer-TCP/UDP)
- 应用层(Application Layer)
- TCP三次握手/四次挥手
- HTTP原理
- 传输流程
- HTTP状态
- HTTPS
- CDN 原理
- 分发服务系统
- 负载均衡系统
- 管理系统
日志
- Slf4j
- Log4j
- LogBack
- Logback优点
- ELK
Zookeeper
- Zookeeper概念
- Zookeeper角色
- Leader
- Follower
- Observer
- ZAB协议
- 事务编号 Zxid(事务请求计数器+ epoch)
- epoch
- Zab协议有两种模式-恢复模式(选主)、广播模式(同步)
- ZAB协议4阶段
- Leader election(选举阶段-选出准Leader)
- ZAB协议JAVA实现(FLE-发现阶段和同步合并为 Recovery Phase(恢复阶段))
- 投票机制
- Zookeeper工作原理(原子广播)
- Znode有四种形式的目录节点
Kafka
- Kafka概念
- Kafka数据存储设计
- partition的数据文件(offset,MessageSize,data)
- 数据文件分段segment(顺序读写、分段命令、二分查找)
- 数据文件索引(分段索引、稀疏存储)
- 生产者设计
- 负载均衡(partition会均衡分布到不同broker上)
- 批量发送
- 压缩(GZIP或Snappy)
- 消费者设计
- Consumer Group
RabbitMQ
- RabbitMQ概念
- RabbitMQ架构
- Exchange 类型
Hbase
- Hbase概念
- 列式存储
- Hbase核心概念
- Hbase核心架构
- Hbase的写逻辑
- HBase vs Cassandra
- MongoDB
- MongoDB概念
- MongoDB特点
Cassandra
- Cassandra概念
- 数据模型
- Cassandra一致Hash和虚拟节点
- Gossip协议
- 数据复制
- 数据写请求和协调者
- 数据读请求和后台修复
- 数据存储(CommitLog、MemTable、SSTable)
- 二级索引(对要索引的value摘要,生成RowKey)
- 数据读写
设计模式
- 设计原则
- 工厂方法模式
- 抽象工厂模式
- 单例模式
- 建造者模式
- 原型模式
- 适配器模式
- 装饰器模式
- 代理模式
- 外观模式
- 桥接模式
- 组合模式
- 享元模式
- 策略模式
- 模板方法模式
- 观察者模式
- 迭代的模式
- 责任链模式
- 命令模式
- 备忘录模式
负载均衡
- 四层负载均衡 vs 七层负载均衡
- 负载均衡算法/策略
- LVS
- Keepalive
- Nginx反向代理负载均衡
- HAProxy
数据库
- 存储引擎
- 索引
- 数据库三范式
- 数据库是事务
- 存储过程(特定功能的SQL 语句集)
- 触发器(一段能自动执行的程序)
- 数据库并发策略
- 数据库锁
- 基于Redis分布式锁
- 分区分表
- 两阶段提交协议
- 三阶段提交协议
- 柔性事务
- CAP
一致性算法
- Paxos
- Zab
- Raft
- NWR
- Gossip
- 一致性Hash
- 一致性Hash特性
- 一致性Hash原理
JAVA算法
- 二分查找
- 冒泡排序算法
- 插入排序算法
- 快速排序算法
- 希尔排序算法
- 归并排序算法
- 桶排序算法
- 基数排序算法
- 剪枝算法
- 回溯算法
- 最短路径算法
- 最大的数组算法
- 最长公共子序算法
- 最小生成树算法
数据结构
- 栈(stack)
- 队列(queue)
- 链表(Link)
- 散列表(Hash Table)
- 排序二叉树
- 红黑树
- B-TREE
- 位图
加密算法
- AES
- RSA
- CRC
- MD5
Hadoop
- Hadoop概念
- HDFS
- Client
- NameNode
- Secondary NameNode
- DataNode
- MapReduce
- JobTracker
- TaskTracker
- Task
- Reduce Task 执行过程
- Hadoop MapReduce 作业的生命周期
- 作业提交与初始化
- 任务调度与监控。
- 任务运行环境准备
- 任务执行
- 作业完成
Spark
- Spark概念
- 核心架构
- 核心组件
- SPARK编程模型
- SPARK计算模型
- SPARK运行流程
- SPARK RDD流程
- SPARK RDD
Storm
- Storm概念
- 集群架构
- Nimbus(master-代码分发给Supervisor)
- Supervisor(slave-管理Worker进程的启动和终止)
- Worker(具体处理组件逻辑的进程)
- Task
- ZooKeeper
- 编程模型(spout->tuple->bolt)
- opology运行
- Storm Streaming Grouping
- ResourceManager
- NodeManager
- ApplicationMaster
- YARN运行流程
机器学习
- 决策树
- 随机森林算法
- 逻辑回归
- SVM
- 朴素贝叶斯
- K 最近邻算法
- K 均值算法
- Adaboost 算法
- 神经网络
- 马尔可夫
云计算
- SaaS
- PaaS
- IaaS
- Docker
- Openstack
- Namespaces
- 进程(CLONE_NEWPID 实现的进程隔离)
- Libnetwork与网络隔离
- 资源隔离与CGroups
- 镜像与UnionFS
- 存储驱动
写在最后
作为一名即将求职的程序员,面对一个可能跟近些年非常不同的 2019 年,你的就业机会和风口会出现在哪里?在这种新环境下,工作应该选择大厂还是小公司?已有几年工作经验的老兵,又应该如何保持和提升自身竞争力,转被动为主动?
就目前大环境来看,跳槽成功的难度比往年高很多。一个明显的感受:今年的面试,无论一面还是二面,都很考验Java程序员的技术功底。
最近我整理了一份复习用的面试题及面试高频的考点题及技术点梳理成一份“Java经典面试问题(含答案解析).pdf和一份网上搜集的“Java程序员面试笔试真题库.pdf”(实际上比预期多花了不少精力),包含分布式架构、高可扩展、高性能、高并发、Jvm性能调优、Spring,MyBatis,Nginx源码分析,Redis,ActiveMQ、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多个知识点高级进阶干货!
由于篇幅有限,为了方便大家观看,这里以图片的形式给大家展示部分的目录和答案截图!有需要的朋友可以戳这里免费获取
Java经典面试问题(含答案解析)
阿里巴巴技术笔试心得
上比预期多花了不少精力),包含分布式架构、高可扩展、高性能、高并发、Jvm性能调优、Spring,MyBatis,Nginx源码分析,Redis,ActiveMQ、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多个知识点高级进阶干货!
由于篇幅有限,为了方便大家观看,这里以图片的形式给大家展示部分的目录和答案截图!有需要的朋友可以戳这里免费获取
[外链图片转存中…(img-Gsi1O3I3-1624014964535)]
Java经典面试问题(含答案解析)
[外链图片转存中…(img-keUaCamS-1624014964538)]
阿里巴巴技术笔试心得
[外链图片转存中…(img-oXLSG6fB-1624014964539)]
做了6年的Java,mysql去重查询方法相关推荐
- mysql去重查询的三种方法
文章目录 前言 一.插入测试数据 二.剔除重复数据方法 1.方法一:使用distinct 2.方法二:使用group by 3.方法三:使用开窗函数 总结 前言 数据库生成环境中经常会遇到表中有重复的 ...
- java mysql 分页查询_MySQL分页查询方法及优化
当数据库的数据量很大时,一次性查询结果就会变得很慢,为了提高查询效率,我们可以使用MySQL的分页查询功能.本文就为大家带来MySQL分页查询方法及优化. 推荐阅读: 分页查询方法: 在MySQL中, ...
- ORACLE和MYSQL 去重查询
ORACLE // 去重查询 select * from(select 别名1.*, row_number() over(partition by 别名1.列名1 order by 别名1.列名2 A ...
- MySQL去重查询只保留一条最新的记录
需求:MySQL去重查询只保留一条最新的记录 文章目录 易错的写法 正确的写法-1 正确的写法-2 正确的写法-3 易错的写法 表结构与初始数据如下SQL文件: -- MySQL dump 10.13 ...
- MySQL分页查询方法及优化
MySQL分页查询方法及优化 http://uusama.com/458.html
- 高级查询(二)+php中文网,MySQL高级查询方法之记录查询
欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 此文章主要向大家描述的是MySQL高级查询方法之记录查询的实际操作步骤,以及对其实际操作过程中要用到的代码的详细描述,以下 ...
- mysql去重查询只留一条最新的
mysql查询到时候如何去重(指定两个条件一样的数据) 可以使用groupby以dname分组 select*fromtablegroupbydname 这样不行,,因为我还有dname一样,,但是s ...
- Mysql去重查询(根据指定字段去重)
在日常数据查询中,多有需要进行数据去重的查询,或删除重复数据的情况,以下罗列集中数据去重查询: 1.根据全部字段的去重查询: select distinct * from table 2.根据某些字段 ...
- mysql去重查询数量_mysql 数据去重
数据库版本mysql5.5.10 操作工具navicate for mysql 插入数据重复了 用mysql语句去重 -- 查询数量是否大于1 大于1 表示有重复数据 SELECT cou ...
最新文章
- linux 关闭开机 ftp,解决linux ftp匿名上传、下载开机自启问题
- android闹钟唤醒不准的原因_俄罗斯睡眠专家:闹钟铃声选错了,可能扰乱你的内分泌...
- .NetCore使用skywalking实现实时性能监控
- 名片大全:30款精美的企业名片设计欣赏
- 一张“黑洞”照片需半吨重硬盘?!
- SAS学习笔记之《SAS编程与数据挖掘商业案例》(3)变量操作、观测值操作、SAS数据集管理...
- 软件配置管理(CN) Google讨论组
- JAVA加勒比_【JAVA】synchronized关键字
- 伴生对象-apply方法
- 陶哲轩实分析 习题 12.5.8 :度量空间中有界闭集不一定是紧集
- HTML 标签的 target 属性
- 计算机odbc数据源管理位置,ODBC数据源管理器的主要功能是什么 ODBC数据源怎么配置...
- 无人驾驶综述:等级划分
- 深度学习中的激活函数及其作用
- android水印的添加,Android添加水印的正确方法 只要三步!
- 从中国的山水画谈谈游戏场景设计该有的状态
- java网络爬虫如何控制爬取的深度_Java 动手写爬虫: 二、 深度爬取
- c语言程序设计第二张答案,自学考试《C语言程序设计》习题及答案_第2页
- Cannot connect:由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败。192.168.0.113:22
- 29岁了还一事无成是人生的常态?