sql学习--insert
insert的四种插入方式
第一种最简单的
into 和目标列的列表是可选的
intsert [into] tableA [(col1,col2)] values(val1,val2)
第二种
insert tableA values(val1,default)--cal2的在创建表时需要有默认值约束
insert tableA default values --tableA表中所有的列都时有默认值约束才可以
第三种
insert [into] tableA(col1,col2)
select val1,val2 from Stu --可以使用select查出的值作为insert值
第四种,使用存储过程返回的结果集
insert [into] tableA(col1,col2)
exec sourceprocname
insert和错误
insert的一个有趣的特性就是批命令错误的密封性--同时插入10条数据其中一条错误,但其它9条不受那一条的影响
如果希望一个insert插入失败时整个批命令都失败如何操作呢?--利用@@ERROR
create table #famousjaycees
(
jc varchar(15) unique,
occupation varchar(25),
becamefamous int default 0,
notes text null
) insert #famousjaycees values('julius','miliday',0045,'took the raman')
if(@@ERROR <>0) GOTO LIST
insert #famousjaycees values('julius','miliday',0045,'took the raman')
if(@@ERROR <>0) GOTO LIST
insert #famousjaycees values('JESUS','founded',0001,'birth featured')
if(@@ERROR <>0) GOTO LIST
insert #famousjaycees values('John','founded',0001,'birth featured')
if(@@ERROR <>0) GOTO LIST
insert #famousjaycees values('Joan','founded',0001,'birth featured')
if(@@ERROR <>0) GOTO LIST
insert #famousjaycees values('Joe','founded',0001,'birth featured')
if(@@ERROR <>0) GOTO LIST list:select * from #famousjaycees
执行语句


用insert命令删除重复行
通过IGNORE_DRE_KEY设定唯一索引的办法来删除重复行。重复行将会失败并且不影响其他行
create table #famousjaycees
(
jc varchar(15),
occupation varchar(25),
becamefamous int default 0,
notes text null
)
insert #famousjaycees values('julius','miliday',0045,'took the raman') insert #famousjaycees values('julius','miliday',0045,'took the raman') insert #famousjaycees values('JESUS','founded',0001,'birth featured') insert #famousjaycees values('John','founded',0001,'birth featured') insert #famousjaycees values('Joan','founded',0001,'birth featured') insert #famousjaycees values('Joe','founded',0001,'birth featured')
create table #famousjaycees2
(
jc varchar(15),
occupation varchar(25),
becamefamous int default 0,
notes text null
)
--创建索引
create unique index removedups on #famousjaycees2(jc,occupation,becamefamous)
with ignore_dup_key
--插入数据
insert #famousjaycees2
select * from #famousjaycees
select * from #famousjaycees2
实例

