父亲

作者的父亲为供养三个孩子上学辛勤劳动,导致身体出现问题。在上海检查后得知并无大碍,只是需要避免过度劳累。此行还实现了父亲看海的愿望,尽管上海的海景并不如青岛那般壮丽。文中表达了作者对父亲深深的感激之情。

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

今天父亲要回去了,心情有些沉重,一直睡不着,就起来写点东西....

父亲由于要供我们3个兄弟上大学,而且是一个普普通通的农民,其劳累肯定是非常大的,现在身体出现了一些问题,之前在大哥那里检查治疗了一年多,也没有什么起色,于是就来到上海做一下检查,还好经过2周的检查,医生说没有什么大的问题,只是一些炎症,以后不要过于劳累,每年做一次检查就行了,在2家大医院的专家都是这么说的。我的心这才放了下来。谢天谢地!

父亲一直想看海,但上海这个地方的海是很难看的,远比不是青岛的海岸,海水,但没有办法,就去了海边,看到黄黄的海水,但的确是海,一眼望不到边.....

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]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值