返回顶部
首页 > 资讯 > 数据库 >MySQL数据库(五)插入操作
  • 717
分享到

MySQL数据库(五)插入操作

MySQL数据库(五)插入操作 2016-04-14 05:04:42 717人浏览 无得
摘要

前提要述:参考书籍《Mysql必知必会》 《mysql必知必会》是先讲了查询,但是没有记录就无法查询,所以先将如何添加数据。 表已经知道怎么创建了,随便创两张。 5.1 插入数据 Mysql使用 INSERT来插入(或添加)行

MySQL数据库(五)插入操作

前提要述:参考书籍《Mysql必知必会》

mysql必知必会》是先讲了查询,但是没有记录就无法查询,所以先将如何添加数据。

表已经知道怎么创建了,随便创两张。

5.1 插入数据

Mysql使用 INSERT来插入(或添加)行(记录)到数据库表中。插入可用以下几种方式使用:

  • 插入完整的行(记录);
  • 插入行的一部分;
  • 插入多行;
  • 插入某些查询结果。

5.2 插入完整的行(记录)

什么叫完整的行,即插入的有效数据都可以对应表中的每一列。

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

# 写法:
INSERT INTO  VALUES(value1,value2,...);
# 规范写法:
INSERT INTO (field1, field2, ...) VALUES(value1,value2,...);

解释:

  • 如果使用第一种写法,虽然很简单,但是并不安全,应该尽量避免使用。因为该语句高度依赖于表中列的次序,并且还依赖其次序容易获得的信息。即使可得到这种次序信息,也不能保证下次表结构变动后各个列保持完全相同的次序。所以在开发中如果这样写,那么就是把插入语句写死了。因为数据库表中的列的顺序有可能可能会改变,一旦改变,就会出现致命错误,比如:一个varchar类型的可能会被插入到char中,如果超长度可能会报错,而且varchar是大范围而char是小范围,可能会导致数据丢失;而如果一个浮点型的数据因为列顺序的改变插入到了一个整型的列中,这又不会报错,所以也很难找错。
  • 推荐使用规范写法,特别是在开发时编写sql语句。因为一旦指定列名,那么VALUES必须以其指定的次序匹配指定的列名,不一定按各个列出现在实际表中的次序。 所以即使表的结构改变,此INSERT语句仍然可以正确工作。
  • 第一种写法必须完整的给出表中的全部列的值,并且还得按照表中列的次序;而规范写法不用,因为会根据(field1, field2, ...)来进行赋值,即使跟表中的列的次序不一样,或者一些列不想赋值。

例子:在学生表中插入数据

INSERT INTO student(stu_id, stu_name, stu_sex)  VALUES(1, '张三', '男');

注意:字符串或字符需要使用""(单引号)圈起来。

输出:如果成功的话

Query OK, 1 row affected (0.01 sec)

而如果在主键使用了自增长(AUTO_INCREMENT),那么则可以这样写

INSERT INTO student(stu_id, stu_name, stu_sex)  VALUES(null, '张三', '男');

或者,不写主键:

INSERT INTO student(stu_name, stu_sex)  VALUES('张三', '男');

也就是插入时,在主键的位置直接插入null或者不写默认就是赋给null,MySQL会因为AUTO_INCREMENT自己给它赋值。


  • 如果对表中不允许NULL值且没有默认值的列不给出值(插入时省略了),则MySQL将产生一条错误信息,并且相应的行插入不成功。
  • 规范写法哪些列可以省略不写:
    • 该列定义为允许NULL值(无值或空值);
    • 在表定义中给出默认值。也就表示如果在插入时不给出值,就会使用默认值;
    • 使用AUTO_INCREMENT的列。
  • INSERT操作可能很耗时(特别是有很多索引需要更新时),而且它可能降低等待处理的SELECT语句的性能。如果数据检索是最重要的,则可以通过在INSERT和INTO之间添加关键字LOW_PRioRITY,指示MySQL降低INSERT语句的优先级。
