由于FK引用,我在INSERT上遇到了问题。过程如下:
Cuentas
和Cuentas_Con_RowNumber
tempDB
。我必须这样做,因为在巨大的数据库中有许多记录具有相同的Cuenta_Nro
具有不同的事务,我只需要一个。tempDB
所有列中选择RowNumber
,然后将其插入Cuentas
表。tempDB
Pais
(国家/地区)列不是引用Paises
(国家/地区)表格的FK,而是原始表格({{1}因此,它会崩溃。代码:
Cuentas
错误消息是:
InstrucciónINSERTen conflicto conlalimitciónFOREIGNKEY“FK__Cuentas__Cuenta___24B338F0”。 El Conflicto ha aparecido en la base de datos“GD1C2015”,tabla“dbo.Paises”,“Pais_Id”栏。
答案 0 :(得分:0)
问题是因为Maestro.Cuenta_Pais_Codigo
列是从gd_esquema.Maestra
表中提取的,而Cuenta_PaisOrigen
表又在目标表中作为Cuentas
并且定义了外键。
在Pais_Id
表中没有匹配的dbo.Paises
记录的插入INSERT INTO #Cuentas_Con_RowNumer
SELECT *
FROM (SELECT
...
FROM gd_esquema.Maestra Maestro
inner join dbo.Clientes on
Clientes.Cliente_Apellido = Maestro.Cli_Apellido AND
Clientes.Cliente_Nombre = Maestro.Cli_Nombre
inner join Paises P on Maestro.Cuenta_Pais_Codigo = P.Pais_Id
) AS a
WHERE a.RowNumber = '1'
表中会选择一些记录。
您可以按如下方式添加内部联接,并将结果检查为:
class Post(db.Model):
__tablename__ = 'posts'
id = db.Column(db.Integer, primary_key=True)
title = db.Column(db.String(80))
body = db.Column(db.Text)
timestamp = db.Column(db.DateTime, index=True, default=datetime.utcnow)
author_id = db.Column(db.Integer, db.ForeignKey('users.id'))
body_html = db.Column(db.Text)
comments = db.relationship('Comment', backref='post', lazy='dynamic')
category_id = db.Column(db.Integer, db.ForeignKey('categories.id'))
category = db.relationship('Category',
backref=db.backref('posts', lazy='dynamic'))
@staticmethod
def on_changed_body(target, value, oldvalue, initiator):
allowed_tags = ['a', 'abbr', 'acronym', 'b', 'blackquote', 'code', 'em', 'i', 'li', 'ol', 'pre', 'strong',
'ul', 'h1', 'h2', 'h3', 'p']
target.body_html = bleach.linkify(bleach.clean(
markdown(value, output_form='html'),
tags=allowed_tags, strip=True))
db.event.listen(Post.body, 'set', Post.on_changed_body)
class Category(db.Model):
__tablename__ = 'categories'
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(50))
def __repr__(self):
return '<Category {}>'.format(self.name)