我必须执行插入查询,从另一个表中插入数据
条件:如果我有'codigoTipo'='A',则'numero'列应该是最后一个'numero'+ 1
e.g:
id | codigoTipo | numero
1 | A | 1
2 | O | 1
3 | A | 2
4 | A | 3
INSERT asociados (id, codigoTipo, numero, cp, direccion, email, fax, movil, nombre, nombreEncargado, telefono, website, idLocalidad)
SELECT p.id, 'A', (MAX(asociados.numero)+1 ) , p.postalcode, p.address, p.mail, p.fax, p.movil, p.name, p.charge_person, p.phone, p.website, p.locality
FROM
partners as p, asociados
我该怎么做?我的代码有错误。
编辑:codigoTipo和numero,是一个复合PK,这就是为什么我需要列'numero'中的自动增量数字
答案 0 :(得分:3)
您可以使用子查询来获取最大值。
INSERT asociados (id, codigoTipo, numero, cp, direccion,
email, fax, movil, nombre, nombreEncargado, telefono, website, idLocalidad)
SELECT p.id, 'A', dm.MaxNum + 1 , p.postalcode, p.address,
p.mail, p.fax, p.movil, p.name, p.charge_person,
p.phone, p.website, p.locality
FROM partners as p, (SELECT MAX(numero) MaxNum FROM asociados) dm
更新:如果要增加插入的行,请使用以下查询:
INSERT asociados (id, codigoTipo, numero, cp, direccion,
email, fax, movil, nombre, nombreEncargado, telefono, website, idLocalidad)
SELECT p.id, 'A', @r := @r + 1 , p.postalcode, p.address,
p.mail, p.fax, p.movil, p.name, p.charge_person,
p.phone, p.website, p.locality
FROM partners as p, (SELECT @r := MAX(numero) MaxNum FROM asociados) dm