注意索引中不能包括note类型的列
insert和聚集索引
没有聚集索引的表被称作堆表,无论表中是否还有空间,向堆表中插入的行都会被插入。如果在表中没有任何一个已有页中都没有空间了,那么久创建一个新页,然后插入该行。
这样会在表的结尾产生一个热点(多个用户同时向表中执行insert操作,他们要竞争同一资源)。为了避免这样情况的发生的可能性,最好为自己建的表创建聚集索引。考虑使用唯一
关键字来为新行均匀的插入到表中。避免使用自动的、连续的聚集索引键,因为他们同样会产生热点。将一个堆表变成一个有聚集索引的表时,如果使用单调增加的键为索引,那么仍然
没有什么改善。还要避免使用不唯一的关键字作为聚集索引。在sql7.0之前,带有重复键值的行插入时会产生溢出页,降低操作速度并造成表中有碎片。从7.0版本开始,为了保证索引键
的唯一性,在每个重复键值的后面附加上一个’uniqueifier‘(4个字节的序列号-int)。这样做自然会占用一部分处理时间,如果在开始时就使用了唯一关键字值,就不必要使用这种操作了。与所有
的索引一样,尽量平衡个人访问数据和修改数据的需要来使用关键字值。--我个人的理解,这块应该使用带有唯一性约束或索引的列,但不能自增因为还是会使热点到最后一页,使用非自增可以平坦热点
如果还是并发高,从数据库手段上可以使用批处理,在程序上可以引入消息队列等中间件来处理
批量插入(Bulk Insert)
除了标准的insert之外,T-SQL还提供了Bulk Insert命令来进行大批量的数据插入
create table #famousjaycees
(
jc varchar(15),
occupation varchar(25),
becamefamous int default 0,
notes text null
)
BULK INSERT famousjaycees from 'D:\DATA\famousjaycees.bcp'
1.批量插入和触发器
Bulk Insert覆盖了SQL Server的触发器机制。当使用BULK INSERT 命令插入行时,insert触发器不会被触发。这是因为SQL SERVER的BCP工具尽可能的避免将插入的行写在
事务处理日志中。也就是说,触发器根本就没有被触发的机会。然而又一个工作区,在这个工作区中使用一个假的修改可以迫使触发器触发。见Update学习文章
2.批量插入和约束
相对而言,说明性约束可通过使用Bulk Insert的CHECK_CONSTRAINTS选项来执行。默认情况下,除了UNIQUE约束之外,目标表的其它约束都将被忽略,所以如果想在
大量数据操作的同时坚持这些约束,那么就要包括这个选项。但这会大幅度降低操作速度。
3.批量插入和同一性列
在默认情况下,插入数据时将重新产生同一数据结构列的值。很显然,如果将数据插入到一个有外键的表时,那么后果是直接失败。
为了防止这种情况,需要包括Bulk Insert的关键字KEEPIDENTITY
sql学习--insert的更多相关文章
- SQL学习(时间,存储过程,触发器)
SQL学习 几个操作时间的函数 --datapart 获取时间中的年月日时分秒等部分 select DATEPART(year,current_timestamp); select DATEPART( ...
- sql动态insert向varchar(MAX)中写入据的问题
sql动态insert向varchar(MAX)中写入据的问题,在写入时出现列无效.后来发现,varchar要加''两个,号才可以 SET @SQL='INSERT INTO '+@TabName+' ...
- SQL Server Insert操作中的锁
原文:SQL Server Insert操作中的锁 这篇博文简单介绍一下在SQL Server中一条Insert语句中用到的锁. 准备数据 首先我们建立一张表Table_1,它有两列Id(bigint ...
- ORALCE PL/SQL学习笔记
ORALCE PL/SQL学习笔记 详情见自己电脑的备份数据资料
- Delphi X10.2 + FireDAC 使用 SQL 语句 INSERT
// CREATE TABLE [tabusers]( // [id] INTEGER PRIMARY KEY AUTOINCREMENT, // [username] CHAR NOT NULL, ...
- TERADATA SQL学习随笔<一>
此博客内容简介及目录 http://www.cnblogs.com/weibaar/p/6644261.html 最近在TERADATA环境学习SQL.在这里记录一下学习中查过的知识点,作为备案. 目 ...
- sql在insert时判断有无唯一性冲突
sql在insert时判断有无唯一性冲突,存在相同主键或唯一索引,则不创建 INSERT INTO table(field1, field2, fieldn) SELECT 'field1', 'fi ...
- Mybatis执行sql(insert、update、delete)返回值问题
数据库:Mysql 在使用mybatis的过程中对执行sql的返回值产生疑问,顺手记录一下. 结论: insert: 插入n条记录,返回影响行数n.(n>=1,n为0时实际为插入失败) up ...
- (013)每日SQL学习:日期的各种计算
1.确定两个日期之间的工作日天数 --确定两个日期之间的工作日天数with x0 as (select to_date('2018-01-01','yyyy-mm-dd') as 日期 from du ...
随机推荐
- 关于MySQL中自增的理解和设置
show create table t10;--查看表的创建结果 show create table t10\G;--竖列查看 --设置自增为20 ); insert into t2(name) va ...
- WEB 移动端 CSS3动画性能 优化
很多时候,我们在开发移动端的时候要使自己的网页兼容不同的机型,很多时候会采用CSS3动画,但是很多时候在安卓机下,动画明显会出现卡顿,很难看,那么这里我介绍几个CSS 属性进行硬件加速那么就会得到明显 ...
- [转] C# 隐藏方法和重写方法
1:方法重写:就是在基类中的方法用virtual关键字来标识,然后在继承类中对该类进行重写 (override),这样基类中的方法在子类中已经被重写了,基类中的方法在子类中已经失去了功能 了.当让基类 ...
- [Vue] Lazy Load a Route by using the Dynamic Import in Vue.js
By default, vue-router doesn’t lazy load the routes unless you tell it to do it. Lazy loading of the ...
- mongodb mapreduce使用总结
文章来自本人个人博客: mongodb mapreduce使用总结 大家都知道,mongodb是一个非关系型数据库.也就是说.mongodb数据库中的每张表是独立存在的,表与表之间没有不论什么依赖 ...
- 重学C++ (十一) OOP面向对象编程(2)
转换与继承 本节主要须要区分的是: 基类和派生类的转换: 引用(指针)的转换和对象的转换. 1.每一个派生类对象包括一个基类部分.因此.能够像使用基类对象一样在派生类对象上执行操作. 基于这一点,能够 ...
- Delphi 中控件路径加入不进去解决方法
使用notepa++打开project中的*.dproj文件,在里面找到相似例如以下的区域 <DCC_UnitSearchPath>T:\BusinessSkinForm1006Sourc ...
- Android Fragment实现button间的切换
原文地址:http://blog.csdn.net/a123demi/article/details/32693037 Fragment要点 Fragment是activity的界面中的一部分或一种行 ...
- Color a Tree HDU - 6241
/* 十分巧妙的二分 题意选最少的点涂色 使得满足输入信息: 1 x的子树涂色数不少于y 2 x的子树外面涂色数不少于y 我们若是把2转化到子树内最多涂色多少 就可以维护这个最小和最大 如果我们二分出 ...
- QFileDialog关于选择文件对话框中的几个信号的说明(currentChanged,directoryEntered,fileSelected,filterSelected)
QFileDialog关于选择文件对话框中的几个信号 实例: openFile::openFile(QWidget *parent) :QWidget(parent),ui(new Ui::openF ...