0

当在 Stata 中两个数据集被合并时,基于一个变量在任何一个数据集中都不是唯一的,合并 x:x 似乎不是一个有用的工具。什么策略会产生预期的结果?

程式化的例子:

数据集1

AssetManager | Bankcode
A              1
B              2
B              3
C              3

数据集2

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

直觉:有些资产管理公司可以由多家银行持有,而有些银行也拥有多家资产管理公司。

4

1 回答 1

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)
于 2016-02-04T19:54:51.013 回答