Emacs中的自动完成(Auto Completion)完全指南

本文详述了Emacs中的自动完成框架,包括auto-complete结合clang、hippie-expand、complete-symbol以及evil-mode的配置和使用,强调了各框架的特点和适用场景。对于C++程序员,推荐使用auto-complete和clang的组合,而对于其他语言,可以考虑ctags和hippie-expand。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

作者: 陈斌(redguardtoo)

版本号: 20120821

原创时间: 2012-08-21 二

所谓"自动完成",就是emacs智能猜测用户想输入的是什么词,帮助用户自动输入,如果emacs找到多个可选项,也可能弹出下拉菜单让用户来选择.

通常我们所说的IDE中的Intellisense,也可以认为是某种"自动完成".

Emacs的自动完成远比篇普通IDE的Intellisense强大得多,例如Emacs可以自动输入当前打开的文件的名字(带或者不带文件名后缀都可以).

我不是来赞美Emacs的强大的,我是来吐槽的.Emacs中的自动完成框架实在是太多了,很多框架的功能是重叠的,让人实在困扰.

所以本文的目的有两个,

  1. 说明哪些自动完成框架是主流的
  2. 如何配置使用自动完成框架

### 使用 `ON DUPLICATE KEY UPDATE` 更新所有字段但排除主键MySQL 中,当使用 `ON DUPLICATE KEY UPDATE` 语句时,如果希望更新主键外的所有字段,可以通过显式列出需要更新的字段来实现。由于主键通常设置为 `AUTO_INCREMENT` 具有唯一性约束,因此在插入更新操作中不应直接修改主键字段。 #### 示例 假设有一个名为 `employees` 的表,定义如下: ```sql CREATE TABLE employees ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(100), department VARCHAR(50), salary DECIMAL(10, 2) ); ``` 现在需要插入一条记录,如果 `id` 冲突(例如,表中已存在相同的主键),则更新主键外的所有字段: ```sql INSERT INTO employees (id, name, department, salary) VALUES (101, 'Alice', 'Engineering', 85000.00) ON DUPLICATE KEY UPDATE name = 'Alice', department = 'Engineering', salary = 85000.00; ``` 在这个例子中,如果 `id = 101` 的记录已经存在,则会更新 `name`、`department` 和 `salary` 字段;如果不存在,则插入新记录。主键 `id` 在插入时指定,但在更新时不被修改 [^4]。 #### 使用 `VALUES()` 函数简化更新语句 当插入的数据较多时,可以使用 `VALUES()` 函数来引用插入时的值,从而简化更新语句: ```sql INSERT INTO employees (id, name, department, salary) VALUES (101, 'Alice', 'Engineering', 85000.00), (102, 'Bob', 'Marketing', 75000.00) ON DUPLICATE KEY UPDATE name = VALUES(name), department = VALUES(department), salary = VALUES(salary); ``` 在这个例子中,如果 `id` 冲突,`ON DUPLICATE KEY UPDATE` 子句会使用当前插入的值来更新对应的 `name`、`department` 和 `salary` 字段 [^4]。 #### 注意事项 - `ON DUPLICATE KEY UPDATE` 需要表中存在主键唯一索引,否则不会触发更新操作 [^1]。 - 如果更新的字段包含主键唯一索引列,并且更新后的值与其他记录冲突,会导致插入和更新都失败。 - 使用 `ON DUPLICATE KEY UPDATE` 时,自增字段(`AUTO_INCREMENT`)可能会跳过某些值,因为每次插入操作都会尝试分配一个新的自增值,即使最终执的是更新操作 [^3]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值