INSERT LOW_PRIORITY INTO
  • UPDATE操作和DELETE操作也适用。

5.3 插入多个行

INSERT可以插入一行到一个表中,也可以插入多行到一个表中,第一种方式就是写多条INSERT语句,还有一种方式就是在一条INSERT语句中插入多行。

语法:

INSERT INTO (
    field1,
    field2,
    ...
    )
    VALUES(
        valueA1,
        valueA2,
        ...
        ),
        (
        valueB1,
        valueB2,
        ...
    );

此写法可以提供INSERT的性能,因为MySQL用单条INSERT语句处理多个插入比使用多条INSERT快。

5.4 插入检索出的数据

INSERT语句可以利用一条SELECT语句查询的结果插入到表中。也就是所谓的INSERT SELECT,它是由一条INSERT语句和一条SELECT语句构成。

比如我需要把一张表的数据复制到另一张表,语法:

INSERT INTO (field1, field2, ...) 
    SELECT field1, field2 FROM ;
# 或 也就是列名可以不同
INSERT INTO (field1, field2, ...) 
    SELECT f1, f2 FROM ;

注意:如果新表不存在则报错。
解释:

  • 先使用SELECT语句从旧表中查询出数据,然后再使用INSERT语句把查询的结果插入到新表中。
  • SELECT列出的每一个列对应于后所跟的列表中的每一个列。
  • 如果为空,即没有行可以插入也不会报错。
  • 如果能保证从旧表导入到新表(假设新表有数据)的主键值不会重复,那么插入时可以省略这主键,比如有AUTO_INCREMENT的主键就可以省略。
  • 在INSERT和SELECT语句中使用相同的列名,但是不一定要求列名匹配。实际上,MySQL甚至不关心SELECT返回的列名。它使用的是列的位置,因此SELECT中的第一列(不管列名)将用来填充表列中指定的第一个列,第二列将用来填充表列中指定的第二列等。
  • INSERT SELECT中SELECT语句可包含WHERE子句以过滤插入的数据。
您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库(五)插入操作

