我正在尝试创建一个用整数替换varchar(50)字段的清理表。原始字段偶尔会有文本值,我想将其转换为0或null值。 我可以在select语句中这样做,但在尝试创建表时会出错。
以下是使用字符串的最小示例:
/* This works */
DROP TABLE IF EXISTS mytest;
CREATE TABLE mytest
AS
SELECT convert("123", unsigned) AS mynum;
/* This works, returning a row of 0 */
SELECT convert("TEST", unsigned) AS mynum;
/* But this fails, with: Truncated incorrect INTEGER value: 'TEST'*/
DROP TABLE IF EXISTS mytest;
CREATE TABLE mytest
AS
SELECT convert("TEST", unsigned) AS mynum;`
上面有什么问题,是否有更好的方法来实现我的目标?谢谢你的帮助。
答案 0 :(得分:2)
我没有解释为什么会出现这种错误,但我找到了使用子查询的解决方法:
DROP TABLE IF EXISTS mytest;
CREATE TABLE mytest
AS
SELECT mynum
FROM (SELECT convert("TEST"), unsigned) AS mynum) t;
答案 1 :(得分:2)
我会为它使用case语句,并切换到使用CAST而不是转换,这样你就会得到失败而不是隐式转换。
CREATE TABLE mytest(myVarchar varchar(10));
INSERT mytest VALUES ('123'),('TEST');
SELECT CASE
WHEN myVarchar REGEXP '^[0-9]+$' THEN CAST(myVarchar,unsigned)
ELSE 0
END As mynum
FROM mytest;
我没有一个方便测试的mysql实例,所以希望我没有任何语法错误。
答案 2 :(得分:0)
您可以更新数据然后更改表格,而不是转换:
UPDATE mytest SET mynum=mynum + 0;
ALTER TABLE mytest CHANGE COLUMN mynum mynum INT UNSIGNED;
答案 3 :(得分:0)
看起来您正在通过create中的select语句隐式定义列名。这可能是假设“TEST”字符串是数据类型。查看您收到的错误消息会有所帮助,但我的假设是将列明确定义为:
CREATE TABLE mytest(mynum int);
然后
Insert into mytest(mynum)
select convert("TEST",unsigned) as mynum;
这也是为什么子查询的答案可能有效的原因,当它到达外部查询时,它被隐式定义为int。