精华内容
下载资源
问答
  • insert into 语句的四种写法

    万次阅读 多人点赞 2016-08-29 15:21:16
    方式1、 INSERT INTO t1(field1,field2) VALUE(v001,v002); 明确只插入一条Value 方式2、 INSERT INTO t1(field1,field2) VALUES(v101,v102),(v201,v202),(v301,v302),(v401,v402); 在插入批量数据时方式2优于...

    方式1、 INSERT INTO t1(field1,field2) VALUE(v001,v002);           

     明确只插入一条Value

    方式2、 INSERT INTO t1(field1,field2) VALUES(v101,v102),(v201,v202),(v301,v302),(v401,v402);

    在插入批量数据时 方式2 优于 方式1.

    【特注】当 id 为自增,即  id INT PRIMARY KEY AUTO_INCREMENT 时,执行 insert into 语句,需要将除 id 外的所有 field 列举出来(有没有感觉,好不方便,期待 mysql 提供一个简便方法来标记这种情况,因为在早测试数据的时候,普遍会使用,而列举出除 id 外所有字段,真有麻烦感)。

    方式3.1、  INSERT INTO t2(field1,field2) SELECT colm1,colm2 FROM t1 WHERE ……

    这里简单说一下,由于可以指定插入到 talbe2 中的列,以及可以通过相对较复杂的查询语句进行数据源获取,可能使用起来会更加的灵活一些,但我们也必须注意,我们在指定目标表的列时,一定要将所有非空列都填上,否则将无法进行数据插入,还有一点比较容易出错的地方就是,当我们写成如下简写格式:

    方式3.2、  INSERT INTO t2 SELECT colm1,colm2,…… FROM t1

    此时,我们如果略掉了目标表的列的话,则默认会对目标表的全部列进行数据插入,且 SELECT 后面的列的顺序 必须和目标表中的列的定义顺序完全一致 才能完成正确的数据插入,这是一个很容易被忽略的地方,值得注意。

    【特注】由于插入操作只粗略地对表 t1、t2 按顺序对所有字段进行 [数据类型] 检查,不对 [字段名] 核对。这是把双刃剑,既提供便利,又存在可能因粗心造成风险。在使用中,需确认顺序,使用中建议使用 [方式3.1] 或 [方式4].

    方式4、INSERT INTO 表名 SET 列名1 = 列值1,列名2=列值2,...;(博友提供,感谢)

    不过用INSERT INTO SET这种方式,不能批量增加数据。(参考:mysql数据库中插入数据INSERT INTO SET的优势

    展开全文
  • Merge into用法总结

    万次阅读 多人点赞 2018-04-11 09:18:47
    在Microsoft的SQL语法中,很简单的一句判断就可以了,SQL Server中的语法如下: if exists(select 1 from T where T.a='1001' ) update T set T.b=2 Where T.a='1001' else insert into T(a,b) values('1001',2);...

    简单的说就是,判断表中有没有符合on()条件中的数据,有了就更新数据,没有就插入数据。  

    有一个表T,有两个字段a、b,我们想在表T中做Insert/Update,如果条件满足,则更新T中b的值,否则在T中插入一条记录。在Microsoft的SQL语法中,很简单的一句判断就可以了,SQL Server中的语法如下:  

     

    if exists(select 1 from T where T.a='1001' )
    
    update T set T.b=2 Where T.a='1001'
    
    else
    
    insert into T(a,b) values('1001',2);

    但是很明显这个语法对于SQL只能更改一条语句,并且Oracle不能使用.所以就有了Merge intoOracle 9i引入的功能)语法 

    merge into 目标表 a
    
    using 源表 b
    
    on(a.条件字段1=b.条件字段1 and a.条件字段2=b.条件字段2 ……)  
    
    when matched then update set a.更新字段=b.字段
    
    when  not matched then insert into a(字段1,字段2……)values(值1,值2……)

     

      "在一个同时存在Insert和Update语法的Merge语句中,总共Insert/Update的记录数,就是Using语句中"源表"的记录数"

     源表b可能是一张表结构不同于a的表,有可能是一张构建相同表结构的临时表,也有可能是我们自己组起来的数据.

    对于前两种很好理解。现在主要说一下组件数据。

    对于Oracle有dual这个系统表很好构建,如下

     

    MERGE INTO T T1
    
    USING (SELECT '1001' AS a, 2 AS b FROM dual)  T2
    
    ON ( T1.a=T2.a)
    
    WHEN MATCHED THEN
    
    UPDATE SET T1.b= T2.b
    
    WHEN NOT MATCHED THEN
    
    INSERT (a,b) VALUES(T2.a,T2.b);

     在sql server中,不能使用dual这个系统变量来创建表,所以只能换下思路用union all组装数据或使用临时表,另外using中可以使用的还有table表,view视图,sub_query,子查询

    USING (
    SELECT  '1001'C1,2 C2 
    union all
    SELECT  '1002'C1,3 C2 
    union all...
    ) T2 

    工作中的一个实例

            public Message Saves(List<GoodsQuestionManageModel> models)
            {
                Message msg;
                StringBuilder sbSourceSql = new StringBuilder();
                if (models.Count > 0)//循环组织sql语句
                {
                    int i = 1;
                    foreach (GoodsQuestionManageModel model in models)
                    {
                        sbSourceSql.AppendFormat("select {0} GoodsQuestionManageId,{1} GoodsId,'{2}' OrderNumber,'{3}' Sku,{4} GoodsQuantity,{5} QuestionQuantity,{6} GoodsQuestionTypeId,'{7}' Remarks,{8} CreateUserId,'{9}' CreateTime,{10} LastUpdateUserId,'{11}' LastUpdateTime,{12} IsDelete \r\n",
                            model.GoodsQuestionManageId, model.GoodsId, model.OrderNumber, model.Sku, model.GoodsQuantity, model.QuestionQuantity, model.GoodsQuestionTypeId, model.Remarks, GlobalModel.Instance.UserId, DateTime.Now, GlobalModel.Instance.UserId, DateTime.Now, model.IsDelete);
                        if (models.Count > i++)
                        {
                            sbSourceSql.AppendLine(" union all");
                        }
                    }
    
                    string strSql = string.Format(@"merge into tb_e_GoodsQuestionManage t
                                                        using
                                                        (
                                                       {0}
                                                        )tSource
                                                        on (t.GoodsQuestionManageId=tSource.GoodsQuestionManageId)
                                                        when not matched then 
                                                        insert values
                                                        (
                                                         tSource.GoodsId, tSource.OrderNumber, tSource.Sku, tSource.GoodsQuantity, tSource.QuestionQuantity, tSource.GoodsQuestionTypeId, tSource.Remarks, tSource.CreateUserId, tSource.CreateTime, tSource.LastUpdateUserId, tSource.LastUpdateTime, tSource.IsDelete
                                                        )
                                                        when matched then 
                                                        update set 
                                                        t.GoodsId=tSource.GoodsId,t.OrderNumber=tSource.OrderNumber,t.Sku=tSource.Sku,t.GoodsQuantity=tSource.GoodsQuantity,t.QuestionQuantity=tSource.QuestionQuantity,
                                                        t.GoodsQuestionTypeId=tSource.GoodsQuestionTypeId,t.Remarks=tSource.Remarks,t.LastUpdateUserId=tSource.LastUpdateUserId,t.LastUpdateTime=tSource.LastUpdateTime,t.IsDelete=tSource.IsDelete;", sbSourceSql.ToString());
                    int effectNum = SqlHelper.ExecuteNonQuery(strSql);
                    if (effectNum > 0)
                    {
                        msg = new Message(true, "保存成功!");
                    }
                    else
                    {
                        msg = new Message(false, "保存失败!");
                    }
                }
                else
                {
                    msg = new Message(false, "没有数据,无需保存!");
                }
                return msg;
            }


    Merge 的其他功能

     Merge语句还有一个强大的功能是通过OUTPUT子句,可以将刚刚做过变动的数据进行输出。我们在上面的Merge语句后加入OUTPUT子句

       

       此时Merge操作完成后,将所变动的语句进行输出

       

       

       当然了,上面的Merge关键字后面使用了多个WHEN…THEN语句,而这个语句是可选的.也可以仅仅新增或是仅仅删除

       

     

       

       我们还可以使用TOP关键字限制目标表被操作的行,如图8所示。在图2的语句基础上加上了TOP关键字,我们看到只有两行被更新。

       

       

        但仅仅是MATCHED这种限制条件往往不能满足实际需求,我们可以在图7那个语句的基础上加上AND附加上额外的限制条件

        

     

     

    merge into  效率很高,强烈建议使用,尤其是在一次性提交事务中,可以先建一个临时表,更新完后,清空数据,这样update锁表的几率很小了。

    展开全文
  • insert into 语句的三种写法

    万次阅读 多人点赞 2018-04-24 12:03:34
    insert into 语句的三种写法方式1、 INSERT INTO t1(field1,field2) VALUE(v001,v002); // 明确只插入一条Value方式2、 INSERT INTO t1(field1,field2) VALUES(v101,v102),(v201,v202),(v301,v302),(v401,v402);...
    

    insert into 语句的三种写法

     

    方式1、 INSERT INTO t1(field1,field2) VALUE(v001,v002);            // 明确只插入一条Value

     

    方式2、 INSERT INTO t1(field1,field2) VALUES(v101,v102),(v201,v202),(v301,v302),(v401,v402);

    在插入批量数据时方式2优于方式1.

     

    方式3.1、  INSERT INTO t2(field1,field2) SELECT col1,col2 FROM t1 WHERE ……

    这里简单说一下,由于可以指定插入到talbe2中的列,以及可以通过相对较复杂的查询语句进行数据源获取,可能使用起来会更加的灵活一些,但我们也必须注意,我们在指定目标表的列时,一定要将所有非空列都填上,否则将无法进行数据插入,还有一点比较容易出错的地方就是,当我们写成如下简写格式:

     

    方式3.2、  INSERT INTO t2 SELECT id, name, address FROM t1

    此时,我们如果略掉了目标表的列的话,则默认会对目标表的全部列进行数据插入,且SELECT后面的列的顺序 必须和目标表中的列的定义顺序完全一致 才能完成正确的数据插入,这是一个很容易被忽略的地方,值得注意。

    展开全文
  • 文章目录常用插入语句insert intoinsert ignore intoinsert into ... on duplicate key updatereplace into使用场景总结 当MySQL表字段设置unique key或者primary key时,被约束的字段就必须是唯一的。新插入数据...

    当MySQL表字段设置unique key或者primary key时,被约束的字段就必须是唯一的。新插入数据直接使用insert into,如果出现唯一性冲突,就会抛出异常。我们可以根据需求选择合适的插入语句。

    为了演示,我们先新建一张user表,SQL语句如下,其中user_id为主键,username为唯一索引

    SET NAMES utf8mb4;
    SET FOREIGN_KEY_CHECKS = 0;
    
    -- ----------------------------
    -- Table structure for user
    -- ----------------------------
    DROP TABLE IF EXISTS `user`;
    CREATE TABLE `user`  (
      `user_id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '用户id',
      `username` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '用户名',
      `password` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '密码',
      `mobile_phone_number` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '手机号码',
      `email` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '邮箱',
      `delete_state` tinyint(1) UNSIGNED DEFAULT 0 COMMENT '用户状态,1表示删除,0表示未删除',
      `create_time` datetime(0) DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
      `update_time` datetime(0) DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',
      PRIMARY KEY (`user_id`) USING BTREE,
      UNIQUE INDEX `uk_username`(`username`) USING BTREE COMMENT '用户名唯一'
    ) ENGINE = InnoDB AUTO_INCREMENT = 9 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;
    
    -- ----------------------------
    -- Records of user
    -- ----------------------------
    INSERT INTO `user` VALUES (1, 'JourWon', '123456', '13800000000', 'JourWon@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (2, '马云', '123456', '13800000011', 'JackMa@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (3, '马化腾', '123456', '13800000022', 'PonyMa@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (4, '李彦宏', '123456', '13800000033', 'RobinLee@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (5, '任正非', '123456', '13800000044', 'RenZhengfei@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (6, 'Jobs', '123456', '13800000055', 'Jobs@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (7, 'Bill Gates', '123456', '13800000066', 'Bill Gates@163.com', 0, CURRENT_TIMESTAMP, NULL);
    INSERT INTO `user` VALUES (8, 'Buffett', '123456', '13800000077', 'Buffett@163.com', 0, CURRENT_TIMESTAMP, NULL);
    
    SET FOREIGN_KEY_CHECKS = 1;
    

    常用插入语句

    insert into

    当插入数据时,如果唯一性校验出现重复问题,则报错;

    如果没有重复性问题,则执行插入操作。

    简单总结:重复则报错,不重复则插入。

    示例

    INSERT INTO `user`
    VALUES
    	( 8, 'Buffett', '123456', '13800000077', 'Buffett@163.com', 0, CURRENT_TIMESTAMP, NULL );
    

    执行结果

    INSERT INTO `user`
    VALUES
    	( 8, 'Buffett', '123456', '13800000077', 'Buffett@163.com', 0, CURRENT_TIMESTAMP, NULL )
    > 1062 - Duplicate entry '8' for key 'user.PRIMARY'
    > 时间: 0.001s
    

    insert ignore into

    当插入数据时,如果唯一性校验出现重复问题,则忽略错误,只以警告形式返回,不执行此SQL语句;

    如果没有重复性问题,则执行插入操作。

    简单总结:重复则忽略,不重复则插入。

    示例

    INSERT IGNORE INTO `user`
    VALUES
    	( 8, 'Buffett', '123456', '13800000077', 'Buffett@163.com', 0, CURRENT_TIMESTAMP, NULL );
    

    执行结果

    INSERT IGNORE INTO `user`
    VALUES
    	( 8, 'Buffett', '123456', '13800000077', 'Buffett@163.com', 0, CURRENT_TIMESTAMP, NULL )
    > Affected rows: 0
    > 时间: 0.001s
    

    insert into … on duplicate key update

    当插入数据时,如果唯一性校验出现重复问题,则在原有记录基础上,更新指定字段内容,其它字段内容保留;

    如果没有重复性问题,则执行插入操作。

    简单总结:重复则更新指定字段,不重复则插入

    示例

    INSERT INTO `user` ( username, PASSWORD, mobile_phone_number, email )
    VALUES
    	( 'Buffett', '123456', '13800000088', 'Buffett@163.com' ) 
    	ON DUPLICATE KEY UPDATE mobile_phone_number = '13800000088';
    

    执行结果

    INSERT INTO `user` ( username, PASSWORD, mobile_phone_number, email )
    VALUES
    	( 'Buffett', '123456', '13800000088', 'Buffett@163.com' ) 
    	ON DUPLICATE KEY UPDATE mobile_phone_number = '13800000088'
    > Affected rows: 2
    > 时间: 0.022s
    

    表记录,mobile_phone_number更新了,update_time也有值了,但是user_id没有变

    user_id username password mobile_phone_number email delete_state create_time update_time
    8 Buffett 123456 13800000088 Buffett@163.com 0 2020-05-28 09:49:53 2020-05-28 10:04:30

    replace into

    replace into表示插入替换数据,当插入数据时,如果唯一性校验出现重复问题,删除旧记录,插入新记录;

    如果没有重复性问题,则执行插入操作,效果和insert into是一样的。

    简单总结:重复则先删除再插入新记录,不重复则插入

    示例

    REPLACE INTO `user` ( username, PASSWORD, mobile_phone_number, email )
    VALUES
    	( 'Buffett', '123456', '13800000099', 'Buffett@163.com' );
    

    执行结果

    REPLACE INTO `user` ( username, PASSWORD, mobile_phone_number, email )
    VALUES
    	( 'Buffett', '123456', '13800000099', 'Buffett@163.com' )
    > Affected rows: 2
    > 时间: 0.019s
    

    表记录,user_id和mobile_phone_number变了,update_time变为了空

    user_id username password mobile_phone_number email delete_state create_time update_time
    10 Buffett 123456 13800000099 Buffett@163.com 0 2020-05-28 09:49:53

    使用场景总结

    • 如果出现重复异常,希望捕获异常,则使用insert into

    • 如果出现重复异常,希望保存旧纪录,忽略新纪录,则使用insert ignore into

    • 如果出现重复异常,希望更新指定字段,则使用insert into … on duplicate key update

    • 如果出现重复异常,希望删除旧记录,插入新记录,则使用replace into

    展开全文
  • select into和insert into select

    万次阅读 2018-01-27 20:36:56
    1、SELECT INTO FROM语句(Sql Server) 语句形式为:SELECT vale1, value2 into Table2 from Table1 要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中 2、INSERT...
  • 场景: 使用MySQL存储千万级数据量并根据城市进行分表,从总表对分表插入数据时很慢很慢 原因: 在默认的事务隔离级别下: ...使用insert into tablA select * from tableB语句时,一定要确保tableB后面的where,...
  • REPLACE INTO

    千次阅读 2020-03-20 21:50:11
    REPLACE INTO 1.前言 replace into 可以说是 insert 的增强版,但由于其独特的特性,误用会带来一些副作用, 其功能与 insert 功能类似,不同点是replace into 首先尝试插入数据到表中 如果数据已经存在...
  • select into from 和 insert into select都是用来复制表,两者的主要区别为: select into from 要求目标表不存在,因为在插入时会自动创建。insert into select from 要求目标表存在   下面分别介绍两者语法   一...
  • SELECT INTO

    千次阅读 2018-11-14 16:14:11
    Evernote Export Sql Server中 select into 的用法01. 把存储过程结果集SELECT INTO到临时表在开发过程中,很多时候要...1. 使用select into会自动生成临时表,不需要事先创建select into #temp from sy...
  • INSERT IGNORE INTO 与 INSERT INTO

    千次阅读 2019-05-21 17:48:18
    INSERT IGNORE INTO 与 INSERT INTO 转载:https://blog.csdn.net/qq_30715329/article/details/79363761 INSERT IGNORE INTO 会忽略数据库中已经存在 的数据,如果数据库没有数据,就插入新的数据,如果有数据...
  • insert into select 和 insert into values区别

    万次阅读 2018-03-30 11:38:11
    INSERT INTO SELECT语句:从一个表复制数据,然后把数据插入到一个已存在的表中。将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO ...
  • 如何用insert into values插入多条数据

    万次阅读 多人点赞 2018-05-31 12:03:20
    INSERT INTO 语句 INSERT INTO 语句用于向表格中插入新的行。 语法:第一种形式无需指定要插入数据的列名,只需提供被插入的值即可: INSERT INTOtable_name VALUES (value1,value2,value3,...); 例子: ...
  • replace into和insert into区别

    千次阅读 2018-02-27 23:14:44
    replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中, 1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。 2. 否则,直接插入新数据...
  • select into与insert into区别

    千次阅读 2016-06-07 10:43:43
    select into from 和 insert into select都是用来复制表,两者的主要区别为: select into from 要求目标表不存在,因为在插入时会自动创建。insert into select from 要求目标表存在。 下面分别介绍两者语法 一、...
  • 表复制:SELECT INTO 和 INSERT INTO SELECT

    万次阅读 2018-01-09 20:26:21
    INTO SELECT语句 语句形式为: Insert into Table2(field1,field2,...) select value1,value2,... from Table1 要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的...
  • SQL学习 之 into outfile 和 into dumpfile

    千次阅读 2020-03-31 15:18:19
    在学sqlmap的时候发现,写文件不用into outfile用的却是into dumpfile于是去查了一波。 the SELECT ... INTO form of SELECT enables a query result to be stored in variables or written to a file: SELECT ... ...
  • mysql select into和insert into select

    千次阅读 2018-05-11 17:38:49
    SELECT INTO FROM语句 语句形式为:SELECT vale1, value2 into Table2 from Table1 要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到Table2中2、INSERT INTO SELECT语句...
  • insert into 是插入表最常用的语句,一般我们往表里插入数据要首先判断是否存在,再插入。举个栗子~~~~ if not exists (select 1 from t where id = 1) then insert into t(id, update_time) values(1, getdate()) ...
  • insert into select与select into的区别

    千次阅读 2017-12-12 16:39:22
    1.适用场景:将table1的全部字段...2.实现方式:select into语句、insert into select语句。 3.select into语句、insert into select语句实现方式的区别:  (1)insert into select语句  insert into Table1(fi
  • insert into value和insert into select from dual 两者效果一样
  • 通常会有这两种方法:insert into select 和 select into from    insert into select:是PL/SQL language 的赋值语句,可以将select 出来的N行(0到任意数)结果集复制一个新表中   select into from:是...
  • select into 与 insert into select

    千次阅读 2015-04-22 21:20:36
    insert into select: 用于将select出来的结果集复制到一个新表中, 它是标准的sql语句 select into: 将结果保存到一个变量中, 它是plsql的赋值语句 二. 例子: insert into select: insert into test select * ...
  • select into from 和 insert into select都被用来复制表结构和表中数据, 两者的主要区别为: select into from 要求目标表不存在,因为在插入时会自动创建。 insert into select from 要求目标表已存在数据库...
  • insert into table1(字段)select table2:从一个表复制数据,然后把数据插入到一个已存在的表中。 注意事项:当数据库语句为insert into table1(字段)select table2 时,切记不可加values 否则就是错误的写法了 ...
  • replace into详解

    千次阅读 2020-04-29 11:16:03
    一、replace into原理: replace是insert的增强版 replace into 首先尝试插入数据到表中, 1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。 2. 否则,直接插入新...
  • mysql中SELECT INTO 和 INSERT INTO SELECT

    千次阅读 2018-09-01 17:51:38
    1.INSERT INTO SELECT语句 语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1 要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外...
  • 1.INSERT INTO SELECT语句语句形式为:Insert into Table2(field1,field2,…) select value1,value2,… from Table1或者:Insert into Table2 select * from Table1注意: (1)要求目标表Table2必须存在,并且字段...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 691,870
精华内容 276,748
关键字:

into