-- phpMyAdmin SQL Dump
-- version 5.2.1
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Tempo de geração: 13/03/2026 às 17:32
-- Versão do servidor: 10.4.32-MariaDB
-- Versão do PHP: 8.0.30

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: `projeto1`
--

DELIMITER $$
--
-- Procedimentos
--
CREATE DEFINER=`root`@`localhost` PROCEDURE `verificaativonadal` (IN `$idmacnadal` VARCHAR(17), OUT `$ativo` BOOLEAN)   BEGIN
SELECT ativo into $ativo from macnadal
WHERE idmacnadal = $idmacnadal; 


END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitenadal` (IN `$idmacnadal` VARCHAR(17), OUT `$limite` INT, OUT `$contador` INT)   BEGIN
SELECT  limite into  $limite
from macnadal 
where idmacnadal =  $idmacnadal; 

select  contador into $contador
from macnadal 
where idmacnadal =  $idmacnadal; 
END$$

DELIMITER ;

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

--
-- Estrutura para tabela `leituranadal`
--

CREATE TABLE `leituranadal` (
  `idleituranadal` int(10) UNSIGNED NOT NULL,
  `macnadal_idmacnadal` varchar(17) NOT NULL,
  `dataleitura` date DEFAULT NULL,
  `horaleitura` time DEFAULT NULL,
  `unidade` double DEFAULT NULL,
  `temperatura` double DEFAULT NULL,
  `luz` int(10) UNSIGNED DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Despejando dados para a tabela `leituranadal`
--

INSERT INTO `leituranadal` (`idleituranadal`, `macnadal_idmacnadal`, `dataleitura`, `horaleitura`, `unidade`, `temperatura`, `luz`) VALUES
(3, 'aa', '2026-02-13', '15:07:00', 28, 29.7, 110);

--
-- Acionadores `leituranadal`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleituranadal` AFTER DELETE ON `leituranadal` FOR EACH ROW BEGIN
UPDATE macnadal
SET contador=contador-1 
WHERE idmacnadal= old.macnadal_idmacnadal;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgsalvaleituranadal` AFTER INSERT ON `leituranadal` FOR EACH ROW BEGIN 
UPDATE macnadal
SET contador=contador +1 
WHERE idmacnadal = new.macnadal_idmacnadal;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativonadal` BEFORE INSERT ON `leituranadal` FOR EACH ROW BEGIN 
CALL verificaativonadal(new.macnadal_idmacnadal, @$ativo);
if @$ativo=0 
then SIGNAL SQLSTATE '45000' SET
MESSAGE_TEXT = 'Placa inativa';
end if;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificalimitenadal` BEFORE INSERT ON `leituranadal` FOR EACH ROW BEGIN 
CALL
verificalimitenadal(new.macnadal_idmacnadal,@$limite, @$contador);
IF @$contador>@$limite
THEN SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT='Limite de gravações atingido';
ENd IF;

END
$$
DELIMITER ;

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

--
-- Estrutura para tabela `macnadal`
--

CREATE TABLE `macnadal` (
  `idmacnadal` varchar(17) NOT NULL,
  `nome` varchar(50) DEFAULT NULL,
  `contador` int(10) UNSIGNED DEFAULT 0,
  `limite` int(10) UNSIGNED DEFAULT NULL,
  `ativo` tinyint(1) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Despejando dados para a tabela `macnadal`
--

INSERT INTO `macnadal` (`idmacnadal`, `nome`, `contador`, `limite`, `ativo`) VALUES
('aa', 'Placa teste', 1, 50, 0);

--
-- Índices para tabelas despejadas
--

--
-- Índices de tabela `leituranadal`
--
ALTER TABLE `leituranadal`
  ADD PRIMARY KEY (`idleituranadal`),
  ADD KEY `leituranadal_FKIndex1` (`macnadal_idmacnadal`);

--
-- Índices de tabela `macnadal`
--
ALTER TABLE `macnadal`
  ADD PRIMARY KEY (`idmacnadal`);

--
-- AUTO_INCREMENT para tabelas despejadas
--

--
-- AUTO_INCREMENT de tabela `leituranadal`
--
ALTER TABLE `leituranadal`
  MODIFY `idleituranadal` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=4;

--
-- Restrições para tabelas despejadas
--

--
-- Restrições para tabelas `leituranadal`
--
ALTER TABLE `leituranadal`
  ADD CONSTRAINT `leituranadal_ibfk_1` FOREIGN KEY (`macnadal_idmacnadal`) REFERENCES `macnadal` (`idmacnadal`) 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 */;
