Spring Boot 2系列(三十八):全局异常统一处理

  Spring Boot 在默认情况下,提供了 /error 映射来处理所有错误,在 Servlet 容器里注册了全局的错误页面(Whitelabel Error Page)并返回客户端。

  也可以自定义替换默认的异常处理, 通过实现 ErrorController 接口并注册为 Bean;或者添加 ErrorAttributes 类型的 Bean 来替换内容。

  通常情况下,都会自定义全局异常统一处理,返回统一的消息结构体,便于了解和快速定位问题,Spring 提供了 @ControllerAdvice 注解,非常好实现。

  Spring Boot 官方文档,错误处理:28.1.11 Error Handling

阅读更多

MySQL系列(10): MySQL InnoDB 锁机制

  是计算机协调多个进程或并发访问某一资源的机制,数据也是供许多用户共享的资源。Java有机制,数据库也有机制。数据库锁定机制简单来说,是为了保证在并发情况下数据的一致性、有效性。  

  MySQL锁机制是由存储引擎提供的,InnoDB存储引擎支持行级锁表级锁,默认级别行级锁(row-Level locking); MyISAMMEMORY存储引擎采用的是表级锁(table-level locking),BDB存储引擎采用的是页面锁(page-level locking),也支持表级锁BDB已成为历史。

  InnoDBMyISAM 最大的不同有两点:一是支持事务,二是采用行级锁。

  MySQL 5.7 官方文档:14.7.1 InnoDB Locking14.7.3 Locks Set by Different SQL Statements in InnoDB14.7.5 Deadlocks in InnoDB

阅读更多

MySQL系列(9): MySQL InnoDB存储引擎之事务模型

  事务(Transaction )是InnoDB存储引擎一个很重要并且区别于其它存储引擎的特性。 使用了 Innodb 存储引擎的数据库或表才支持事务。

  **事务:**指作为单个逻辑工作单元执行的一组操作,这组操作的各个单元要么全部成功,要么全部失败。
  **事务处理:**通过将一组相关操作组合为一个要么全部成功,要么全部失败的单元,保证数据一致性。

阅读更多

MySQL系列(8): group by 坑和 update 强制条件

MySQL 5.7.5 版本,默认开启了only_full_group_by模式,select字段只能是group by的字段,否则会报错,可以关闭该模式,或使用 any_value(column) 来抑制该异常。

防止在生产中使用 update 语句漏带条件导致全表更新事故,开启安全更新模式,强制带条件更新,否则报错。 

阅读更多

MySQL系列(7): 存储引擎介绍

MySQL 默认支持多种存储引擎,提供了灵活的存储,以支持不同场景的应用。

MySQL 8.0 版本,默认使用 InnoDB存储引擎,即建表语句(CREATE TABLE) 不带 ENGINE=子句会创建 InnoDB 表。

关于 MySQL 存储引擎,可以单独写成一个系列文章,后续有时间列入计划中。The InnoDB Storage Engine - 官网lternative Storage Engines - 替代引擎

阅读更多

MySQL系列(4): MySQL 常用函数

  MySQL 提供了丰富的函数,可以帮助编写简单快捷的 SQL 语句。比如字符串处理、数值运算、日期运算等。

  常用的函数有字符串函数日期函数数值函数聚合函数,还有 全文检索函数转换函数XML函数位操作函数加密解密函数锁函数MySQL信息函数几何函数空间函数JSON 函数MySQL 企业加密函数其它函数

  MySQL 8.0 函数和操作官方文档

  此篇文章目的是作为字典,看过一遍先了让自己有个映像有些函数可以实现某些功能,具体需要使用再查询,多用几次就记住了。

阅读更多

MySQL系列(3): 基本数据类与类型选择

  MySQL 支持多种数据类型来存储数据,包括数值类型、字符串类型、时间和日期类型、JSON格式类型
  
  本篇是对 MySQL 5.7 版本官方手册 **[MySQL 5.7 Reference Manual . Chapter 11 Data Types]**章节的简单汇总,便于快速查看。

阅读更多

MySQL系列(2): 快速了解基本的 SQL 操作

快速了解基本的 SQL 语句。

SQL(Structure Query Language - 结构化查询语言),已是关系数据库的基本标准。

本篇涉及到的 SQL 语法可能并不完整,主要是为了快速构建一个 SQL 操作的概念。实际工作中大多会借用工具来快速操作,如SQLyog、Navicat

阅读更多