向PostgreSQL插入数据

在创建完一个表的时候,它里面没有数据。在数据库可以有点用处之前要做的第一件事就是向里面插入数据。数据在概念上是每次插入一行。我们当然可以每次插入多行,但是确实没有办法插入少于一行的数据。即使你只知道几个字段的数值,那么你也必须创建一个完整的行。

使用INSERT命令创建一个新行。这条命令要求提供表名字以及字段值。

CREATE TABLE products (
    product_no integer,
    name text,
    price numeric
);

下面是一个向表中插入一行的例子:

INSERT INTO products VALUES (1, ‘Cheese‘, 9.99);

数据值是按照这些字段在表中出现的顺序列出的,并且用逗号分隔。通常,数据值是文本(常量),但也允许使用标量表达式。

上述语法的缺点是你必须知道表中字段的顺序。你也可以明确地列出字段以避免这个问题。比如,下面的两条命令都和上面的那条命令效果相同:

INSERT INTO products (product_no, name, price) VALUES (1, ‘Cheese‘, 9.99);
INSERT INTO products (name, price, product_no) VALUES (‘Cheese‘, 9.99, 1);

许多用户认为明确列出字段名是个好习惯。

如果你不知道所有字段的数值,那么可以省略其中的一些。这时候,这些未知字段将被填充为它们的缺省值。比如:

INSERT INTO products (product_no, name) VALUES (1, ‘Cheese‘);
INSERT INTO products VALUES (1, ‘Cheese‘);

第二种形式是PostgreSQL的一个扩展。它从左向右用给定的值尽可能多的填充字段,剩余的填充缺省值。

为了保持清晰,你也可以对独立的字段或者整个行明确使用缺省值:

INSERT INTO products (product_no, name, price) VALUES (1, ‘Cheese‘, DEFAULT);
INSERT INTO products DEFAULT VALUES;

你可以在一条命令中插入多行:

INSERT INTO products (product_no, name, price) VALUES
    (1, ‘Cheese‘, 9.99),
    (2, ‘Bread‘, 1.99),
    (3, ‘Milk‘, 2.99);

提示: 要一次插入大量数据,可以看看COPY命令。它不像INSERT命令那么灵活,但是更高效。

时间: 2024-07-29 16:06:37

向PostgreSQL插入数据的相关文章

Postgresql插入数据返回自增id

Postgresql插入数据返回自增id 一.设置自增id 新建字段  并且将字段属性设置为serial 二.插入返回 insert语句增加return 例如:insert into point(pointtype,pointx,pointy,pointval)values(1,2,3,4) RETURNING id;

关于oracle批量插入数据遇到的问题

截取部分日志信息: 2015-09-01 14:48:47,132 INFO [org.springframework.beans.factory.xml.XmlBeanDefinitionReader] - Loading XML bean definitions from class path resource [org/springframework/jdbc/support/sql-error-codes.xml]2015-09-01 14:48:47,178 INFO [org.spr

postgres 使用存储过程批量插入数据

参考资料(pl/pgsql 官方文档): http://www.postgresql.org/docs/9.3/static/plpgsql.html create or replace function creatData2() returns boolean AS $BODY$ declare ii integer; begin II:=1; FOR ii IN 1..10000000 LOOP INSERT INTO ipm_model_history_data (res_model, r

golang 下 mongodb 与 postgresql 插入速度的测试

近期看了篇文章,说是postgresql也支持nosql,定义了专属的jsonb数据类型,而且速度比mongodb还快,今天验证了下,同样的数据,postgre的插入速度只是mongo 的三分一不到.有可能是各自的驱动造成的. 数据结构: type StockDay struct { Date int32 O, H, L, C, V, A float32 } mongo 用了mgo 包,插入代码如下: func ReadHq(conn net.Conn, c *mgo.Collection, C

postgresql大批量数据导入方法

一直没有好好关注这个功能,昨天看了一下,数据库插入有瓶颈,今天研究了一下: 主要有以下方案: 1.使用copy从文件导入: copy table_001(a, b, "f", d, c, "e") from 'd:/data1.txt' (delimiter ','); 速度极快: 不带索引: 查询成功: 共计 69971 行受到影响,耗时: 4351 毫秒(ms).        查询成功: 共计 69971 行受到影响,耗时: 4971 毫秒(ms).     

FreeSql 插入数据,如何返回自增值

FreeSql是一个功能强大的 .NET ORM 功能库,支持 .NetFramework 4.0+..NetCore 2.1+.Xamarin 等支持 NetStandard 所有运行平台. 以 MIT 开源协议托管于 github:https://github.com/2881099/FreeSql FreeSql 插入数据的方式有多种,这篇文章教你用最优的方案做数据插入功能. static IFreeSql fsql = new FreeSql.FreeSqlBuilder() .UseC

没有躲过的坑--map的初始化(插入数据)

最近工作中需要使用map,进行查询. 首先简单介绍一点map,也许是教科书里讲授最少的STL知识吧.但是在实际工作中map挺重要的,用于查找很方便快捷,尤其是以键和值的形式存在的! 1.头文件 #include<map> 2.map的功能 自动建立Key - value的对应.key 和 value可以是任意你需要的类型. 根据key值快速查找记录,查找的复杂度基本是Log(N),如果有1000个记录,最多查找10次,1,000,000个记录,最多查找20次. 快速插入Key - Value

php 获取最后插入数据的id

向mysql 插入数据时 很多时候 我们想知 道刚刚插入数据的id 这对我们很有用 下面我说出常用的三种 方法并一一分析其利与弊 一 用以下语句: mysql_query("select max(id) from t1",$link); 使用这种方法时 我们得到得是 id最大的值 的确时最后一个 但当多链接线程时 这个最大的id并不一定是 我们插入的所以这个不利用域线程 二 用以下函数: msyql_insert_id(); 当系统执行完INSERT后,再执行SELECT时,可能已经被

向mysql中批量插入数据的性能分析

MYSQL批量插入数据库实现语句性能分析 假定我们的表结构如下 代码如下   CREATE TABLE example (example_id INT NOT NULL,name VARCHAR( 50 ) NOT NULL,value VARCHAR( 50 ) NOT NULL,other_value VARCHAR( 50 ) NOT NULL) 通常情况下单条插入的sql语句我们会这么写: 代码如下   INSERT INTO example(example_id, name, valu