-- 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:11
-- 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: `db_jollan`
--

DELIMITER $$
--
-- Procedimentos
--
CREATE DEFINER=`root`@`localhost` PROCEDURE `verficalimitejollan` (IN `$idmac` VARCHAR(17), OUT `$limite` INT, OUT `$contador` INT)   BEGIN

SELECT limite INTO $limite 
FROM macjollan
WHERE idmacjollan=$idmac;

SELECT contador INTO $contador 
FROM macjollan
WHERE idmacjollan=$idmac;

END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificaativojollan` (IN `$idmac` VARCHAR(17), OUT `$ativo` BOOLEAN)   BEGIN

SELECT ativo into $ativo from macjollan
WHERE idmacjollan=$idmac;

END$$

DELIMITER ;

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

--
-- Estrutura da tabela `leiturajollan`
--

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

--
-- Extraindo dados da tabela `leiturajollan`
--

INSERT INTO `leiturajollan` (`idleiturajollan`, `macjollan_idmacjollan`, `dataleitura`, `horaleitura`, `umidade`, `temperatura`, `luz`) VALUES
(2, 'aa', '2026-02-20', '14:19:00', 75, 22, 658);

--
-- Acionadores `leiturajollan`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleiturajollan` AFTER DELETE ON `leiturajollan` FOR EACH ROW BEGIN
UPDATE macjollan
SET contador=contador-1
WHERE idmacjollan=old.macjollan_idmacjollan;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tginsertleiturajollan` AFTER INSERT ON `leiturajollan` FOR EACH ROW BEGIN
UPDATE macjollan
SET contador=contador+1
WHERE idmacjollan=new.macjollan_idmacjollan;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativojollan` BEFORE INSERT ON `leiturajollan` FOR EACH ROW BEGIN
CALL verificaativojollan(new.macjollan_idmacjollan,@$ativo);
if @$ativo=0
then SIGNAL SQLSTATE '45000' 
SET MESSAGE_TEXT = 'Placa inativa';
end if;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificalimitejollan` BEFORE INSERT ON `leiturajollan` FOR EACH ROW BEGIN

CALL verificalimitejollan(new.macjollan_idmacjollan,@$contador,@$limite);
if @contador>@limite 
THEN SIGNAL SQLSTATE '45000' SET
MESSAGE_TEXT = 'Limite de gravações atinigido';
end if;

END
$$
DELIMITER ;

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

--
-- Estrutura da tabela `macjollan`
--

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

--
-- Extraindo dados da tabela `macjollan`
--

INSERT INTO `macjollan` (`idmacjollan`, `nome`, `contador`, `limite`, `ativo`) VALUES
('aa', 'placa teste', 1, 50, NULL);

--
-- Índices para tabelas despejadas
--

--
-- Índices para tabela `leiturajollan`
--
ALTER TABLE `leiturajollan`
  ADD PRIMARY KEY (`idleiturajollan`),
  ADD KEY `leiturajollan_FKIndex1` (`macjollan_idmacjollan`);

--
-- Índices para tabela `macjollan`
--
ALTER TABLE `macjollan`
  ADD PRIMARY KEY (`idmacjollan`);

--
-- AUTO_INCREMENT de tabelas despejadas
--

--
-- AUTO_INCREMENT de tabela `leiturajollan`
--
ALTER TABLE `leiturajollan`
  MODIFY `idleiturajollan` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=3;

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

--
-- Limitadores para a tabela `leiturajollan`
--
ALTER TABLE `leiturajollan`
  ADD CONSTRAINT `leiturajollan_ibfk_1` FOREIGN KEY (`macjollan_idmacjollan`) REFERENCES `macjollan` (`idmacjollan`) 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 */;
