首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Clojure中的drop列CQL语句上捕获特定的异常

在Clojure中的drop列CQL语句上捕获特定的异常
EN

Stack Overflow用户
提问于 2022-11-25 22:04:49
回答 1查看 86关注 0票数 0

我希望在可能存在或不存在该列的表上运行drop列CQL语句。理想情况下,我希望做一个if-存在然后删除列,但我不相信CQL支持这一点。

我的工作是捕获一个无效的查询异常,但这不起作用,我不知道原因。在下面的代码中,泛型"com.datastax.driver.core.exceptions.InvalidQueryException:将命中给出在表my_table中找不到的消息my_col列my_table“。我不知道为什么我的InvalidQueryException没有击中。

代码语言:javascript
运行
复制
(ns my-namespace
  (:require [qbits
              [alia :as alia]
              [hayt :as hayt]]))

(defn prepared-statement
  [session]
  (try
     (alia/execute session
                   (hayt/alter-table :my_table
                                     (hayt/drop-column :my_col)))
     (catch com.datastax.driver.core.exceptions.InvalidQueryException ie
       (prn "your column doesn't exist"))
     (catch Exception e
       (prn (ex-data e)))))
EN

回答 1

Stack Overflow用户

发布于 2022-11-26 17:53:21

看看来源 for alia/execute。如您所见,它已经包含了只包含区块Exception

因此,您必须调用CqlSessionCqlSession方法(并使用hayt/->raw创建查询字符串):

代码语言:javascript
运行
复制
(:import (com.datastax.oss.driver.api.core.servererrors InvalidQueryException))

(defn prepared-statement
  [session]
  (try (.execute session
              (hayt/->raw (hayt/alter-table :my_table
                                            (hayt/drop-column :my_col))))
    (catch InvalidQueryException ie
      (prn "your column doesn't exist"))
    (catch Exception e
      (prn (ex-data e)))))

测试:

代码语言:javascript
运行
复制
(prepared-statement s)
"your column doesn't exist"
=> nil
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74578173

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档