mySQL用alter使列为空_MySQL alter table修改列在具有空值的行中失败

我有一个大约10K行的表,我正在尝试改变,以便field field定界符从不为null.我试图做一个alter语句,期望任何空值被更改为默认值,但是我从sql语句中返回一个错误.

alter table merchant_ftp_account modify column `fielddelimiter` char(1) NOT NULL DEFAULT 't';

17:08:48 [ALTER - 0 row(s), 0.000 secs] [Error Code: 1265, SQL State: 01000] Data truncated for column 'fielddelimiter' at row 3987

... 1 statement(s) executed, 0 row(s) affected, exec/fetch time: 0.000/0.000 sec [0 successful, 0 warnings, 1 errors]

据了解,这意味着数据超出了这一行的字段大小,但是(a)字段中的数据在该行为(null),并且(b)我可以使用值’ t’,我没有收到截断错误.如果我使用非空值更新该行,并尝试重新运行alter语句,那么在fielddelimiter为null的下一行将失败. [ETA:我得到MySQL可以在任何方向更新,但我可以跟踪它的进度,因为我更改行.]

MySQL文档中有一个警告:

Warning This conversion may result in alteration of data. For example, if you shorten a

string column, values may be truncated. To prevent the operation from succeeding if

conversions to the new data type would result in loss of data

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值