pt-online-schema-change和默认值关系

在使用pt-online-schema-change会遇到如下的错误导致表修改失败:

Copying rows caused a MySQL error 1364,Message: Field ‘XXX‘ doesn‘t have a default value

例子1:

#修改的SQL:
ALTER TABLE `live_comment` ADD `sourcefrom` VARCHAR(15) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT ‘来源标志‘ AFTER `ip`, ADD `type` INT UNSIGNED NOT NULL DEFAULT ‘0‘ COMMENT ‘评论类型‘ AFTER `sourcefrom`, ADD INDEX (`type`)

错误信息为:

`sportslive`.`live_comment` was not altered.
Error copying rows from `sportslive`.`live_comment` to `sportslive`.`_live_comment_new`: Copying rows caused a MySQL error 1364:
    Level: Warning
     Code: 1364
  Message: Field ‘sourcefrom‘ doesn‘t have a default value

对应的表结构为:

CREATE TABLE `sportslive`.`_live_comment_new` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `live_id` int(11) NOT NULL DEFAULT ‘0‘,
  `content` varchar(200) NOT NULL DEFAULT ‘‘,
  `reply_uid` bigint(20) NOT NULL DEFAULT ‘0‘,
  `reply_username` varchar(30) NOT NULL DEFAULT ‘‘,
  `reply_content` varchar(200) NOT NULL DEFAULT ‘‘,
  `reply_profile_pic` varchar(100) NOT NULL DEFAULT ‘‘,
  `parent_id` int(11) NOT NULL,
  `uid` bigint(20) NOT NULL DEFAULT ‘0‘,
  `username` varchar(30) NOT NULL DEFAULT ‘‘,
  `profile_pic` varchar(100) NOT NULL DEFAULT ‘‘,
  `addtime` datetime NOT NULL,
  `ip` varchar(15) NOT NULL DEFAULT ‘‘,
  `prior` tinyint(4) NOT NULL DEFAULT ‘0‘ COMMENT ‘xxxx‘,
  PRIMARY KEY (`id`),
  KEY `live_id` (`live_id`)
) ENGINE=InnoDB AUTO_INCREMENT=296173 DEFAULT CHARSET=utf8

例子2:

修改的SQL:

ALTER TABLE `mb_post_spider_1209` CHANGE `category` `category` VARCHAR(8) NOT NULL COMMENT ‘‘, CHANGE `reposts_count` `reposts_count` INT(11) UNSIGNED NOT NULL DEFAULT ‘0‘ COMMENT ‘‘, CHANGE `heat` `heat` DECIMAL(8,5) UNSIGNED NOT NULL DEFAULT ‘0.00000‘ COMMENT ‘‘, CHANGE `spider_date` `spider_date` INT(8) UNSIGNED NOT NULL DEFAULT ‘0‘ COMMENT ‘抓取时间‘, CHANGE `main_cat` `main_cat` TINYINT(1) NOT NULL COMMENT ‘‘, CHANGE `sub_cat` `sub_cat` TINYINT(1) NOT NULL COMMENT ‘‘, CHANGE `state` `state` TINYINT(1) UNSIGNED NOT NULL DEFAULT ‘0‘ COMMENT ‘‘, CHANGE `bid` `bid` BIGINT(20) UNSIGNED NOT NULL DEFAULT ‘0‘ COMMENT ‘‘, CHANGE `bname` `bname` VARCHAR(32) NOT NULL COMMENT ‘‘

Warning信息如下:

Error copying rows from `mb_content`.`mb_post_spider_1209` to `mb_content`.`_mb_post_spider_1209_new`: Copying rows caused a MySQL error 1048:
    Level: Warning
     Code: 1048
  Message: Column ‘bname‘ cannot be null

http://www.mysqlperformanceblog.com/2012/06/21/pt-online-schema-change-and-default-values/

pt-online-schema-change和默认值关系,布布扣,bubuko.com

时间: 2024-12-17 02:46:41

pt-online-schema-change和默认值关系的相关文章

Hibernate实体类与数据表字段默认值之间的优先关系

