-- phpMyAdmin SQL Dump
-- version 5.2.0
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Tempo de geração: 20-Fev-2026 às 19:31
-- Versão do servidor: 10.4.24-MariaDB
-- versão do PHP: 8.1.6

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
START TRANSACTION;
SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8mb4 */;

--
-- Banco de dados: `bancoleitura`
--

DELIMITER $$
--
-- Procedimentos
--
CREATE DEFINER=`root`@`localhost` PROCEDURE `verificaativobrujo` (IN `$idmac` VARCHAR(17), OUT `$ativo` BOOLEAN)   BEGIN
select ativo into $ativo from macbrujo
WHERE	idmacbrujo=$idmac;

END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitebrujo` (IN `$idmac` VARCHAR(17), OUT `$limite` INT, OUT `$contador` INT)   BEGIN
select limite into $limite
FROM	macbrujo
WHERE	idmacbrujo=$idmac;
select contador into $contador
FROM	macbrujo
WHERE	idmacbrujo=$idmac;
END$$

DELIMITER ;

-- --------------------------------------------------------

--
-- Estrutura da tabela `leiturabrujo`
--

CREATE TABLE `leiturabrujo` (
  `idleiturabrujo` int(10) UNSIGNED NOT NULL,
  `macbrujo_idmacbrujo` varchar(17) NOT NULL,
  `dataleitura` date DEFAULT NULL,
  `horaleitura` time DEFAULT NULL,
  `umidade` double DEFAULT NULL,
  `temperatura` double DEFAULT NULL,
  `luz` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

--
-- Acionadores `leiturabrujo`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleiturabrujo` AFTER DELETE ON `leiturabrujo` FOR EACH ROW BEGIN
UPDATE	macbrujo
SET		contador=contador-1
WHERE	idmacbrujo=old.macbrujo_idmacbrujo;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tginsertleiturabrujo` AFTER INSERT ON `leiturabrujo` FOR EACH ROW BEGIN
UPDATE 	macbrujo
SET		contador=contador+1
WHERE	idmacbrujo=new.macbrujo_idmacbrujo;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativobrujo` BEFORE INSERT ON `leiturabrujo` FOR EACH ROW BEGIN
CALL verificaativobrujo(new.macbrujo_idmacbrujo,@$ativo);
if @$ativo=0 then SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT= 'Esta placa está Inativa';
end if;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificalimitebrujo` BEFORE INSERT ON `leiturabrujo` FOR EACH ROW BEGIN
CALL verificalimitebrujo(new.macbrujo_idmacbrujo,@$contador,@$limite);
IF @$contador>@$limite
THEN SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT='Limite de gravações atingido';
END IF;

END
$$
DELIMITER ;

-- --------------------------------------------------------

--
-- Estrutura da tabela `macbrujo`
--

CREATE TABLE `macbrujo` (
  `idmacbrujo` varchar(17) NOT NULL,
  `nome` varchar(35) DEFAULT NULL,
  `contador` int(10) UNSIGNED DEFAULT 0,
  `ativo` tinyint(1) DEFAULT NULL,
  `limite` int(10) UNSIGNED DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

--
-- Extraindo dados da tabela `macbrujo`
--

INSERT INTO `macbrujo` (`idmacbrujo`, `nome`, `contador`, `ativo`, `limite`) VALUES
('aa', 'Placa teste', 0, 1, 1);

--
-- Índices para tabelas despejadas
--

--
-- Índices para tabela `leiturabrujo`
--
ALTER TABLE `leiturabrujo`
  ADD PRIMARY KEY (`idleiturabrujo`),
  ADD KEY `leiturabrujo_FKIndex1` (`macbrujo_idmacbrujo`);

--
-- Índices para tabela `macbrujo`
--
ALTER TABLE `macbrujo`
  ADD PRIMARY KEY (`idmacbrujo`);

--
-- AUTO_INCREMENT de tabelas despejadas
--

--
-- AUTO_INCREMENT de tabela `leiturabrujo`
--
ALTER TABLE `leiturabrujo`
  MODIFY `idleiturabrujo` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=9;

--
-- Restrições para despejos de tabelas
--

--
-- Limitadores para a tabela `leiturabrujo`
--
ALTER TABLE `leiturabrujo`
  ADD CONSTRAINT `leiturabrujo_ibfk_1` FOREIGN KEY (`macbrujo_idmacbrujo`) REFERENCES `macbrujo` (`idmacbrujo`) ON DELETE NO ACTION ON UPDATE NO ACTION;
COMMIT;

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;