我正在学习Postgresql和db。我有这样一个简单的查询,我想了解它做了什么
CREATE TABLE adempiere.c_mom(
c_mom_id NUMERIC(10,0) NOT NULL,
isactive character(1) DEFAULT 'Y'::bpchar NOT NULL,
start_date date NOT NULL,
start_time timestamp without time zone NOT NULL,
end_time timestamp without time zone NOT NULL,
CONSTRAINT c_mom_pkey PRIMARY KEY (c_mom_id)
);所以在我执行完这个任务后
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "c_mom_pkey" for table "c_mom"is c_mom_id,但是创建一个隐式索引的目的是什么呢?DEFAULT 'Y'::bpchar做什么,或者::一般做什么?谢谢
发布于 2013-09-09 10:06:13
::表示法是一个特定于PostgreSQL的型铸造表示法,在本例中输入bpchar (空白填充字符)。
创建索引是为了备份主键,以提高它们的效率。如果没有索引来支持它,那么每个insert语句都必须扫描整个表,以确定该插入是否会创建一个重复的键。使用索引可以加快速度(如果表很大的话)。
这不是PostgreSQL特有的。许多关系数据库将创建唯一的索引来备份主键。
https://stackoverflow.com/questions/18695696
复制相似问题