insert 返回字段说明

简介: --查我们插入一条数据到数据库时,pg会返回给我们如下信息,postgres=# insert into test_2(id) select n from generate_series(...
--查我们插入一条数据到数据库时,pg会返回给我们如下信息,
postgres=# insert into test_2(id) select n from generate_series(1,10000) n;
INSERT 0 10000
--第一列说明是插入动作,第三列表示插入了多少行,那么第二列是什么呐


--查看源码,可知
ProcessQuery(PlannedStmt *plan,
			 const char *sourceText,
			 ParamListInfo params,
			 DestReceiver *dest,
			 char *completionTag)
{
	if (completionTag)
	{
		Oid			lastOid;

		switch (queryDesc->operation)
		{
			case CMD_SELECT:
				snprintf(completionTag, COMPLETION_TAG_BUFSIZE,
						 "SELECT %u", queryDesc->estate->es_processed);
				break;
			case CMD_INSERT:  --如果执行的命令是 insert 
				if (queryDesc->estate->es_processed == 1) --如果插入了一行
					lastOid = queryDesc->estate->es_lastoid; --插入表的 OID
				else
					lastOid = InvalidOid; --插入的行数超过一行,则返回系统默认OID=0
				snprintf(completionTag, COMPLETION_TAG_BUFSIZE,
				   "INSERT %u %u", lastOid, queryDesc->estate->es_processed); --实际打印的输出
				break;
			case CMD_UPDATE:
				snprintf(completionTag, COMPLETION_TAG_BUFSIZE,
						 "UPDATE %u", queryDesc->estate->es_processed);
				break;
			case CMD_DELETE:
				snprintf(completionTag, COMPLETION_TAG_BUFSIZE,
						 "DELETE %u", queryDesc->estate->es_processed);
				break;
			default:
				strcpy(completionTag, "???");
				break;
		}
	}
	
}


--由以上可知 pg插入返回的第二列是一个oid
--只有在表具有oid属性,且插入行数为一行时,第二列才实际被填充

postgres=# create table t1(id int) with (oids=true);
CREATE TABLE
postgres=# \d+ t1;
                          Table "public.t1"
 Column |  Type   | Modifiers | Storage | Stats target | Description 
--------+---------+-----------+---------+--------------+-------------
 id     | integer |           | plain   |              | 
Has OIDs: yes

--oid列被填充
postgres=# insert into t1 values(1);                
INSERT 33125 1
--超过一行,oid列被填充为0
postgres=# insert into t1 values(1),(2);  
INSERT 0 2	


目录
相关文章
|
2月前
|
SQL 存储 关系型数据库
SQL判断CHAR类型字段不为空的方法与技巧
在SQL查询中,判断一个CHAR类型字段是否不为空是一个常见的需求
|
6月前
|
数据库
仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值
仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值
766 0
|
7月前
|
SQL 数据库
SQL INSERT INTO 语句详解:插入新记录、多行插入和自增字段
SQL INSERT INTO 语句用于在表中插入新记录。
694 0
|
SQL 数据采集 关系型数据库
SQL中对数据字段null值的处理
SQL中对数据字段null值的处理
SQL中对数据字段null值的处理
|
Java 数据库连接 mybatis
metaObject.hasSetter在updayeFill的时候把实体类中没有这个字段的值也返回了true
metaObject.hasSetter在updayeFill的时候把实体类中没有这个字段的值也返回了true
165 0
|
程序员 数据库 索引
|
关系型数据库 MySQL RDS
timestamp类型在not null时可以插入null值?
背景 有同学问在RDS MySQL 5.6在timestamp 设置为 not null 并且SQL模式是严格模式时,仍然可以插入空值,理论上应该有报错,是不是RDS的bug? 环境 MySQL 5.
2447 0