在日常的应用开发过程中,我们一般都会使用对象关系映射来通过面向对象的编程模型来解决数据库的操作,我们生产过程当中使用较多的当属Hibernate框架了,他非常灵活,为我们提供了多种方式来实现数据层的操作与管理.通过实体类与数据表的映射,实体类对应表,属性对应字段就可以将我们想要生产的对象赋值到数据库,但是我们有时也需要查询对象,但是无论什么操作,都必须通过实体类来传递数据. 有时我们数据库有一些字段是数据库自动赋值,禁止用户通过程序修改的,如记录生成时间,那么如果你实体类按照正常情况下,你为了查

8. react 基础 - props 默认值和类型限制 与 Props , State , render 函数 关系

一. PropTypes 与 DefaultProps 官方文档 1. PropTypes 属性校验 引入 PropTypes import PropTypes from 'prop-types'; 强校验 props 属性 eg: import React, { Component } from 'react' import PropTypes from 'prop-types' class TodoItem extends Component{ constructor(props){ sup

c3p0配置之preferredTestQuery参数默认值探秘

http://www.mchange.com/projects/c3p0/ c3p0的配置参数preferredTestQuery用于检测数据库连接测试,检测数据库是否能连接成功.Default: nullDefines the query that will be executed for all connection tests, if the default ConnectionTester (or some other implementation of QueryConnectionT

Android中如何修改编译的资源ID值(默认值是0x7F...可以随意改成0x02~0x7E)

一.技术准备 今天我们来看一下如何修改Android中编译时的资源Id的值,在讲解这内容之前,我们需要先了解一下Android中的资源编译之后的结构和编译过程,这里就不多说了,具体可以查看这篇文章: http://blog.csdn.net/jiangwei0910410003/article/details/50628894 这篇文章中,介绍了如何解析Android中编译之后的resource.arsc文件,这里就介绍了Android中资源文件编译之后的类型和格式,其实Android中资源编译

SQL 添加字段和默认值脚本

--插入字段和默认值alter table Acc_WayBill add DeclaredValue nvarchar(50)goEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'申明价值' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Acc_WayBill', @level2type=N'COLUM

struts中的常量,action配置中的默认值

1.struts中Action的开发方式 继承ActionSupport类,这种方法实现的Action可以进行数据校验: 实现Action接口: 不继承任何类,不实现任何接口: 是否继承类或实现结构,struts都会进行默认拦截器的启动,拦截器的启动和Action没有关系. 2.struts中的通配符 在对action进行配置时,会有重复的情况 <action name="login" class="com.juaner.action.UserAction"

解决android greenDAO没有默认值default value和没有原始数据类型的问题

大多数android应用开发攻城狮们对greenDAO的威名都有听过,高效,使得它在众多的orm工具中脱颖而出 最近有项目对sqlite效率有要求,所以相当了它,但是中间遇到了如题所述的两个问题 1.在greenDAO generator项目中没有相应的API能设置默认值(default value),例如: entity.addIntProperty("test").defValue("7"); 2.greenDAO generator所产生的java实体类和da

Swift——(五)Swift中的那些默认值

在Swift语言中,有很多默认值,这里将常用的总结,欢迎补充. @Author: twlkyao 1.函数(方法)形参 在函数(方法)中,形参默认是常量,这主要是为了防止误操作,在调用函数(方法)时改变了实参的值,所以使用常量,如果想在函数内部对实参进行修改,可以使用var关键字进行标识,但是这并没有结束,如果想在函数(方法)调用结束之后仍然可以使用修改后的值,需要使用inout关键字进行标识,同时不要使用var对形参进行标识,在调用函数(方法)的时候,传递的实参,需要使用"&"

mysql修改表中某个字段的默认值

Mysql中用SQL增加.删除字段,修改字段名.字段类型.注释,调整字段顺序总结 在网站重构中,通常会进行数据结构的修改,所以添加,删除,增加mysql表的字段是难免的,有时为了方便,还会增加修改表或字段的注释,把同字段属性调整到一块儿.这些操作可以在phpmyadmin或者别的mysql管理工具中完成,但是我们有时为了更方便的管理,会选择写sql语句来实现. 1.增加一个字段  代码如下 复制代码 //增加一个字段,默认为空alter table user add COLUMN new1 VA