Foxtable(狐表)用户栏目专家坐堂 → sql中字符串转数据为什么会出错?


  共有2106人关注过本帖树形打印复制链接

主题:sql中字符串转数据为什么会出错?

帅哥,在线噢!
有点蓝
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:107720 积分:547933 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/11/12 14:52:00 [显示全部帖子]

1、厚度2有不能转换为数字的值。
2、或者试试

UPDATE  表A SET 厚度 = case when 厚度2 is null or 厚度2 = '' then null else CAST(厚度2 AS FLOAT) WHERE 厚度2 IS NOT NULL AND 厚度2 <> ''

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:107720 积分:547933 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/11/12 15:38:00 [显示全部帖子]

没有这种通用的用法。只能这样。

或者取出来到表格里再使用代码处理

 回到顶部
帅哥,在线噢!
有点蓝
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:107720 积分:547933 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/11/12 16:22:00 [显示全部帖子]

试试
UPDATE  表A SET 厚度 = CAST(厚度2 AS FLOAT) WHERE PATINDEX('%[^0-9|.|-|+]%', 厚度2)=0

 回到顶部