繁体   English   中英

在MySQL中将文本列转换为整数

[英]Converting text column to integer in MySQL

我正在尝试创建一个清理表,以整数替换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;`

上面有什么问题,有没有更好的方法来实现我想要的? 谢谢您的帮助。

我没有解释为什么会发生该错误的原因,但是我发现了使用子查询的解决方法:

DROP TABLE IF EXISTS mytest;
CREATE TABLE mytest
AS
    SELECT mynum
    FROM (SELECT convert("TEST"), unsigned) AS mynum) t;

演示: http ://www.sqlfiddle.com/#!2/ 4909a/1

我将为此使用case语句,并切换到使用CAST而不是convert,这样您将获得失败而不是隐式转换。

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实例,因此希望我不会遇到任何语法错误。

除了转换,您可以更新数据,然后更改表:

UPDATE mytest SET mynum=mynum + 0;
ALTER TABLE mytest CHANGE COLUMN mynum mynum INT UNSIGNED;

看起来您正在通过create中的select语句隐式定义列名称。 这可能是假设“ TEST”字符串是数据类型。 这将有助于查看您收到的错误消息,但是我的假设是将列明确定义为:

CREATE TABLE mytest(mynum int);

然后

Insert into mytest(mynum)
select convert("TEST",unsigned) as mynum;

这也是为什么子查询的答案可以起作用的原因,因为当它到达外部查询时,它被隐式定义为int。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM