MYSQL 没有重复的 2 个值

Posted

技术标签:

【中文标题】MYSQL 没有重复的 2 个值【英文标题】:MYSQL no duplicate of 2 values 【发布时间】:2020-09-10 15:11:01 【问题描述】:

我无法找到这个确切问题的答案,尽管我确信信息在此处某处。

我有一个将股票数据添加到数据库中的 python 脚本。对于每个股票数据库有大约 1000 行,其中“ticker”是股票名称,“time”是日期(每天 1 个)。

当我运行我的更新脚本时,我想替换数据库中的最新行,以防它在一天结束之前发生变化。

与“ticker”相比,有没有办法让“time”变得独一无二?

使用这个 sql 我可以排序并且只获取我想要的数据,但它不会从数据库中删除多余的数据。

SELECT distinct open, high, low, close, volume, time FROM security WHERE security.ticker='%s' order by time DESC limit 100" % ticker

【问题讨论】:

【参考方案1】:

您可以在 (ticket, time) 上创建唯一索引(令人困惑的是,名为 time 的东西表示没有时间组件的日期,而列 date 有日期和时间......但似乎这是您的数据模型的结构)。

create unique index on security(ticker, date);

然后,您可以在脚本中使用insert ... on duplicate key 语法。看起来像:

insert into security (ticker, time, date, open, ... )
values (:ticker, :time, :date, :open)
on duplicate key update 
    date = values(date),
    open = values(open),
    ...

【讨论】:

【参考方案2】:

您可以添加一个复合主键,由 (ticker, time) 对组成

【讨论】:

这个复合键,除了使用 REPLACE INTO 而不是 INSERT INTO 应该可以很好地解决问题

以上是关于MYSQL 没有重复的 2 个值的主要内容,如果未能解决你的问题,请参考以下文章

Pandas每组中的前n个值[重复]

为啥倒数第二个值被复制到数组的最后一个值上[重复]

打印出列表中最大数的第 n 个值 [重复]

从csv文件(python)的列中查找最大2(或n)个值[重复]

MySQL - 如何删除重复的数据输入?

将 3 个值编码为 [0,1,-1] [重复]