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>(列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之增_insert-replace的更多相关文章

  1. (转)mysql自增列导致主键重复问题分析

    mysql自增列导致主键重复问题分析...  原文:http://www.cnblogs.com/cchust/p/3914935.html 前几天开发童鞋反馈一个利用load data infile ...

  2. 关于MySQL自增主键的几点问题(上)

    前段时间遇到一个InnoDB表自增锁导致的问题,最近刚好有一个同行网友也问到自增锁的疑问,所以抽空系统的总结一下,这两个问题下篇会有阐述. 1. 划分三种插入类型 这里区分一下几种插入数据行的类型,便 ...

  3. MySQL AutoIncrement--自增锁模式

    自增锁模式 在MYSQL 5.1.22版本前,自增列使用AUTO_INC Locking方式来实现,即采用一种特殊的表锁机制来保证并发插入下自增操作依然是串行操作,为提高插入效率,该锁会在插入语句完成 ...

  4. MySQL自增ID 起始值 修改方法

    在mysql中很多朋友都认为字段为AUTO_INCREMENT类型自增ID值是无法修改,其实这样理解是错误的,下面介绍mysql自增ID的起始值修改与设置方法. 通常的设置自增字段的方法: 创建表格时 ...

  5. Java连接MySQL数据库增删改查通用方法

    版权声明:本文为博主原创文章,未经博主允许不得转载. Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类 ...

  6. node.js中对 mysql 进行增删改查等操作和async,await处理

    要对mysql进行操作,我们需要安装一个mysql的库. 一.安装mysql库 npm install mysql --save 二.对mysql进行简单查询操作 const mysql = requ ...

  7. MySQL数据库(增删改查语句)

    MySQL数据库(增删改查语句)一.登录数据库:---->  mysql -uroot -proot;(对应用户名和密码)二.SQL语句:    数据定义语言DDL  用来定义数据库.表.列,关 ...

  8. python操作mysql数据库增删改查的dbutils实例

    python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...

  9. Nodejs连接mysql的增、删、改、查操作

    一,创建数据库 Source Database : my_news_test SET FOREIGN_KEY_CHECKS=0; -- ---------------------------- -- ...

  10. Mysql自增ID起始值修改

    在mysql中很多朋友都认为字段为AUTO_INCREMENT类型自增ID值是无法修改,其实这样理解是错误的,下面介绍mysql自增ID的起始值修改与设置方法.通常的设置自增字段的方法:创建表格时添加 ...

随机推荐

  1. [leetcode-599-Minimum Index Sum of Two Lists]

    Suppose Andy and Doris want to choose a restaurant for dinner, and they both have a list of favorite ...

  2. 【Android Developers Training】 97. 序言:访问通讯录数据

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  3. java基础(10) -线程

    线程 相当于轻量级进程,线程在程序中是独立的.并发的执行路径,每个线程有它自己的堆栈.自己的程序计数器和自己的局部变量.但是,与分隔的进程相比,进程中的线程之间的隔离程度要小.它们共享内存.文件句柄和 ...

  4. css自定义动画在微信中无法执行的原因

    这是我去年年底遇到的一个问题, 在这个过程中我发现了一个比较有趣的问题. 我们在做抽奖的时候,微信分享到朋友圈的页面里,安卓机器无法执行页面中的自定义动画(元宝的位移,进入按钮的放大缩小等等).这让我 ...

  5. jap页面获取struts2中action中变量的值

    在jsp页面中可以通过ONGL表达式获取struts2中action处理后的变量的值,这是因为每一个action在初始化后都会放到strackcontext中,可以通过ONGL表达式取到值. 注意要在 ...

  6. 深入理解Java虚拟机-----------虚拟机类加载机制

    虚拟机类加载机制 类从被加载到虚拟机内存开始,到卸载出内存为止,整个生命周期包括:加载,验证,准备,解析,初始化,使用,卸载等7个阶段.其中,验证,准备,解析3个部分称为连接. 以上7个阶段中,加载, ...

  7. 一次C++调试记录

         之前开发用Linux C比较多,C++中的STL 容器基本没有接触过.最近在学习C++,平时用到c++ 17中的部分新特性,下面就简单分享下自己C++的学习流程. 一.环境搭建      本 ...

  8. [jbdj]SpringMVC框架(3)映射器

    映射器:什么样的请求交给Action. 1} class  :  BeanNameUrlHandlerMapping  要掌握, 将程序员定义的Action所对应的<bean>标签的nam ...

  9. 详解Android Activity---Activity的生命周期

    转载注明来自:  http://www.cnblogs.com/wujiancheng/ 一.正常情况下Activity的生命周期:  Activity的生命周期大概可以归为三部分 整个的生命周期:o ...

  10. nyoj_762:第k个互质数

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=762 直接给代码好了,容斥原理具体看<组合数学> #include<bi ...