MySQL之增_insert-replace
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的更多相关文章
- (转)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的起始值修改与设置方法.通常的设置自增字段的方法:创建表格时添加 ...
随机推荐
- Redis 内存管理与事件处理
1 Redis内存管理 Redis内存管理相关文件为zmalloc.c/zmalloc.h,其只是对C中内存管理函数做了简单的封装,屏蔽了底层平台的差异,并增加了内存使用情况统计的功能. void * ...
- 6.解决AXIOS的跨域问题
在服务端加上: response.addHeader("Access-Control-Allow-Origin", "*"); response.addHead ...
- 13.什么是javabean,以及使用原则
javabean简介 javabeans就是符合某种特定的规范的java类,使用javabeans的好处是解决代码的重复编写,减少代码 冗余,功能区分明确,提高了代码的维护性. javabean的设计 ...
- 在线用户数-Constants
package com.pb.news.constants; public class Constants { public static int ONLINE_USER_COUNT=0;//在线用户 ...
- usaco training 4.2.4 Cowcycles 题解
Cowcycles题解 Originally by Don Gillies [International readers should note that some words are puns on ...
- JAVA - 深入JAVA 虚拟机 2
类的两种类型的类加载器 -Java虚拟机自带的加载器 根类加载器(Bootstrap): 使用C++编写,programer can not abtain this class. 扩展类加载器(Ext ...
- App Extensions篇之Sticker Pack Extension
转载请标明原文链接:http://www.cnblogs.com/zhanggui/p/7151795.html 前言 上一篇文章对App Extension做了简单介绍以及对Share Extens ...
- Hibernate框架 主配置文件(Hibernate.cfg.xml) 映射配置 说明
Hibernate.cfg.xml 主配置文件中主要配置:数据库连接信息.其他参数.映射信息! 常用配置查看源码: hibernate-distribution-3.6.0.Final\project ...
- JVM入门——运行时数据区
这张图我相信基本上对JVM有点接触的都应该很熟悉,可以说这是JVM入门的第一课.其中的“堆”和“虚拟机栈(栈)”更是耳熟能详.下面将围绕这张图对JVM的运行时数据区做一个简单介绍. 程序计数器(Pro ...
- rang enumerate
叨逼叨: 小知识点 rang enumerate # 1. 请输出1-10# 2.7: 立即生成所有数字# range(1,11) # 生成 1,23,,4,56.10# 3.x: 不会立即生成,只有 ...