[英]Dynamically generate unique primary key for a column composition in a T-SQL SELECT statement
有人知道是否有办法在 MS SQL Server / Transact SQL SELECT 语句中生成唯一的整数主键吗?
我有一个问题,我必须通过列的组合(如复合主键)以编程方式合并 3 个数据表。 组合不是实际的主键。
我的表看起来有点像这样:
Table 1: Base Table which is needed to be filled:
+----------+------+----------------+------------+----------+
|operatorid|opcode|bookkeeping_date|cash_amount |tip_amount|
+----------+------+----------------+------------+----------+
| 1 | 1 | 01.01.2018 |null |null |
+----------+------+----------------+------------+----------+
| 1 | 1 | 01.02.2018 |null |null |
+----------+------+----------------+------------+----------+
| 2 | 2 | 01.02.2018 |null |null |
+----------+------+----------------+------------+----------+
Table 2: Cash Data Table to be merged with base table
+----------+------+----------------+------------+
|operatorid|opcode|bookkeeping_date|cash_amount |
+----------+------+----------------+------------+
| 1 | 1 | 01.01.2018 |2.50 |
+----------+------+----------------+------------+
| 1 | 1 | 01.02.2018 |17.80 |
+----------+------+----------------+------------+
| 2 | 2 | 01.02.2018 |4.20 |
+----------+------+----------------+------------+
Table 3: Tip Data Table to be merged with base table:
+----------+------+----------------+----------+
|operatorid|opcode|bookkeeping_date|tip_amount|
+----------+------+----------------+----------+
| 1 | 1 | 01.01.2018 |3.50 |
+----------+------+----------------+----------+
| 1 | 1 | 01.02.2018 |4.20 |
+----------+------+----------------+----------+
| 2 | 2 | 01.02.2018 |0.00 |
+----------+------+----------------+----------+
如此简化的目标是通过合并数据表来填充“表 1:基表”。 我们已经有了 ac# 方法来管理选择数据表后的主键合并。
我现在的问题是我没有唯一的主键,而是“operatorid”和“bookkeeping_date”的组合。
有没有办法可以修改每个表的 SELECT 语句以通过哈希或校验和或类似的东西获得唯一的整数?
编辑:现金金额和小费金额是表选择语句中使用聚合 SUM() 的汇总值。
此致
白粉病
我确信这些表中的数据可以定期更改,并且由于总是可以引入历史记录,从而抛出任何排名或行号函数,因此最好走一条同时使用 operatorid 和 bookkeeping_date 的路线来创建一个唯一的密钥。
一种简单的方法是将日期转换为整数值,并将 operatorid 附加到末尾。
1/1/2018 变为“43099”。 Operatorid 1 在末尾变为“1”(或“01”/“001”/“0001”,如果这些 ID 有机会变成更大的整数)。
select
convert(int, convert(varchar(6), convert(int, (convert(datetime,replace(bookkeeping_date,'.','-'),110))))
+ convert(varchar(2), operatorid)) as unique_id
from (select 1 as operatorid, 1 as opcode, '01.01.2018' as bookkeeping_date, 3.50 as tip_amount) tip
在日期整数达到六位数之前,您还有几个世纪的时间,这可能会导致一些复杂情况 - 但您也可以将日期整数转换为带有尾随零的内容,以便在需要时适应这种情况。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.