• 【postgresql 基础入门】插入数据的多种方式 单条,多值,查询结果,插入数据冲突处理,批量导入,多种方式让数据插入更灵活


    添加表数据

    专栏内容

    开源贡献

    个人主页我的主页
    管理社区开源数据库
    座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.

    系列文章

    前言

    postgresql 数据库是一款通用的关系型数据,在开源数据库中能与商业数据媲美,在业界也越来越流行。

    因为是开源数据库,不仅公开源码,还有很多使用案例,好用的插件,所以它的慢慢变成了数据库的先驱和标准,通过postgresql可以很好从使用到原理,彻底搞懂;

    如果是学习编程,也可以学到丰富的编程知识,数据结构,编程技巧,它里面还有很多精妙的架构设计,分层思想,可以灵活定制的思想。

    本专栏主要介绍postgresql 入门使用,数据库维护管理,通过这些使用来了解数据库原理,慢慢了解postgresql是什么样的数据库,能做那些事情,以及如何做好服务,最关键的是这些知识都是面试的必备项。

    概述

    通过前几篇文文章,我们了解了postgresql 的服务启停,数据表的管理,接下来就是给我们创建的表添加数据,进行真正的使用了。

    数据库表添加数据通常使用insert语句,可以进行单条数据的插入,也可以进行多value的插入,还可以写到sql脚本中进行批量插入;当然,也可以将查询结果存入一张表中;

    下面我们就来一起看看各种方法的使用。

    单条插入 (Single Insert)

    常用的插入语句就是insert into 往某张表中插入一条数据,它的语法形式如下:

    INSERT INTO table_name (column1, column2, column3)
    VALUES (value1, value2, value3);
    
    • 1
    • 2

    假设有一个名为"users"的表,具有"id"、"name"和"age"三个列,你可以使用以下语句将一条新记录插入到表中:

    INSERT INTO users (id, name, age)
    VALUES (1, 'John Doe', 25);
    
    • 1
    • 2

    这将向"users"表插入一条新的记录。

    多条插入(Multiple Insert)

    如果有多条数据,我们可以在一条insert into 语句中一次性插入到某张表中,它的语法形式如下:

    INSERT INTO table_name (column1, column2, column3)
    VALUES (value1, value2, value3),
           (value4, value5, value6),
           (value7, value8, value9);
    
    • 1
    • 2
    • 3
    • 4

    你可以一次插入多条记录到表中。在上面的示例中,将同时插入三条记录到"users"表中。

    INSERT INTO users (id, name, age) 
    VALUES (2, 'White', 27),  (3, 'Greenly', 33), (4, 'James', 20);
    
    • 1
    • 2

    在使用 insert into 时,当我们对表中的每个字段都有值对应时,可以只指定表名即可,不用列出所有的列名;

    INSERT INTO users  
    VALUES (2, 'White', 27), (3, 'Greenly', 33, (4, 'James', 20);
    
    • 1
    • 2

    带冲突处理(Conflict Handling)

    在插入数据时,可能会遇到冲突,例如插入重复的唯一索引或主键值。 PostgreSQL提供了ON CONFLICT子句来处理冲突。

    可以有以下选项:

    • DO NOTHING 当冲突发生时,什么都不做,也就不插入数据;
    • DO UPDATE 当冲突发生时,执行update操作,更新冲突列以外的列的值;

    DO NOTHING

    INSERT INTO users (id, name, age)
    VALUES (1, 'John Doe', 25)
    ON CONFLICT (id) DO NOTHING;
    
    • 1
    • 2
    • 3

    如果"id"列的值已经存在于"users"表中,将不执行任何操作。

    DO UPDATE

    INSERT INTO users (id, name, age)
    VALUES (1, 'John Doe', 25)
    ON CONFLICT (id) DO UPDATE;
    
    • 1
    • 2
    • 3

    你可以根据自己的需求,选择使用DO NOTHINGDO UPDATE或其他操作来处理冲突。

    ON CONFLICT DO UPDATE保证一个原子的 INSERT或者 UPDATE结果。在没有无关错误的前提下,这两种 结果之一可以得到保证,即使在很高的并发度也能保证。这也可以被称作 UPSERT — “UPDATE 或 INSERT”。

    需要注意的是,DO UPDATE不能在分区表上使用,因为update后,所有在分区有可能会发生变化;

    当然还可以带条件选择进行DO UPDATE, 也就是条件满足时,update动作;

    postgres=# INSERT INTO users (id, name, age)
    VALUES (1, 'John Doe', 10)
    ON CONFLICT (id) DO UPDATE SET name = EXCLUDED.name WHERE users.age < 18;
    INSERT 0 0
    
    • 1
    • 2
    • 3
    • 4

    当 age小于18岁时,我们才会更新名字,大于等于18的会选择忽略;

    这时会用EXLUDED 来引用要插入的数据,类似一个虚拟的表,而通过原表名引用当前表中已经存在的数据,如上例中,当前表中的age < 18时,才会将name 字段更新为 新值,用excluded字段引用,这里看到更新条数为0,因为表中的age是25;

    将查询结果插入表中

    表数据的来源,还可以是SQL的查询结果, 通过 INSERT INTO ... SELECT 语法,将查询的结果插入表中。

    postgres=# create table user_A(id int primary key, name varchar, order_date date, total_amount numeric(10,2));
    CREATE TABLE
    
    postgres=# insert into user_A(id,name,order_date,total_amount) select c.customer_id, c.customer_name, o.order_date, o.total_amount from orders o, products p, customers c where o.customer_id = c.customer_id and o.order_id = p.product_id and total_amount > 100;
    INSERT 0 2
    
    • 1
    • 2
    • 3
    • 4
    • 5

    新创建一张表user_A, 然后使用我们前面分享的关联查询的方法,从三张表中查到消费总计超过100的消费者信息,记录到user_A中,这样就将优质客户信息单独记录到一张表中。

    批量导入 (Bulk Insert):

    如果你需要批量导入大量数据,可以使用COPY命令,它可以将一个文件的格式化的数据批量导入一张表中。

    COPY table_name (column1, column2, column3) FROM '/path/to/data.csv' CSV;
    
    • 1

    这个命令将从指定的CSV文件路径将数据导入到表中,你需要确保CSV文件的列与表的列相匹配,文件中各字段值间的分隔符必须是相同的,每行数据占一行;

    总结

    通过本文的分享,了解了数据表中如何添加数据,有单条直接插入,这也是常用的SQL,还有多个值同时插入,以及插入时的冲突处理,此外还有将带条件查询结果插入表中,批量插入等高级用法。

    结尾

    非常感谢大家的支持,在浏览的同时别忘了留下您宝贵的评论,如果觉得值得鼓励,请点赞,收藏,我会更加努力!

    作者邮箱:study@senllang.onaliyun.com
    如有错误或者疏漏欢迎指出,互相学习。

    注:未经同意,不得转载!

  • 相关阅读:
    阿里二面:列出 Api 接口优化的几个技巧
    C#实现选择排序算法
    Raspberry Pi 5 新平台 新芯片组
    如何更改文件类型?4个方法,轻松操作!
    webpack5 打包环境抽离分环境基本配置
    vs2019+boost库(boost_1_67_0)安装
    网络技术十一:链路聚合
    VsCode开发Vue(开源框架使用ruoyi)
    『手撕Vue-CLI』下载指定模板
    sql调优之:字符集不一致导致的索引失效案例
  • 原文地址:https://blog.csdn.net/senllang/article/details/133667276