fastjson框架如何处理boolean?CURRENT_TIMESTAMP使用报错?什么是 ONLINE DDL 及 pt-online-schema-change ? getBytes引起的乱码问题?
一、使用fastjson框架进行序列化时,若莫个参数为Boolean类型,而json里的值是其它类型时,框架如何处理?
1、true, false,正常赋值
2、int类型,若为1,则为true,否则为false
3、number类型,若强转int为1,则为true,否则为false
4、string类型,若为空串、"null"、"NULL"则为null;若为"true","1"则为true;若为"false","0"则为false
4、其它情况抛错can not cast to boolean
二、关于CURRENT_TIMESTAMP的问题:
执行以下SQL报错:
CREATE TABLE `test` (
`id` bigint() NOT NULL AUTO_INCREMENT,
`create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
`update_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE=INNODB;
错误:there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause
原因:MYSQL 5.6以下的版本只支持一个字段将当前时间戳为默认值
四种处理方法:
1、当更新数据时,用触发器去设置 update_time 为当前时间
2、当插入数据时,用触发器去设置 create_time 为当前时间
3、create_time 设为 CURRENT_TIMESTAMP,update_time设为 '0000-00-00 00:00:00',更新、插入时去重新设置更新时间
4、更新MYSQL版本到5.6
三、什么是DDL,什么是ONLINE DDL, 什么是pt-online-schema-change?
DDL:数据定义语言DDL,用来创建数据库中的各种对象-----表、视图、索引、同义词、聚簇
DML: insert, update, delete
DQL: select
DCL: 授予或回收访问数据库的某种特权,并控制数据库操纵事务发生的时间及效果,对数据库实行监视
MYSQL 5.1的DDL(添加索引):
建新表(包括新加的索引),锁旧表,拷数据到新表,改表名,删旧表
MYSQL 5.5,引入FIC(Fast Index Creation):
支持在新增删除二级索引时,不去新建表,但仍需锁表
MYSQL 5.6引入ONLINE DDL:
支持在修改表结构的同时,依然允许DML操作,不是所有DDL操作都支持,具体需参考MYSQL官方文档:https://dev.mysql.com/doc/refman/5.6/en/innodb-online-ddl-operations.html
ONLINE DDL的一些限制:
1、无论是涉及到copy table还是添加索引,都需要保证有足够的磁盘大小
2、主从结构,主库在DDL时,会同时执行DML操作,但是从库由于是单个SQL THREAD按顺序应用log,所以得等ALTER语句执行完,才可以执行下一条,这时会有主从延迟。
3、在进行 DDL 操作时会保存操作时间内产生的日志,这与 facebook OSC 的临时表,但是其保存在内存中,而该内存的大小由参数 innodb_online_alter_log_max_size 定义,默认大小为 128M,若请求比较频繁,需要进行调整。
4、ONLINE DDL执行期间,仍会有短时间的排它锁,如准备阶段,提交阶段。
pt-online-schema-change:
第三方工具,支持ONLINE DDL
pt-online-schema-change 工作过程:
1、建新表
2、新表进行DDL操作
3、原表创建三种触发器对应insert,update,delete
3、从原表拷贝数据到新表,期间的DML操作,通过触发器更新到新表
4、锁原表,改表名
5、删旧表
pt-online-schema-change的一些限制:
1、原表不允许有触发器
2、原表必须有主键
参考博客:
https://cloud.tencent.com/developer/article/1005177
http://seanlook.com/2016/05/24/mysql-online-ddl-concept/
http://keithlan.github.io/2018/11/23/mysql_online_ddl_inside/
四、关于getBytes方法
背景:
使用第三方SDK,出现中文乱码,依赖的SDK,有以下代码:
headers.put(key, Base64Utils.encodeAsString(value.getBytes()));
出错原因:
vlaue.getBytes方法,在没有设置字符集时,会默认以JVM默认的字符集(默认操作系统的字符集)进行处理。而服务器上,操作系统的字符集默认为US-ASCII,而value实际上是UTF-8的,这时候就出现了乱码情况。
解决方案:
配置JVM参数,设置JVM默认的字符集为UTF-8:-Dfile.encoding=UTF-8
分析源码:
public byte[] getBytes() {
return StringCoding.encode(value, 0, value.length);
}
static byte[] encode(char[] ca, int off, int len) {
String csn = Charset.defaultCharset().name();
try {
// use charset name encode() variant which provides caching.
return encode(csn, ca, off, len);
} catch (UnsupportedEncodingException x) {
warnUnsupportedCharset(csn);
}
try {
return encode("ISO-8859-1", ca, off, len);
} catch (UnsupportedEncodingException x) {
// If this code is hit during VM initialization, MessageUtils is
// the only way we will be able to get any kind of error message.
MessageUtils.err("ISO-8859-1 charset not available: " + x.toString());
// If we can not find ISO-8859-1 (a required encoding) then things
// are seriously wrong with the installation.
System.exit(1);
return null;
}
}
可以发现在使用getBytes方法时,默认取使用Charset.defaultCharset()方法来获得字符集
然后再看defaultCharset()方法的源码
private static volatile Charset defaultCharset;
public static Charset defaultCharset() {
if (defaultCharset == null) {
synchronized (Charset.class) {
String csn = AccessController.doPrivileged(new GetPropertyAction("file.encoding"));
Charset cs = lookup(csn);
if (cs != null)
defaultCharset = cs;
else
defaultCharset = forName("UTF-8");
}
}
return defaultCharset;
}
defaultCharset其实是个单例,JVM启动后,只会取加载一次file.encoding。
而file.encoding在没有配置的情况,取的是操作系统的字符集。
若想改变默认字符集,则可以设置JVM参数:-Dfile.encoding=UTF-8
fastjson框架如何处理boolean?CURRENT_TIMESTAMP使用报错?什么是 ONLINE DDL 及 pt-online-schema-change ? getBytes引起的乱码问题?的更多相关文章
- animate is not a function(zepto 使用报错)[转]
animate is not a function(zepto 使用报错) 1.为什么使用zepto写animate报错? 因为zepto默认构建包含: Core, Ajax, Event, Form ...
- adb驱动安装和使用报错笔记
adb驱动安装 adb驱动下载地址:https://adb.clockworkmod.com/ 安装时候选择一个容易记住的路径,这个很重要,因为adb驱动没有自动配置环境变量,所以实验时候将adb安装 ...
- Windows下Git使用报错:warning:LF will be replaced by CRLF in ××××.××
Windows下Git使用报错: warning:LF will be replaced by CRLF in ××××.××(文件名) The file will have its original ...
- yum源使用报错
CentOS系统yum源使用报错:Error: Cannot retrieve repository metadata (repomd.xml) for repository: rpmforge. 服 ...
- 2019-9-9:渗透测试,docker下载dvwa,使用报错型sql注入dvwa
docker下载dvwa镜像,报错型注入dvwa,low级 一,安装并配置docker 1,更新源,apt-get update && apt-get upgrade &&am ...
- .net core中Grpc使用报错:The remote certificate is invalid according to the validation procedure.
因为Grpc采用HTTP/2作为通信协议,默认采用LTS/SSL加密方式传输,比如使用.net core启动一个服务端(被调用方)时: public static IHostBuilder Creat ...
- VirtualBox使用报错
VirtualBox使用报错 1.启动报错:Failed to instantiate CLSID_VirtualBox... 报错内容: Failed to instantiate CLSID_Vi ...
- 记一次GRPC使用报错排查
项目一直使用grpc作为服务交互程序,其中我负责的java模块第一次引用该框架:当框架搭建好后,建立客户端代码,报错: Runable Error:java.lang.IllegalAccessErr ...
- antd-mobile使用报错
在第一次使用时,按照官网的进行配置,完了报错找不到antd-mobile下面的css 解决方法来源于 :https://github.com/ant-design/ant-design-mobile/ ...
随机推荐
- Codevs 2800 送外卖(状压DP)
2800 送外卖 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题目描述 Description 有一个送外卖的,他手上有n份订单,他要把n份东西,分别送达n ...
- 洛谷 P3380 【模板】二逼平衡树(树套树)-线段树套splay
P3380 [模板]二逼平衡树(树套树) 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作: 查询k在区间内的排名 查询区间内排名为k的值 修改某一位值上的数 ...
- 刷题记录:[XNUCA2019Qualifier]EasyPHP
目录 刷题记录:[XNUCA2019Qualifier]EasyPHP 解法一 1.error_log结合log_errors自定义错误日志 2.include_path设置包含路径 3.php_va ...
- 关于SpringCloud、SpringBoot简单讲解
什么是Spring Boot 用我的话来理解,Spring Boot就是整合了框架的框架,它让一切依赖都变得有序简单,你不用操心A.jar是什么版本,又依赖哪些版本的jar,它默认配置了很多框架的使 ...
- MySQL事务隔离级别(一)
本文实验的测试环境:Windows 10+cmd+MySQL5.6.36+InnoDB 一.事务的基本要素(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做 ...
- MySQL导入csv文件内容到Table及数据库的自增主键设置
写在前面 目的是测试将csv文件内容导入到表中, 同时记录一下自增主键的设置. 测试采用MySQL8.0. 新建表customer_info如下, 未设置主键. 修改上表, 添加主键id, 并设置为自 ...
- Python开发人员指南
本指南是一个全面的资源贡献 给Python的 -为新的和经验丰富的贡献者.这是 保持由维护的Python同一社区.我们欢迎您对Python的贡献! 快速参考 这是设置和添加补丁所需的基本步骤.了解基础 ...
- net use命令详解(转)
net use命令详解 1)建立空连接: net use \\IP\ipc$ "" /user:"" (一定要注意:这一行命令中包含了3个空格) 2)建立非空连 ...
- js写评价的星星
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/ouqi_qiou/article/det ...
- Linux配置crontab
1. 添加任务(每分钟执行一次)crontab -e* * * * * /home/lings/logRotate.sh 2. 查看日志Jun 5 20:25:01 localhost CROND[8 ...