MySQL增删改查之增insert、replace
一、INSERT语句
带有values子句的insert语句,用于数据的增加
语法:
INSERT [INTO] tbl_name[(col_name,...)]
{VALUES | VALUE} (expr ,...),(...),...
①用来把一个新行插入到表中
②为和其它数据库保持一致,不要省略INTO关键字以及使用VALUES而不是value关键字
③插入一行时,要求必须对该行所有的列赋值。但是赋值方式可以是显式赋值(直接给出值)和隐式赋值(由MySQL自动赋值)
基本格式:
insert into (列名1,列名2,列名3,......) values (值1,值2,值3,......);
解析:
①(列名1,列名2,列名3,......)称为 列清单
②(值1,值2,值3,......)称为 值清单
③列清单和值清单中的列和值必须相互对应(数据类型)
1、在表名后面列出所有的列名
示例:插入一个新的球队到teams表中
mysql> INSERT INTO teams(teamno,playerno,division) VALUES(3,6,'third');
2、在表名后面省略所有的列名
要求:VALUES子句中的值必须按照列在表结构中的顺序来一一赋值
mysql> INSERT INTO teams VALUES(4,104,'third');
3、在表名后面只列出部分的列名
注意:所有没有明确赋值的列,将通过隐式赋值自动得到null值
mysql> insert into (列名1,列名3......) values (值1,值3,......);
添加一个新行数据,没有指定赋值的列,结果集改行数据的列名2处隐式赋null值
当然,可使用字面量NULL给列赋空值
mysql> insert into (列名1,列名2,列名3) values (值1,null,值3);
4、VALUES子句中除了字面量,还可以使用函数、计算、标量子查询等
INSERT INTO (列1,列2)
VALUES((SELECT count(*) FROM 表名2),
(SELECT sum(列名) FROM 表名3));
注意:子查询必须放在单独的小括号中
一条INSERT语句可以插入多个行:
示例:添加4个新的球队
INSERT INTO teams(teamno, captainno,division)
VALUES (6,7,'third'),
(7,27,'fourth'),
(8,39,'fourth'),
(9,112,'sixth');
注意:这种语法只要有1行出错,则插入全部取消
INSERT语句中可以使用IGNORE选项来当INSERT语句出错时,不显示错误消息:但是INSERT语句不会执行
5、从其他表中复制数据:带子查询的INSERT语句,实现从其他表中(可按条件)复制数据进入目标表
语法:
INSERT [INTO] tbl_name[(col_name,...)]
SELECT ...
注意:
①如果在表名后面列出了列名,那么列的数量和数据类型必须和子查询的select列表相匹配
②如果在表名后面没有列出了列名,默认就是直接复制
insert.... select.... 语句常在需要进行数据表的备份时使用
无条件复制:将一个表中的原始数据记录,插入到另一个表中
按条件copy:将一个表查询出来的进行聚合操作之后的记录,插入到目标表中
当然,可以把本表中的行再次添加到本表中,但是必须注意主键值不要重复。
二、REPLACE语句:替代已有的行
INSERT语句的一个变种;
当添加新行时:
①如果主键值重复,那么就覆盖表中已有的行
②如果没有主键值重复,则插入该行
语法:
REPLACE [INTO] tbl_name [(col_name,...)]
VALUES (expr,...),(...),...
或者
REPLACE [INTO] tbl_name [(col_name,...)]
SELECT ...
(转)mysql自增列导致主键重复问题分析
mysql自增列导致主键重复问题分析... 原文:http://www.cnblogs.com/cchust/p/3914935.html 前几天开发童鞋反馈一个利用load data infile ...
关于MySQL自增主键的几点问题(上)
前段时间遇到一个InnoDB表自增锁导致的问题,最近刚好有一个同行网友也问到自增锁的疑问,所以抽空系统的总结一下,这两个问题下篇会有阐述. 1. 划分三种插入类型 这里区分一下几种插入数据行的类型,便 ...
MySQL AutoIncrement--自增锁模式
自增锁模式 在MYSQL 5.1.22版本前,自增列使用AUTO_INC Locking方式来实现,即采用一种特殊的表锁机制来保证并发插入下自增操作依然是串行操作,为提高插入效率,该锁会在插入语句完成 ...
MySQL自增ID 起始值 修改方法
在mysql中很多朋友都认为字段为AUTO_INCREMENT类型自增ID值是无法修改,其实这样理解是错误的,下面介绍mysql自增ID的起始值修改与设置方法. 通常的设置自增字段的方法: 创建表格时 ...
Java连接MySQL数据库增删改查通用方法
版权声明:本文为博主原创文章,未经博主允许不得转载. Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类 ...
node.js中对 mysql 进行增删改查等操作和async,await处理
要对mysql进行操作,我们需要安装一个mysql的库. 一.安装mysql库 npm install mysql --save 二.对mysql进行简单查询操作 const mysql = requ ...
MySQL数据库(增删改查语句)
MySQL数据库(增删改查语句)一.登录数据库:----> mysql -uroot -proot;(对应用户名和密码)二.SQL语句: 数据定义语言DDL 用来定义数据库.表.列,关 ...
python操作mysql数据库增删改查的dbutils实例
python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...
Nodejs连接mysql的增、删、改、查操作
一,创建数据库 Source Database : my_news_test SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- ...
Mysql自增ID起始值修改
在mysql中很多朋友都认为字段为AUTO_INCREMENT类型自增ID值是无法修改,其实这样理解是错误的,下面介绍mysql自增ID的起始值修改与设置方法.通常的设置自增字段的方法:创建表格时添加 ...
随机推荐
常用function() 收集
1.随机数生成函数(来源-微信支付demo案例) /** * * 产生随机字符串,不长于32位 * @param int $length * @return 产生的随机字符串 */ public st ...
svg坐标系变换
svg的坐标变换有三个属性来决定:viewport, viewBox, 和 preserveAspectRatio,我发现三篇比较详细的博客,转载如下: 理解SVG坐标系和变换:视窗,viewBox和 ...
JavaScript中字符串去掉特殊字符和转义字符
/*** * 去掉字符串中的特殊字符 */ var excludeSpeci ...
从配置sublimeClang插件中学到的
1.不害怕失败的关键在于要事先为失败准备补救措施.2.人们害怕内部结构复杂的东西出错,并以自己缺乏对内部结构的认识为理由而放弃查错.其实某些情况下根本无需对内部结构有多么深入的认识,只需从外部观察就够 ...
C++ Primer : 第十二章 : 动态内存之动态数组
动态数组的分配和释放 new和数组 C++语言和标准库提供了一次分配一个对象数组的方法,定义了另一种new表达式语法.我们需要在类型名后跟一对方括号,在其中指明要分配的对象的数目. int* arr ...
Altium Designer 里面怎么画等长线
(1)一般是将走线布完后,新建一个class. Design -> Classes 如上图添加完后可以点击close. (2)快捷键 T + R: 或者 点击Tools 下拉中的Interact ...
条款05:了解C++默默编写并调用哪些函数
每一个class都会有一个或多个构造函数.一个析构函数.一个copy assignment操作符.这些控制着基础操作,像是产出新对象并确保它被初始化.摆脱旧对象并确保它被适当清理.以及赋予对象新值. ...
PHP命名空间(Namespace)的使用详解
对于命名空间,官方文档已经说得很详细[查看],我在这里做了一下实践和总结. 命名空间一个最明确的目的就是解决重名问题,PHP中不允许两个函数或者类出现相同的名字,否则会产生一个致命的错误.这种情况下只 ...
Linux shell脚本学习(一)
一.shell脚本简介 shell脚本是用shell脚本语法将shell命令组织起来形成的文件形式.Shell脚本与Windows/Dos 下的批处理相似,主要为了将大量命令通过一个纯文本文件一次执行 ...
Maven高级应用--编译全模块包-dist包
1. 在需要生成dist包的模块级别,新建文件夹xxx-xxxx-dist 2. 进入目录,新建pom.xml,建议copy 3. dependencies节点,把要编译成全局包的应用引入进来 < ...