database – KDB中Insert和Upsert的行为

我有以下表格:
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)     // 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是什么,但它可能与它的实现有关,通过修改:.[;();,;]

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...