我想在Teradata中创建一个在ID列中使用自动增量的表。代码有效,但我只是不知道为什么ID开始像100001,100002 ..等等,尽管声明start with 1 increment by 1
。
这是我的代码:
cur = connection.cursor()
create_stmt = """CREATE TABLE my_table,
NO FALLBACK,
NO BEFORE JOURNAL,
NO AFTER JOURNAL,
CHECKSUM = DEFAULT
(
id INTEGER NOT NULL GENERATED ALWAYS AS IDENTITY (START WITH 1 INCREMENT BY 1 MINVALUE 1 MAXVALUE 2147483647 NO CYCLE),
word VARCHAR(500) CHARACTER SET UNICODE,
country VARCHAR(50)
)
PRIMARY INDEX (id);"""
cur.execute(create_stmt)
insert_stmt = """INSERT INTO my_table (word,country) VALUES(?,?);"""
mydata=("hello","USA")
my_query=cur.execute(insert_stmt,my_data)
sel_all_stmt="sel * from my_table"
cur.execute(sel_all_stmt)
result = cur.fetchall()
我运行了insert语句几次,看看自动增量是什么样的,这就是我得到的:
[(100001, u'hello', u'USA'), (1, u'hello', u'USA'), (200001, u'hello', u'USA'), (400001, u'hello', u'USA'), (300001, u'hello', u'USA')]
知道为什么id这么久了?
答案 0 :(得分:1)
顺序处理违背了大规模并行DBMS的目的。
Teradata的IDENTITY
不是单个序列,它是并行的多个序列(顺便说一下,标准SQL兼容):每个解析引擎(PE)和每个AMP请求一系列值然后按顺序分配它们。因此,分配给PE / AMP 中的行的数字是顺序,但不是跨PE / AMP。