温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具
所有文章 友链 关于我

温欣爸比

  • 主页
  • Alfred Workflow
  • 《Vim 练级手册》
  • 常用命令
  • 代码笔记
  • 合辑
  • 在线工具

Mysql REPLACE INTO 语法

2018-03-26

Mysql 中插入数据的语法除了 INSERT INTO,还有一个 REPLACE INTO 语法,只不过该语法在没有插入数据时是插入,表中有时是替换,并且会更改主键 id

更改主键 id 这个设定,就决定了正常的业务程序是用不到这个语法的,一条数据老改 id 谁受得了。

但是换一种情况就会显得很有用,比如,你就是想要得到每次都变化的 id,举个例子

1
2
3
4
5
6
7
8
DROP TABLE IF EXISTS `auto_id`;
CREATE TABLE `auto_id` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`max_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '占位字段',
`create_ts` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '记录创建时间',
PRIMARY KEY (`id`),
UNIQUE KEY `auto_max_id_uindex` (`max_id`)
) ENGINE=InnoDB CHARSET=utf8mb4 COMMENT='自动生成 id';

新建一个表,我通过不断的插入相同的 mac_id 字段来获取自增的 id

1
2
3
4
replace into auto_id(max_id) values (1);
select last_insert_id(); -- 1
replace into auto_id(max_id) values (1);
select last_insert_id(); -- 2

想要达到这样的效果需要一个条件,想要替换的数据字段需要设为唯一键

1
UNIQUE KEY `auto_max_id_uindex` (`max_id`)

REPLACE INTO 一共三种写法分别为

1
2
3
replace into auto_id(max_id) values (1);
replace into auto_id(max_id) select 1;
replace into auto_id set max_id = 1;

只是为了得到这个自增 id,多少有点脱裤子放屁,不过配合一些算法,我们可以根据表来得到对应的命名空间的 id,详见 Mysql 自动生成 id 算法

最近更新
Alfred Workflow 命令行帮助工具
最近热读
Go 判断数组中是否包含某个 item
Vim 高级功能 vimgrep 全局搜索文件
办理北京工作居住证的一些细节
Go 语法错误:Non-declaration statement outside function body
Mac 电脑查看字体文件位置
扫码关注公众号,或搜索公众号“温欣爸比” 及时获取我的最新文章
赏

谢谢你请我喝咖啡

支付宝
微信
  • mysql
SQLAlchemy Paginate 分页查询
Vim 插件 Emmet web 开发神器
目录,不存在的…
© 2017 - 2022 温欣爸比 京ICP备15062634号 总访问量3274次 访客数3226人次 本文总阅读量3次
Hexo Theme Yilia by Litten
  • 所有文章
  • 友链
  • 关于我

tag:

  • python
  • flask
  • javascript
  • docker
  • 工具
  • openresty
  • 微信
  • java
  • hexo
  • 杂谈
  • vim
  • git
  • mysql
  • http
  • linux
  • mac
  • tmux
  • ssh
  • 算法
  • 开发
  • node
  • 杂文
  • jinja2
  • maven
  • spring
  • 北京
  • 生活
  • springboot
  • react
  • shell
  • graphql
  • iterm
  • expect
  • nginx
  • sqlalchemy
  • html
  • electron
  • vagrant
  • elastic
  • 宝贝
  • ansible
  • css
  • jquery
  • go
  • markdown
  • awk
  • redis
  • leetcode
  • zsh
  • 漫威
  • ssr
  • android
  • ffmpeg
  • chrome
  • vmware
  • youtube
  • windows
  • jupyter
  • excel
  • jq
  • Mac
  • Homebrew
  • mongo
  • py2
  • HomeBrew
  • movie
  • nodejs

    缺失模块。
    1、请确保node版本大于6.2
    2、在博客根目录(注意不是yilia根目录)执行以下命令:
    npm i hexo-generator-json-content --save

    3、在根目录_config.yml里添加配置:

      jsonContent:
        meta: false
        pages: false
        posts:
          title: true
          date: true
          path: true
          text: false
          raw: false
          content: false
          slug: false
          updated: false
          comments: false
          link: false
          permalink: false
          excerpt: false
          categories: false
          tags: true
    

  • Guru99
每天看书
每天背单词
每天一篇
写写代码
听听周杰伦
爱爱老婆