当在Stata中时,两个数据集应合并,基于一个在任一数据集中不唯一的变量,合并x:x似乎不是一个有用的工具。什么策略会产生预期的结果?
程式化示例:
dataSet1的
AssetManager | Bankcode
A 1
B 2
B 3
C 3
Dataset2
Bankcode | t
1 t1
1 t2
2 t1
2 t2
3 t1
3 t2
目的:
AssetManager | Bankcode | t
A 1 t1
A 1 t2
B 2 t1
B 2 t2
B 3 t1
B 3 t2
C 3 t1
C 3 t2
直觉: 一些资产管理公司可以由多家银行持有,而一些银行也拥有多家资产管理公司。
答案 0 :(得分:1)
不鼓励使用merge m:m
(阅读Stata手册中的相应条目),许多人支持消除它。试试joinby
:
clear
set more off
input ///
str1 AssetManager Bankcode
A 1
B 2
B 3
C 3
end
tempfile first
save "`first'"
clear
input ///
Bankcode str2 t
1 t1
1 t2
2 t1
2 t2
3 t1
3 t2
end
joinby Bankcode using "`first'"
sort AssetManager Bankcode t
order AssetManager Bankcode
list, sepby(AssetManager)