本文链接: https://lsjlt.com/news/3746.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL数据库(五)插入操作
    前提要述:参考书籍《MySQL必知必会》 《MySQL必知必会》是先讲了查询,但是没有记录就无法查询,所以先将如何添加数据。 表已经知道怎么创建了,随便创两张。 5.1 插入数据 MySQL使用 INSERT来插入(或添加)行...
    99+
    2016-04-14
    MySQL数据库(五)插入操作
  • MYSQL数据库插入数据的基本操作
    下文主要给大家带来MYSQL数据库插入数据的基本操作,希望这些内容能够带给大家实际用处,这也是我编辑MYSQL数据库插入数据的基本操作这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。插入数据在建立一...
    99+
    2024-04-02
  • 用python操作mysql数据库(之简单“插入数据”操作)
    #!/usr/bin/env python # -*- coding: utf-8 -*- ''' 1、这里的数据库环境为本地数据库 2、我要通过pytho...
    99+
    2024-04-02
  • Python操作mysql之插入数据
    之前有写过一篇python查询mysql数据的文章,今天写通过python插入数据到mysql数据库。1.先建库,建表,建用户mysql> CREATE DATABASE tda DEFAULT CH...
    99+
    2024-04-02
  • MongoDB笔记五——插入操作
    1、插入语法...
    99+
    2024-04-02
  • MySQL数据库操作DML 插入数据,删除数据,更新数据
    目录DML介绍数据插入数据修改数据删除DML介绍 DML是指数据操作语言,英文全称是Data Manipulation Language,用来对数据库中表的数据记录进行更新。 关键字: 插入insert删除delet&#...
    99+
    2022-07-11
    MySQL数据库操作DML MySQL插入数据 MySQL删除数据 MySQL更新数据
  • MySQL数据库操作DML 插入数据,删除数据,更新数据
    目录DML介绍数据插入数据修改数据删除DML介绍 DML是指数据操作语言,英文全称是Data Manipulation Language,用来对数据库中表的数据记录进行更新。 关键字...
    99+
    2024-04-02
  • MySQL怎么实现数据插入操作
    今天小编给大家分享一下MySQL怎么实现数据插入操作的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、方法分类二、具体方法使...
    99+
    2023-07-05
  • python实现MySQL 数据库表格创建 数据插入及获取插入ID操作教程
    目录创建表格检查表格是否存在主键插入数据到表格插入多行获取插入的ID创建表格 要在mysql中创建表格,请使用"CREATE TABLE"语句。 确保在创建连接时定义了数据库的名称。 示例创建一个名为...
    99+
    2023-11-11
    Python操作MySQL表格数据 Python操作MySQL
  • 用python实现操纵mysql数据库插入
    python操纵mysql数据库,向一个表中插入一条新的记录。 pycahrm提供一个很好的功能,在右边上面,可以连接数据库,并在里面手动操作数据库,连接步骤略过。 1.先看下表...
    99+
    2024-04-02
  • mysql插入多条数据的操作步骤
    这篇文章主要介绍mysql插入多条数据的操作步骤,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql插入多条数据的方法:1、登录mysql数据库;2、指定要插入多条数据的数据库;...
    99+
    2024-04-02
  • python 插入mysql数据库数据
    建立数据库连接def create_db_connect():    """    brief info for: create_db_connect &nbs...
    99+
    2024-04-02
  • mysql数据库表插入数据
    如何向mysql数据表中插入数据? 答:你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据。 以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法: 如果数据是字符型,必须使用单引...
    99+
    2023-08-31
    数据库 mysql php
  • 从零学习node.js之mysql数据库的操作(五)
    准备工作 在使用node操作mysql数据库时,需要先下载mysql模块: npm install mysql --save-dev 在引入mysql模块后,就可以进行数据库的连接和其他的操作了。 ...
    99+
    2022-06-04
    操作 数据库 node
  • 【MySQL】数据库——库操作
    文章目录 1. 创建数据库[IF NOT EXISTS] 的使用 2. 删除库3. 数据库的编码问题查看系统默认支持的字符集查看系统默认支持的校验集只查看 database的校验集指定编码...
    99+
    2023-10-20
    数据库 mysql
  • MySql数据库操作
    MySql数据库操作 –登录MySql:——–Windows环境进入cmd后输入mysql –h localhost –u root –p,再输入密码就可以启动mysql;其中localhost是...
    99+
    2024-04-02
  • 操作MySQL数据库
    SQL是什么    SQL是结构化查询语言,这是一种计算机语言,用于存储,操纵和检索存储在关系数据库中的数据。    SQL是关系数据库系统的标准语言。所有关系型数据...
    99+
    2024-04-02
  • MySQL数据库——MySQL INSERT:插入数据(添加数据)
    数据库与表创建成功以后,需要向数据库的表中插入数据。在 MySQL 中可以使用 INSERT 语句向数据库已有的表中插入一行或者多行元组数据。 基本语法 INSERT 语句有两种语法形式,分别是 INSERT…VALUES 语句和 INSE...
    99+
    2023-08-31
    数据库 mysql sql
  • 如何用python实现操纵mysql数据库插入
    这篇文章主要讲解了“如何用python实现操纵mysql数据库插入”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用python实现操纵mysql数据库插入”吧!python操纵mysql...
    99+
    2023-06-28
  • Python3 多线程(连接池)操作MySQL插入数据
    目录多线程(连接池)操作MySQL插入数据 1.主要模块 2.创建连接池 3.数据预处理 4.线程任务 5.启动多线程 6.完整示例 7.思考/总结 多线程(连接池)操作MySQL插...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作