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 个值的主要内容,如果未能解决你的问题,请参考以下文章