zoukankan      html  css  js  c++  java
  • MySQL基础之插入数据

    数据插入

    INSERT是用来插入(或添加)行到数据库表的。插入可以用几种方式使用:

    • 插入完整的行
    • 插入行的一部分
    • 插入多行
    • 插入某些查询的结果

    插入完整的行

    把数据插入表中的最简单的方法是使用基本的INSERT语法, 它要求指定表名和被插入到新行中的值。

    MariaDB [crashcourse]> INSERT INTO Customers 
        -> VALUES(NULL,
        -> 'Pep E. LaPew',
        -> '100 Main Street',
        -> 'Los Angeles',
        -> 'CA',
        -> '90046',
        -> 'USA',
        -> NULL,
        -> NULL);

    如果你不想给出一个值, 又不能省略此列的时候, 可以指定该列为NULL值

    虽然这种方法很简单, 但并不安全, 应该避免使用。上面的SQL语句高度依赖于表中列的定义次序, 并且还依赖于其次序容易获得的信息。

    INSERT INTO Customers(cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)  VALUES('Pep E. LaPew', '100 Main Street', 'Los Angeles', 'CA', '90046', 'USA', NULL, NULL);

    使用这种语法, 还可以省略列。这表示可以只给某些列提供值。给其他列不提供值。

    INSERT INTO操作可能很耗时(特别是有很多索引需要更新的时候), 而且它可能降低等待处理的SELECT语句的性能。

    如果数据检索是最重要的, 可以通过在INSERT INTO之间添加关键字LOW_PRIORITY, 指示MySQL降低INSERT语句的优先级, 如下所示

    INSERT LOW_PRIOPITY INTO

    插入多行

    如果想要插入多行, 那么可以使用多条INSERT语句, 甚至一次提交它们, 每条语句用一个分号结束

    INSERT INTO Customers(cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)  VALUES('Pep E. LaPew', '100 Main Street', 'Los Angeles', 'CA', '90046', 'USA', NULL, NULL);INSERT INTO Customers(cust_address, cust_city, cust_state, cust_zip, cust_country) VALUES('M. Martian', '42 Galaxy way', 'New York', 'NY', '11213', 'USA');

    或者, 只要每天INSERT语句中的列名(和次序)相同, 可以如下组合个语句

    INSERT INTO Customers(cust_address, cust_city, cust_state, cust_zip, cust_country)  VALUES('Pep E. LaPew', '100 Main Street', 'Los Angeles', 'CA', '90046', 'USA'),
    'M. Martian', '42 Galaxy way', 'New York', 'NY', '11213', 'USA'

    此技术可以提高数据库处理的性能, 因为MySQL用单条INSERT语句处理多个插入比使用多条INSERT语句快

    插入检索出的数据

    INSERT可以将一条SELECT语句的结果插入表中。这就是所谓的INSERT SELECT。

    INSERT INTO customers(cust_id, cust_contact, cust_email, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country)SELECT cust_id, cust_contact, cust_email, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country FROM custnew;

    INSERT SELECT语句中SELECT语句可包含WHERE子句以过滤插入的数据

  • 相关阅读:
    csp-s 92
    支持smtp/imap smtp/pop3的撞库python撞库脚本
    关于KB2839299 微软补丁前后的kifastcallentry
    (转载)RegSetValueEx设置REG_SZ类型键值时要注意的问题
    x64windows安全机制进程_线程_模块加载回调摘要
    windbg脚本实践3----监控特定进程创建
    windbg脚本实践2----监控特定注册表键值创建和删除
    windbg脚本实践1----监控特定文件创建 删除 读写
    纪念在乙方安全公司的2年_关于杀毒软件和远控的斗争
    文件删除的windows下面的三种路径(轻量级)
  • 原文地址:https://www.cnblogs.com/featherwit/p/13406415.html
Copyright © 2011-2022 走看看