- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的 Clojure 技能不存在,我的 SQLite 技能也是如此。由于某种原因,我在工作中被这个项目困住了,但我玩得很开心。
基本上,用户提交一个表单,然后将其发送到 PayPal,我们将其取回,然后我们更新他们购买了商品的数据库。此外,我们还从用于其购物车的数据库中删除临时 session 。
我的工作是将他们购买的商品数量添加到数据库中。这是我下面的used_quantity
。在 PHP/MySQL 中我会做类似的事情:
update sa_forms set used_quantity = used_quantity + {quantity} where id = {id} LIMIT 1
但似乎我实际上必须执行两个步骤才能添加数量。
我添加的唯一内容是 let
语句。没有它,整个事情就可以正常进行。有了它,它就会崩溃。
insert-db-order (if (:login session)
(doseq [order db-orders]
(j/insert! SQLDB :sa_orders
{:form_id (:form_id order)
:user_id (:user_id order)
:form_name (:form_name order)
:user_name username
:total_cost_paid (* (:payment_amt order) (:quantity order))
:date_completed (.getTime (java.util.Date.))
:order_content (:html order)
:created_at (.getTime (java.util.Date.))
:updated_at (.getTime (java.util.Date.))
:status false
:quantity (:quantity order)})
(let [quantityOf (j/query SQLDB ["SELECT used_quantity FROM sa_forms WHERE id = ? LIMIT 1" (:form_id order)])]
(j/update! SQLDB :sa_forms
{:used_quantity (+ (:used_quantity quantityOf) (:quantity order))}
(sql/where {:id (:form_id order)}))
)
)
(doseq [id (keys session-orders)]
(j/insert! SQLDB :sa_orders
{:form_id (:form_id (id session-orders))
:user_id anonymous-key
:form_name (:form_name (id session-orders))
:user_name username
:total_cost_paid (* (:payment_amt (id session-orders)) (:quantity (id session-orders)))
:date_completed (.getTime (java.util.Date.))
:order_content (:html (id session-orders))
:created_at (.getTime (java.util.Date.))
:updated_at (.getTime (java.util.Date.))
:status false
:quantity (:quantity (id session-orders))}))
)
我一整天都遇到错误,并且尝试了多种方法。例如:
{:used_quantity (+ (int(:used_quantity quantityOf)) (:quantity order))}
因为它说 map 不能是数字。我试过了
{:used_quantity (+ (quantityOf) (:quantity order))}
因为我只选择一个值,所以不需要显示我所引用的内容。我还尝试pprint
值、或键或全部,但它们要么显示为nil
,要么什么也没有,这没有帮助。
在这次考验中,我了解到我必须将变量定义器放在 let
语句中,但除其他外,我已经在这上面花了 9 个半小时,并且我已经从一个错误转向了另一个错误。
有人可以给我一些 clojure 吗?通俗地说最好。我仍在努力掌握这种语言的行话和奇怪的语法......
谢谢!
最佳答案
首先,请检查您在出现异常的上下文中使用的值的类型。
user> (type '({:quantity 1}))
clojure.lang.PersistentList
user> (type {:quantity 1})
clojure.lang.PersistentArrayMap
sql/query
应该返回顺序数据类型,即使您将限制设置为 1。用作以 seq 作为参数的函数的关键字将给出 nil 结果:
user> (:quantity '({:quantity 1}))
nil
用括号括起来,正如您也尝试过的那样,也肯定是一个错误
user> ('({:quantity 1}))
ClassCastException clojure.lang.PersistentList cannot be cast to clojure.lang.IFn user/eval8554/fn--8555 (form-init7057475948894346608.clj:1)
获得结果的方式应该更像这样:
user> (+ (:quantity (first '({:quantity 1}))) 2)
3
关于java - Clojure 中的 NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26812487/
我正在将我的模板代码移植到 XTend。在某些时候,我在测试用例中有这种类型的条件处理: @Test def xtendIfTest() { val obj = new FD if (
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我的应用程序一直在各种Android版本中保持良好状态。我有用户在Android 4.3、5.0、5.1和6.0上正常运行。但是,具有S7 Edge的用户刚刚更新了Android 7.0,将文本粘贴到
我使用的是最新版本的 LWUIT (1.5)。我在资源编辑器中设计了我的表单,然后将代码生成到 netbeans。问题是如果我想访问除表单之外的任何对象,我会收到此错误: java.lang.Null
更新: 我在 Fedora 21 上运行它。 SonarQube - 5.0。 SonarQube Runner - 2.4 更新 2:Findbugs v3.1,Java 插件 v2.8 更新3:
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
每次运行此 jsp 时,都会收到以下错误异常: org.apache.jasper.JasperException: java.lang.NullPointerException root cause
Kotlin 在编译时有一个出色的 null 检查,使用分离到“可空?”和“不可为空”的对象。它有一个 KAnnotator 来帮助确定来自 Java 的对象是否可以为空。但是,如果 not-null
我有一个布局将显示一个TextView,用于显示一个滴答时间。我遵循了此链接中的代码 How to Display current time that changes dynamically for
Elasticsearch 1.4.1版(“lucene_version”:“4.10.2”) 我有一个像这样的文件: $ curl 'http://localhost:9200/blog/artic
这是我从另一个类调用函数的方法Selenium 设置已定义。 public void Transfer() throws Exception { System.out.println("\nTrans
我试图在主类中使用我在此类中创建的函数,但它崩溃并显示“警告:无法在根 0 处打开/创建首选项根节点 Software\JavaSoft\Prefsx80000002。 Windows RegCrea
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 我有一个 Java 代码,它将
我声明了两张牌: Card card1 = new Card('3', Card.Suit.clubs); Card card2 = new Card('T', Card.Suit.diamonds)
我编写了一段代码来解码 Base64 图像并在 javafx 中表示该图像。在我的 url base64 代码中不断变化。这就是我在 javafx 代码中使用任务的原因。但我收到错误:java.lan
我正在尝试使用 arrayList 的 arrayList 在 Java 中实现图形。 每当调用 addEdge 函数时,我都会收到 NullPointerException 。我似乎无法弄清楚为什么
我是 Java/android 的新手,所以很多这些术语都是外国的,但我愿意学习。我不打算详细介绍该应用程序,因为我认为它不相关。我目前的问题是,我使用了博客中的教程和代码 fragment ,并使我
我正在开发一个 Android 应用程序来在 Android developer guide 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!