Carlos Rocha Posted May 23, 2018 at 10:29 AM Report #610647 Posted May 23, 2018 at 10:29 AM Tenho a seguinte função: public function excluir ($idPlano) { $string1 = "DELETE FROM planos WHERE idPlano = ".$idPlano; $string2 = "DELETE FROM fotos WHERE idPlano = ".$idPlano; $this->conexao->query($string1); $this->conexao->query($string2); } Gostaria de fazer algo como: public function excluir ($idPlano) { $string = "DELETE FROM planos WHERE idPlano = ".$idPlano." CONCAT"; $string .= "DELETE FROM fotos WHERE idPlano = ".$idPlano; return $this->conexao->query($string) ? 1 : 2; } Fazer de 2 pesquisas apenas 1. Tem como isso? Meio que um CONCAT...
M6 Posted May 23, 2018 at 11:15 AM Report #610649 Posted May 23, 2018 at 11:15 AM Vamos por partes. O concat é para concatenar strings, não é para aplicar a comandos. O comando delete não é uma pesquisa, não retorna dados, é comando de eliminação. Tens de fazer um comando de delete por cada tabela onde queres eliminar dados. 10 REM Generation 48K! 20 INPUT "URL:", A$ 30 IF A$(1 TO 4) = "HTTP" THEN PRINT "400 Bad Request": GOTO 50 40 PRINT "404 Not Found" 50 PRINT "./M6 @ Portugal a Programar."
Carlos Rocha Posted May 23, 2018 at 12:25 PM Author Report #610650 Posted May 23, 2018 at 12:25 PM public function excluir ($idPlano) { $string = "DELETE FROM planos,fotos USING planos,fotos WHERE planos.idPlano = fotos.idPlano AND planos.idPlano = ".$idPlano; return $this->conexao->query($string); } O return é só para saber se a exclusão foi ou não relaizada. No caso, no MySQL retorna 1 ou 2
M6 Posted May 23, 2018 at 05:36 PM Report #610657 Posted May 23, 2018 at 05:36 PM Antenção que o USING é uma extensão do MySQL, não é SQL standard. PS: o PostgreSQL também usa essa extensão. 10 REM Generation 48K! 20 INPUT "URL:", A$ 30 IF A$(1 TO 4) = "HTTP" THEN PRINT "400 Bad Request": GOTO 50 40 PRINT "404 Not Found" 50 PRINT "./M6 @ Portugal a Programar."
Carlos Rocha Posted May 23, 2018 at 06:10 PM Author Report #610660 Posted May 23, 2018 at 06:10 PM Eu sei. Mas além do site ser pequeno, não estou usando PDO.
HappyHippyHippo Posted May 23, 2018 at 09:33 PM Report #610668 Posted May 23, 2018 at 09:33 PM 3 hours ago, carcleo said: Eu sei. Mas além do site ser pequeno, não estou usando PDO. Ninguém falou de pdo... IRC : sim, é algo que ainda existe >> #p@p Portugol Plus
Carlos Rocha Posted May 23, 2018 at 09:46 PM Author Report #610669 Posted May 23, 2018 at 09:46 PM (edited) Eu falei de PDO por causa da intercambialidade de bancos distintos! Edited May 23, 2018 at 09:47 PM by carcleo
Rui Carlos Posted May 23, 2018 at 10:12 PM Report #610670 Posted May 23, 2018 at 10:12 PM Alguma razão para não usar simplesmente as queries separadas? É que o facto de estar tudo numa query não significa que fique mais rápido (a única possível vantagem que estou a ver é poupares um request à BD, mas também consegues juntar duas queries num request). Rui Carlos Gonçalves
Carlos Rocha Posted May 26, 2018 at 12:13 PM Author Report #610700 Posted May 26, 2018 at 12:13 PM Da forma abaixo, APENAS MYSQL, é possível também, se NÃO houver registros na segunda tabela, remove apenas os da primeira. No exemplo anterior, NÃO excluía de nenhuma tabela! Fica a dica: public function excluir ($idPlano) { $string = "DELETE planos, fotos FROM planos LEFT JOIN fotos ON planos.idPlano = fotos.idPlano WHERE planos.idPlano = ".$idPlano; return $this->conexao->query($string); }
HappyHippyHippo Posted May 26, 2018 at 03:00 PM Report #610705 Posted May 26, 2018 at 03:00 PM no meu tempo, em vez de martelar soluções improváveis e limitadas ao SGBD, era uso normal das FOREIGN KEY's assim como as acções referenciais destas como ON DELETE CASCADE ... mas novamente ... isso era no meu tempo ... 1 Report IRC : sim, é algo que ainda existe >> #p@p Portugol Plus
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now