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

  1. create table #famousjaycees
  2. (
  3. jc varchar(15) unique,
  4. occupation varchar(25),
  5. becamefamous int default 0,
  6. notes text null
  7. )
  8.  
  9. insert #famousjaycees values('julius','miliday',0045,'took the raman')
  10. if(@@ERROR <>0) GOTO LIST
  11. insert #famousjaycees values('julius','miliday',0045,'took the raman')
  12. if(@@ERROR <>0) GOTO LIST
  13. insert #famousjaycees values('JESUS','founded',0001,'birth featured')
  14. if(@@ERROR <>0) GOTO LIST
  15. insert #famousjaycees values('John','founded',0001,'birth featured')
  16. if(@@ERROR <>0) GOTO LIST
  17. insert #famousjaycees values('Joan','founded',0001,'birth featured')
  18. if(@@ERROR <>0) GOTO LIST
  19. insert #famousjaycees values('Joe','founded',0001,'birth featured')
  20. if(@@ERROR <>0) GOTO LIST
  21.  
  22. list:select * from #famousjaycees

执行语句

用insert命令删除重复行

  通过IGNORE_DRE_KEY设定唯一索引的办法来删除重复行。重复行将会失败并且不影响其他行

  1. create table #famousjaycees
  2. (
  3. jc varchar(15),
  4. occupation varchar(25),
  5. becamefamous int default 0,
  6. notes text null
  7. )
  8. insert #famousjaycees values('julius','miliday',0045,'took the raman')
  9.  
  10. insert #famousjaycees values('julius','miliday',0045,'took the raman')
  11.  
  12. insert #famousjaycees values('JESUS','founded',0001,'birth featured')
  13.  
  14. insert #famousjaycees values('John','founded',0001,'birth featured')
  15.  
  16. insert #famousjaycees values('Joan','founded',0001,'birth featured')
  17.  
  18. insert #famousjaycees values('Joe','founded',0001,'birth featured')
  19. create table #famousjaycees2
  20. (
  21. jc varchar(15),
  22. occupation varchar(25),
  23. becamefamous int default 0,
  24. notes text null
  25. )
  26. --创建索引
  27. create unique index removedups on #famousjaycees2(jc,occupation,becamefamous)
  28. with ignore_dup_key
  29. --插入数据
  30. insert #famousjaycees2
  31. select * from #famousjaycees
  32. select * from #famousjaycees2

实例

注意索引中不能包括note类型的列

insert和聚集索引

  没有聚集索引的表被称作堆表,无论表中是否还有空间,向堆表中插入的行都会被插入。如果在表中没有任何一个已有页中都没有空间了,那么久创建一个新页,然后插入该行。

这样会在表的结尾产生一个热点(多个用户同时向表中执行insert操作,他们要竞争同一资源)。为了避免这样情况的发生的可能性,最好为自己建的表创建聚集索引。考虑使用唯一

关键字来为新行均匀的插入到表中。避免使用自动的、连续的聚集索引键,因为他们同样会产生热点。将一个堆表变成一个有聚集索引的表时,如果使用单调增加的键为索引,那么仍然

没有什么改善。还要避免使用不唯一的关键字作为聚集索引。在sql7.0之前,带有重复键值的行插入时会产生溢出页,降低操作速度并造成表中有碎片。从7.0版本开始,为了保证索引键

的唯一性,在每个重复键值的后面附加上一个’uniqueifier‘(4个字节的序列号-int)。这样做自然会占用一部分处理时间,如果在开始时就使用了唯一关键字值,就不必要使用这种操作了。与所有

的索引一样,尽量平衡个人访问数据和修改数据的需要来使用关键字值。--我个人的理解,这块应该使用带有唯一性约束或索引的列,但不能自增因为还是会使热点到最后一页,使用非自增可以平坦热点

如果还是并发高,从数据库手段上可以使用批处理,在程序上可以引入消息队列等中间件来处理

