Python Teradata自动增量从一个6位数而不是1开始?

时间:2016-04-18 23:35:38

标签: python mysql teradata

我想在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这么久了?

1 个答案:

答案 0 :(得分:1)

顺序处理违背了大规模并行DBMS的目的。

Teradata的IDENTITY不是单个序列,它是并行的多个序列(顺便说一下,标准SQL兼容):每个解析引擎(PE)和每个AMP请求一系列值然后按顺序分配它们。因此,分配给PE / AMP 中的行的数字是顺序,但不是跨PE / AMP。

More details can be found in the manuals.