我正在尝试使用SQLAlchemy的ORM层(通过Flask-SQLAlchemy == 2.0),我需要支持(摄取和更新)使用Strings(Varchars)创建的一些表作为主键。顺便说一下,我在开发过程中使用SQLite作为后端,但生产数据存储区将是Oracle。
以下代码应该创建模型,然后test_setup函数应该初始化一些测试数据,但我似乎只能用Integers创建表作为主键。
# MODEL
class MAG_BAG(db.Model):
"""An entity used for the test_setup"""
__tablename__ = 'DS_MAG_BAG'
BAG_ABBREV = db.Column(db.String(18), primary_key=True)
BAG_NM = db.Column(db.String(128))
MAGIC_POWER_DESCR = db.Column(db.String(128))
SORT_ORD = db.Column(db.Integer)
def __repr__(self):
return '<MAG_BAG {0}>'.format(self.BAG_NM)
def test_setup():
"""Only used during development or testing as a convenience."""
db.create_all() # why this no make DS_MAG_BAG?
#
if User.query.filter_by(login_id='felix').first() is None:
u = User.register('felix', 'cat')
e = Entity.register('Magic Bag', 'DS_MAG_BAG', u.id)
# u and e populate tables just fine
# but section below does nothing
for b in [('FSH','Magic Fish Sack'),('CANBAG','Canoe Bag'),('ESC', 'Escalator Bag')]:
print(a_bag)
a_bag = MAG_BAG(BAG_ABBREV=b[0], BAG_NM=b[1])
db.session.add(a_bag)
db.session.commit()
是否可以创建PK数据类型不是数字类型的表?
答案 0 :(得分:-2)
Is it possible to apply primary key on the text fields in android database
Strings as Primary Keys in SQL Database
我认为sqlite不适合开发数据库。 很多问题都会发生。