批量插入(Bulk Insert)

  除了标准的insert之外,T-SQL还提供了Bulk Insert命令来进行大批量的数据插入

  1. create table #famousjaycees
  2. (
  3. jc varchar(15),
  4. occupation varchar(25),
  5. becamefamous int default 0,
  6. notes text null
  7. )
  8. 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的更多相关文章

  1. SQL学习(时间,存储过程,触发器)

    SQL学习 几个操作时间的函数 --datapart 获取时间中的年月日时分秒等部分 select DATEPART(year,current_timestamp); select DATEPART( ...

  2. sql动态insert向varchar(MAX)中写入据的问题

    sql动态insert向varchar(MAX)中写入据的问题,在写入时出现列无效.后来发现,varchar要加''两个,号才可以 SET @SQL='INSERT INTO '+@TabName+' ...

  3. SQL Server Insert操作中的锁

    原文:SQL Server Insert操作中的锁 这篇博文简单介绍一下在SQL Server中一条Insert语句中用到的锁. 准备数据 首先我们建立一张表Table_1,它有两列Id(bigint ...

  4. ORALCE PL/SQL学习笔记

    ORALCE  PL/SQL学习笔记 详情见自己电脑的备份数据资料

  5. Delphi X10.2 + FireDAC 使用 SQL 语句 INSERT

    // CREATE TABLE [tabusers]( // [id] INTEGER PRIMARY KEY AUTOINCREMENT, // [username] CHAR NOT NULL, ...

  6. TERADATA SQL学习随笔<一>

    此博客内容简介及目录 http://www.cnblogs.com/weibaar/p/6644261.html 最近在TERADATA环境学习SQL.在这里记录一下学习中查过的知识点,作为备案. 目 ...

  7. sql在insert时判断有无唯一性冲突

    sql在insert时判断有无唯一性冲突,存在相同主键或唯一索引,则不创建 INSERT INTO table(field1, field2, fieldn) SELECT 'field1', 'fi ...

  8. Mybatis执行sql(insert、update、delete)返回值问题

    数据库:Mysql 在使用mybatis的过程中对执行sql的返回值产生疑问,顺手记录一下. 结论: insert:   插入n条记录,返回影响行数n.(n>=1,n为0时实际为插入失败) up ...

  9. (013)每日SQL学习:日期的各种计算

    1.确定两个日期之间的工作日天数 --确定两个日期之间的工作日天数with x0 as (select to_date('2018-01-01','yyyy-mm-dd') as 日期 from du ...

随机推荐

  1. PAT 1100. Mars Numbers

    People on Mars count their numbers with base 13: Zero on Earth is called "tret" on Mars. T ...

  2. unigui菜单【3】

    unigui菜单TuniTreeView 根据数据库表中的内容,显示菜单的处理: function TMainForm.CreateMenu: Integer; var myMenuPoint : P ...

  3. PKI 的组成

    PKI(Public Key Infrastructure)公钥基础设施是提供公钥加密和数字签名服务的系统或平台,目的是为了管理密钥和证书.一个机构通过采用PKI 框架管理密钥和证书可以建立一个安全的 ...

  4. BZOJ1443 游戏game (二分图染色+匈牙利算法)

    先对整幅图进行二分图染色,再跑一遍匈牙利算法.如果最大匹配数=点数*2,那么输出WIN. 对于任何一个非必须在最大匹配上的点,即为所求的点. Program Test375num2; type arr ...

  5. 虚拟机+centOS挂载ISO步骤

    https://blog.csdn.net/u010612373/article/details/52240447

  6. 贪心算法 Heidi and Library (easy)

    A. Heidi and Library (easy) time limit per test 2 seconds memory limit per test 256 megabytes input ...

  7. 计算机与linux操作系统的发展

    一.计算机 (一)计算机的概念 1.概念:计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可以进行逻辑计算,还具有存储记忆功能.是能够按照程序运行,自动.高速 ...

  8. linux更改gitlab存储位置

    更改仓库存储位置默认时GitLab的仓库存储位置在“/var/opt/gitlab/git-data/repositories”,在实际生产环境中显然我们不会存储在这个位置,一般都会划分一个独立的分区 ...

  9. Homebrew 命令

    安装(需要 Ruby):ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)" 搜索 ...

  10. yum install mysql(转载)

    linux下使用yum安装mysql 1.安装查看有没有安装过:          yum list installed mysql*          rpm -qa | grep mysql* 查 ...