繁体   English   中英

为 T-SQL SELECT 语句中的列组合动态生成唯一主键

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM