雪花:删除列(如果存在) [英] Snowflake: DROP COLUMN if exists

查看:0
本文介绍了雪花:删除列(如果存在)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我找不到任何简单的方法来翻译Snowflake中的以下T-SQL查询。

ALTER TABLE table1
DROP COLUMN if exists [col1]

有什么想法吗? 谢谢!

推荐答案

目前无法在删除列时指定是否存在_,因此简单翻译如下:

ALTER TABLE table1
drop column "col1";

如果";col1";不存在(用引号括起来使其区分大小写),则将导致SQL编译错误。如果生成错误对您的用例不起作用(例如,代码会认为这是一个更严重的问题),则可以在尝试删除列之前使用外部逻辑(如Python)或存储过程中的内部逻辑来检查该列是否存在。您可以使用下面的SQL测试列的存在,如果列退出,则返回1,如果不存在,则返回0:

select count(*) as COLUMN_EXISTS
from INFORMATION_SCHEMA.COLUMNS
where TABLE_SCHEMA = 'SCHEMA_TO_CHECK' and
      TABLE_NAME   = 'TABLE_TO_CHECK' and
      COLUMN_NAME  = 'COLUMN_TO_CHECK'
;

这篇关于雪花:删除列(如果存在)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