search
mysql小技巧Jun 07, 2016 pm 03:01 PM
insertmysqlSkillgrammar

INSERT语法 INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [ IGNORE ] [INTO] tbl_name [( col_name ,...)] VALUES ({ expr | DEFAULT},...),(...),... [ ON DUPLICATE KEY UPDATE col_name = expr , ... ] 或: INSERT [LOW_PRIORITY | DELAYED | HIGH_

INSERT语法

<font>INSERT [LOW_PRIORITY | <strong><font>DELAYED</font></strong> | HIGH_PRIORITY] [<strong><font>IGNORE</font></strong>]</font>
<font>      [INTO] <em>tbl_name</em> [(<em>col_name</em>,...)]</font>
<font>      VALUES ({<em>expr</em> | DEFAULT},...),(...),...</font>
<font>      [ <font>ON DUPLICATE KEY UPDATE</font> <span><em>col_name</em></span>=<em>expr</em>, ... ]</font>

或:

<font>INSERT [LOW_PRIORITY | <strong><font>DELAYED</font></strong> | HIGH_PRIORITY] [<strong><font>IGNORE</font></strong>]</font>
<font>      [INTO] <em>tbl_name</em></font>
<font>      SET <em>col_name</em>={<em>expr</em> | DEFAULT}, ...</font>
<span><font>      [ <font>ON DUPLICATE KEY UPDATE</font> <em>col_name</em>=<em>expr</em>, ... ]</font></span>

或:

<font>INSERT [LOW_PRIORITY | HIGH_PRIORITY] [<strong><font>IGNORE</font></strong>]</font>
<font>      [INTO] <em>tbl_name</em> [(<em>col_name</em>,...)]</font>
<font>      SELECT ...</font>
<span><font>      [ <font>ON DUPLICATE KEY UPDATE</font> <em>col_name</em>=<em>expr</em>, ... ]</font></span>

一、<strong><font>DELAYED</font></strong>的使用
    使用延迟插入操作
DELAYED调节符应用于INSERT和REPLACE语句。当DELAYED插入操作到达的时候,<br>
服务器把数据行放入一个队列中,并立即给客户端返回一个状态信息,这样客户<br>
端就可以在数据表被真正地插入记录之前继续进行操作了。如果读取者从该数据<br>
表中读取数据,队列中的数据就会被保持着,直到没有读取者为止。接着服务器<br>
开始插入延迟数据行(delayed-row)队列中的数据行。在插入操作的同时,服务器<br>
还要检查是否有新的读取请求到达和等待。如果有,延迟数据行队列就被挂起,<br>
允许读取者继续操作。当没有读取者的时候,服务器再次开始插入延迟的数据行。<br>
这个过程一直进行,直到队列空了为止。
几点要注意事项:<br>
· INSERT DELAYED应该仅用于指定值清单的INSERT语句。服务器忽略用于INSERT DELAYED...SELECT语句的DELAYED。<br>
· 服务器忽略用于INSERT DELAYED...ON DUPLICATE UPDATE语句的DELAYED。<br>
· 因为在行被插入前,语句立刻返回,所以您不能使用LAST_INSERT_ID()来获取AUTO_INCREMENT值。AUTO_INCREMENT值可能由语句生成。<br>
· 对于SELECT语句,DELAYED行不可见,直到这些行确实被插入了为止。<br>
· DELAYED在从属复制服务器中被忽略了,因为DELAYED不会在从属服务器中产生与主服务器不一样的数据。
<span>注意,目前在队列中的各行只保存在存储器中,直到它们被插入到表中为止。这意味着,如果您强行中止了mysqld(例如,使用kill -9)<br>
或者如果mysqld意外停止,则所有没有被写入磁盘的行都会丢失。</span>
二、<font><strong>IGNORE</strong></font>的使用
IGNORE是<u><strong>MySQL</strong></u>相对于标准SQL的扩展。如果在新表中有重复关键字,<br>
或者当STRICT模式启动后出现警告,则使用IGNORE控制ALTER TABLE的运行。<br>
如果没有指定IGNORE,当重复关键字错误发生时,复制操作被放弃,返回前一步骤。<br>
如果指定了IGNORE,则对于有重复关键字的行,只使用第一行,其它有冲突的行被删除。<br>
并且,对错误值进行修正,使之尽量接近正确值。
insert ignore into tb(...) value(...)
这样不用校验是否存在了,有则忽略,无则添加<br>
<br>
三、<font>ON DUPLICATE KEY UPDATE</font>的使用
<p>如果您指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或<span>PRIMARY KEY</span>中出现重复值,则执行旧行UPDATE。例如,如果列a被定义为UNIQUE,并且包含值1,则以下两个语句具有相同的效果:</p>
<pre class="brush:php;toolbar:false">mysql> <strong>INSERT INTO table (a,b,c) VALUES (1,2,3)</strong>
      -> <span><strong>ON DUPLICATE KEY UPDATE c=c+1;</strong></span>
 
mysql> <strong>UPDATE table SET c=c+1 WHERE a=1;</strong>

如果行作为新记录被插入,则受影响行的值为1;如果原有的记录被更新,则受影响行的值为2。

注释:如果列b也是唯一列,则INSERT与此UPDATE语句相当:

mysql> <strong>UPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1;</strong>

如果a=1 OR b=2与多个行向匹配,则只有一个行被更新。通常,您应该尽量避免对带有多个唯一关键字的表使用ON DUPLICATE KEY子句。

您可以在UPDATE子句中使用VALUES(col_name)函数从INSERT...UPDATE语句的INSERT部分引用列值。换句话说,如果没有发生重复关键字冲突,则UPDATE子句中的VALUES(col_name)可以引用被插入的col_name的值。本函数特别适用于多行插入。VALUES()函数只在INSERT...UPDATE语句中有意义,其它时候会返回NULL

示例:

mysql> <strong>INSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6)</strong>
      -> <strong>ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b);</strong>

本语句与以下两个语句作用相同:

mysql> <strong>INSERT INTO table (a,b,c) VALUES (1,2,3)</strong>
      -> <span><strong>ON DUPLICATE KEY UPDATE c=3;</strong></span>
mysql> <strong>INSERT INTO table (a,b,c) VALUES (4,5,6)</strong>
      -> <strong>ON DUPLICATE KEY UPDATE c=9;</strong>

当您使用ON DUPLICATE KEY UPDATE时,DELAYED选项被忽略。

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
图文详解mysql架构原理图文详解mysql架构原理May 17, 2022 pm 05:54 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

mysql怎么替换换行符mysql怎么替换换行符Apr 18, 2022 pm 03:14 PM

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql怎么去掉第一个字符mysql怎么去掉第一个字符May 19, 2022 am 10:21 AM

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql的msi与zip版本有什么区别mysql的msi与zip版本有什么区别May 16, 2022 pm 04:33 PM

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

mysql怎么将varchar转换为int类型mysql怎么将varchar转换为int类型May 12, 2022 pm 04:51 PM

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

MySQL复制技术之异步复制和半同步复制MySQL复制技术之异步复制和半同步复制Apr 25, 2022 pm 07:21 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

带你把MySQL索引吃透了带你把MySQL索引吃透了Apr 22, 2022 am 11:48 AM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

mysql怎么判断是否是数字类型mysql怎么判断是否是数字类型May 16, 2022 am 10:09 AM

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor