kdb - 具有单个值和多个键的字典
问题描述
具有单个值和多个键的字典代表什么?他们的目的是什么?
我不小心创建了一个,但不能用它做任何事情:
q)type (`a`b`c)!(`d)
99h
q)((`a`b`c)!(`d))[`a]
'par
解决方案
这种特殊形式通常表示分区表的翻转,其中键代表列名,值代表表名:
q)/load a database with partitioned table part_tab
q)flip part_tab
`ncej`jogn`ciha`hkpb`aeaj`blmj`ooei`jgjm`cflm`bpmc!`part_tab
这本词典不打算以通常的方式查找,也不是以您尝试的方式查找。
这将是完全不明智的,但可以通过操作此字典来限制分区表的列:
q)select from part_tab where date=2020.01.02
date ncej jogn ciha hkpb aeaj blmj ooei jgjm cflm bpmc
------------------------------------------------------------
2020.01.02 0 0 0 0 0 0 0 0 0 0
2020.01.02 1 1 1 1 1 1 1 1 1 1
2020.01.02 2 2 2 2 2 2 2 2 2 2
2020.01.02 3 3 3 3 3 3 3 3 3 3
...
q)part_tab:flip`ncej`jogn`ciha!`part_tab
q)select from part_tab where date=2020.01.02
date ncej jogn ciha
-------------------------
2020.01.02 0 0 0
2020.01.02 1 1 1
2020.01.02 2 2 2
...
再次不要在任何大型/生产表上尝试此操作,这是一个未记录的怪癖。
Splay 表在翻转时有一个类似的字典:
q)flip splay
`ncej`jogn`ciha`hkpb`aeaj`blmj`ooei`jgjm`cflm`bpmc!`:splay/
不同之处在于表名末尾有一个“/”并且是hsym
'd。这是.Q.qp
确定表是分区还是展开的方式。
推荐阅读
- javascript - Onclick 找不到要执行的函数
- php - 在 Laravel 表单验证后插入记录
- python - 如何修复 Unix 域套接字“/var/run/postgresql/.s.PGSQL.5432”上的连接?运行 bitbucket 管道时出错
- vba - 如何在 PowerPoint 应用程序中获得字母之间的延迟?
- javascript - 配置vscode任务在parcel watch后复制文件
- c++ - 使用 c++ 循环构建三角形
- ios - 根据按钮数量设置 CollectionView 单元格高度
- mysql - 我需要检测数据库中的所有状态变化
- phpmyadmin - 在 phpmyadmin 中使用更新版本的 PHP 时缺少 Mysqli 扩展
- python-3.x - Panda Dataframe Copy to another dataframe 实际上是复制数据类型?