database – KDB中Insert和Upsert的行为
发布时间:2020-05-24 12:57:21 所属栏目:MsSql 来源:互联网
导读:我有以下表格: q) t:([s:`symbol$()] id:();id2:`int$()) 其中’s’是主键,’id’col是常规类型. 我在’id’列中插入列表(此例中的字符串)时试图理解以下行为: a)Upsert有效但插入失败 q) `t insert (`a;gg;4) // type q) `t upsert (`a;gg;4) //
|
我有以下表格: q) t:([s:`symbol$()] id:();id2:`int$()) 其中’s’是主键,’id’col是常规类型. a)Upsert有效但插入失败 q) `t insert (`a;"gg";4) // 'type
q) `t upsert (`a;"gg";4) // works
b)插入也需要登记主键: q)`t insert (`a;enlist "gg";4) // 'length
q)`t insert (enlist `a;enlist "gg";4) // works
幕后发生了什么? 解决方法我认为问题在于“gg” – 它是一个列表,因此无论您是要插入一个记录还是多个记录,插入都会混淆.这个:`t insert (`a;"g";4) 工作得很好.不幸的是我不知道其他的解决方法,但是插入一个长度为1的记录列表: `t insert (enlist `c;enlist "gg";enlist 4) 我不确定upsert是什么,但它可能与它的实现有关,通过修改:.[;();,;] (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
