Ir para conteúdo
Andinho Luiz

Erro com Procedure no MySQL

Recommended Posts

Boa tarde a todos,

 

Estou tentando criar uma Procedure no MySQL e tenho esta tabela "Cliente"

 

CREATE TABLE IF NOT EXISTS cliente (
    id_cliente INT(5) AUTO_INCREMENT PRIMARY KEY,
    tipo CHAR(1) NOT NULL,
    rSocialNome VARCHAR(20) NOT NULL,
    cnpjCPF VARCHAR(30) NOT NULL,
    ieRG VARCHAR(30),
    contato VARCHAR(50),
    email VARCHAR(30),
    site VARCHAR(30),
    dataCadastro DATE,
    usuario VARCHAR(30)
)ENGINE=MyISAM;

Tenho outra tabela que é a "Endereço"

CREATE TABLE IF NOT EXISTS `endereco` (
  `id_endereco` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
  `id_cliente` INT(11) NOT NULL,
  `logradouro` VARCHAR(20) NOT NULL ,
  `rua` VARCHAR(25) NOT NULL ,
  `numero` INT(11) NOT NULL ,
  `complemento` VARCHAR(40) ,
  `bairro` VARCHAR(40) NOT NULL ,
  `cidade` VARCHAR(40) NOT NULL ,
  `estado` VARCHAR(40) NOT NULL ,
  `cep` VARCHAR(9) NOT NULL ,
  PRIMARY KEY (`id_endereco`),
  constraint fk_endereco_cliente FOREIGN KEY (id_cliente) REFERENCES cliente (id_cliente)
) ENGINE=MyISAM

 

Para fazer o insert nas duas tabelas eu criei uma procedure, podem quando tento adicionar o MySQL da erro "ALERTA: Erro ao inserir na tabela de pessoas"

 

DELIMITER $$
CREATE DEFINER=`dotinfoc`@`localhost` PROCEDURE `cad_cliente`(
   IN c_tipo CHAR(1),
   IN c_rSocialNome VARCHAR(20),
   IN c_cnpjCPF VARCHAR(30),
   IN c_ieRG VARCHAR(30),
   IN c_contato VARCHAR(50),
   IN c_email VARCHAR(30),
   IN c_site VARCHAR(30),
   IN c_logradouro VARCHAR(20),
   IN c_rua VARCHAR(25),
   IN c_numero INT(11) ,
   IN c_complemento VARCHAR(40) ,
   IN c_bairro VARCHAR(40),
   IN c_cidade VARCHAR(40),
   IN c_estado VARCHAR(40),
   IN c_cep VARCHAR(9)
   )
BEGIN
   DECLARE msg VARCHAR(1000) DEFAULT "sem mensagem";
   DECLARE excecao SMALLINT DEFAULT 0;
   DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET excecao = 1;
   
   START TRANSACTION;
   INSERT INTO cliente (tipo, rSocialNome, cnpjCPF, ieRG, contato, email, site, dataCadastro, usuario)
   VALUES (c_tipo, c_rSocialNome, c_cnpjCPF, c_ieRG, c_contato, c_email, c_site);

   IF excecao = 1 THEN
      SET msg = "ALERTA: Erro ao inserir na tabela de pessoas";
      ROLLBACK;
   ELSE
      SELECT DISTINCT LAST_INSERT_ID() INTO @id_cliente FROM cliente;
      IF excecao = 1 THEN
         SET msg = "ALERTA: Erro ao buscar o ultimo ID inserido em clientes";
         ROLLBACK;
      ELSE 
         INSERT INTO endereco(id_cliente, logradouro, rua, numero, complemento, bairro, cidade, estado, cep) values(@id_cliente, c_logradouro, c_rua, c_numero, c_complemento, c_bairro, c_cidade, c_estado, c_cep);
         IF excecao = 1 THEN
            SET msg = "ALERTA: Erro ao inserir na tabela de Endereco";
            ROLLBACK;
         END IF;
      END IF;
   END IF;
   IF excecao <> 1 THEN
      COMMIT;
      SET msg = "ALERTA: Registro Incluido com sucesso";
   END IF;
   SELECT msg AS msg;   
END$$
DELIMITER ;

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por _marlon307
      Tenho uma tabela em meu banco de dados em que as colunas usuário e e-mail são do tipo unio. Como faço para verificar as duas colunas ao mesmo tempo e retorna um valor se encontrar um registro iguai.
    • Por leonardo021970
      Tem alguma maneira de capturar todas as urls do site?
      Testei pelo google mas ele retorna apenas alguns resultados pelo jeito que testei
    • Por _marlon307
      Estou fazendo um sistema simples de cadastro de usuário e preciso que o usuário e e-mail sejam únicos. Mas já configurei a minha tabela para que esses campos seja único. O problema e fazer a checagem para que não retorne erros, e sim redirecionar para pagina de cadastro.
       
      Código:
      <?php require_once 'config/connect.php'; $usermail = mysqli_real_escape_string($link, $_POST['email']); $username = mysqli_real_escape_string($link, $_POST['usuario']); $userpsw = mysqli_real_escape_string($link, $_POST['senha']); $sql = "SELECT usuario, email FROM `tb_usuarios` WHERE `usuario` = '$username', `email` = '$usermail'"; mysqli_query($link, $sql) or die(mysqli_error($link)); $linhas = mysqli_affected_rows($link); if($linhas > 0) { header("Location:cadastro"); } else { $sql = "INSERT INTO tb_usuarios (usuario, senha, email) VALUES ('$username','$userpsw','$usermail')"; mysqli_query($link,$sql) or die(mysqli_error($link)); $linhas = mysqli_affected_rows($link); if($linhas > 0) { header("Location:login"); } } ?>  
    • Por eduardom
      Olá.
       
      Tentarei exemplificar o problema.
       
      Tenho uma tabela com duas colunas e seus respectivos conteúdos:
      VALOR (int), DATA (datetime)
      1, 2018-12-10 20:50:00
      5, 2018-12-13 12:00:00
      4, 2018-12-13 13:00:00
      3, 2018-12-13 17:00:00
      2, 2018-12-15 06:00:00
      9, 2018-12-15 08:00:00
       
      Consulto as informações, por exemplo:
       
      SELECT * FROM TABELA WHERE DATA BETWEEN '2018-12-13 00:00:00' AND '2018-12-13 23:59:59'
       
      Está me trazendo somente os valores 4 e 5, o 3 ele não trás, porém todos estão dentro do período.
      Com isso, estou perdendo registros nas consultas.
      Buscando somente o valor 3 direto, (SELECT * FROM TABELA WHERE VALOR = 3), ele trás a informação normalmente.
      Adicionei e removi os índices, tentei otimizar a tabela, porém nada resolve.
      Não sei se envolve o tamanho da tabela, pois há 2.782.219 registros na mesma.
       
      Estrutura da tabela: InnoDB
      Formatação da tabela: utf8_general_ci
       
      Se alguém tiver uma luz...
    • Por nosredna
      Olá amigos, vocês poderiam me ajudar?
       
      Eu tenho a input abaixo em PHP, quando eu acabar de digitar algo eu desejo que ela selecione o texto digitado automaticamente. É possível? Como eu faria?
      Exemplo abaixo:

       
      Agradeço a ajuda. Valeuuuu.
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.