V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
wuwukai007
V2EX  ›  Python

mysql 如果不存在,插入,还有更快的写法吗?

  •  
  •   wuwukai007 · 2021-09-17 15:34:08 +08:00 · 2963 次点击
    这是一个创建于 1165 天前的主题,其中的信息可能已经有所发展或是发生改变。
    INSERT INTO table_listnames (name, address, tele)
    SELECT * FROM (SELECT 'Unknown' AS name, 'Unknown' AS address, '022' AS tele) AS tmp
    WHERE NOT EXISTS (
        SELECT name FROM table_listnames WHERE name = 'Rupert'
    ) LIMIT 1;
    
    Query OK, 1 row affected (0.00 sec)
    Records: 1  Duplicates: 0  Warnings: 0
    

    目前大概 1000 条 700ms,这个 sql 返回值可以记录重复的数量

    第 1 条附言  ·  2021-09-18 11:10:13 +08:00
    没法使用复合主键判断,因为使用了逻辑删除字段,用复合主键,就和逻辑删除冲突了
    10 条回复    2021-09-21 11:54:18 +08:00
    deplivesb
        1
    deplivesb  
       2021-09-17 15:54:55 +08:00   ❤️ 1
    如果根据主键判断存在 我一般用 ignore
    aitaii
        2
    aitaii  
       2021-09-17 15:56:19 +08:00
    不存在,插入 = 存在,不插入 or 存在,更新列?
    insert ignore into 或者 insert into on duplicate key update
    eason1874
        3
    eason1874  
       2021-09-17 16:01:13 +08:00
    如果 name 是唯一的,可以用 INSERT IGNORE INTO
    msg7086
        4
    msg7086  
       2021-09-17 16:32:56 +08:00
    唯一索引然后条件插入就行了。
    wuwukai007
        5
    wuwukai007  
    OP
       2021-09-17 16:55:03 +08:00
    @aitaii @eason1874 INSERT IGNORE 会导致主键跳跃自增。条件不止一列,好几列,@msg7086 使用唯一索引久没发做逻辑删除了。
    w7938940
        6
    w7938940  
       2021-09-17 17:55:11 +08:00
    quanqiubiannuan
        7
    quanqiubiannuan  
       2021-09-17 17:56:33 +08:00
    replace into
    dusu
        8
    dusu  
       2021-09-17 23:28:03 +08:00 via iPhone
    要快 就做倒排~
    byzf
        9
    byzf  
       2021-09-18 10:20:12 +08:00
    ON DUPLICATE KEY UPDATE ?
    lolizeppelin
        10
    lolizeppelin  
       2021-09-21 11:54:18 +08:00
    这种都算邪道....

    正常业务新增和更新本来就是分开的

    正常业务流程情况下, 发现 update 更新行数不匹配时才 insert
    出现大量 update 无匹配应该检查业务流程和代码而不是走捷径
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4895 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 33ms · UTC 10:02 · PVG 18:02 · LAX 02:02 · JFK 05:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.