-- phpMyAdmin SQL Dump
-- version 5.2.0
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Tempo de geração: 06-Mar-2026 às 19:14
-- 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: `tiagorenso`
--

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

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitetiagoerenso` (IN `$idmac` VARCHAR(17), OUT `$limite` INT, OUT `$contador` INT)   BEGIN
select limite into $limite
FROM mactiagoerenso
WHERE idmactiagorenso=$idmac;
SELECT contador into $contador
FROM mactiagoerenso
WHERE idmactiagoerenso=$idmac;

END$$

DELIMITER ;

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

--
-- Estrutura da tabela `leituratiagoerenso`
--

CREATE TABLE `leituratiagoerenso` (
  `idleituratiagoerenso` int(10) UNSIGNED NOT NULL,
  `mactiagoerenso_idmactiagoerenso` 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 `leituratiagoerenso`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleituratiagoerenso` AFTER DELETE ON `leituratiagoerenso` FOR EACH ROW BEGIN
UPDATE	mactiagoerenso
SET		contador=contador-1
WHERE	idmactiagoerenso=old.mactiagoerenso_idmactiagoerenso;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tginsertleituratiagoerenso` AFTER INSERT ON `leituratiagoerenso` FOR EACH ROW BEGIN
UPDATE 	mactiagoerenso
SET		contador=contador+1
WHERE	idmactiagoerenso=new.mactiagoerenso_idmactiagoerenso;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativotiagoerenso` BEFORE INSERT ON `leituratiagoerenso` FOR EACH ROW BEGIN
CALL
verificaativotiagoerenso(new.mactiagoerenso_idmactiagoerenso,@$ativo);
if @$ativo=0 then SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT = 'Esta placa está inativa';
end if;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificalimitetiagoerenso` BEFORE INSERT ON `leituratiagoerenso` FOR EACH ROW BEGIN
CALL verificalimitetiagoerenso(new.mactiagoerenso_idmactiagoerenso,@$limite,@$contador);
if @contador > @limite
THEN SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT = 'Limite de gravações atingido';
end if;

END
$$
DELIMITER ;

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

--
-- Estrutura da tabela `mactiagoerenso`
--

CREATE TABLE `mactiagoerenso` (
  `idmactiagoerenso` 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 `mactiagoerenso`
--

INSERT INTO `mactiagoerenso` (`idmactiagoerenso`, `nome`, `contador`, `ativo`, `limite`) VALUES
('aa', 'Placa teste', 0, NULL, NULL);

--
-- Índices para tabelas despejadas
--

--
-- Índices para tabela `leituratiagoerenso`
--
ALTER TABLE `leituratiagoerenso`
  ADD PRIMARY KEY (`idleituratiagoerenso`),
  ADD KEY `leituratiagoerenso_FKIndex1` (`mactiagoerenso_idmactiagoerenso`);

--
-- Índices para tabela `mactiagoerenso`
--
ALTER TABLE `mactiagoerenso`
  ADD PRIMARY KEY (`idmactiagoerenso`);

--
-- AUTO_INCREMENT de tabelas despejadas
--

--
-- AUTO_INCREMENT de tabela `leituratiagoerenso`
--
ALTER TABLE `leituratiagoerenso`
  MODIFY `idleituratiagoerenso` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=2;

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

--
-- Limitadores para a tabela `leituratiagoerenso`
--
ALTER TABLE `leituratiagoerenso`
  ADD CONSTRAINT `leituratiagoerenso_ibfk_1` FOREIGN KEY (`mactiagoerenso_idmactiagoerenso`) REFERENCES `mactiagoerenso` (`idmactiagoerenso`) 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 */;
