-- phpMyAdmin SQL Dump
-- version 5.2.1
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Tempo de geração: 26/05/2026 às 22:33
-- Versão do servidor: 10.4.32-MariaDB
-- Versão do PHP: 8.2.12

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

DELIMITER $$
--
-- Procedimentos
--
CREATE DEFINER=`root`@`localhost` PROCEDURE `verificaativothyago` (IN `$idmac` VARCHAR(17), OUT `$ativo` TINYINT)   BEGIN
SELECT ativo into $ativo
FROM mac WHERE idmac=$idmac;
END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitealunothyago` (IN `$idaluno` INT, OUT `$limitealuno` INT, OUT `$contadoraluno` INT)   BEGIN

SELECT limite INTO $limitealuno
FROM aluno
WHERE idaluno=$idaluno;
SELECT contador INTO $contadoraluno
FROM aluno
WHERE idaluno=$idaluno;

END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitemacthyago` (IN `$idmac` INT, OUT `$limitemac` INT, IN `$contadormac` INT)   BEGIN
SELECT limite INTO $limitemac
FROM mac
WHERE idmac=$idmac;
SELECT contador INTO $contadormac
FROM mac
WHERE idmac=$idmac;
END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitesensorthyago` (IN `$idsensor` INT, OUT `$limitesensor` INT, IN `$contadorsensor` INT)   BEGIN
SELECT limite INTO $limitesensor
FROM aluno
WHERE idsensor=$idsensor;
SELECT contador INTO $contadorsensor
FROM sensor
WHERE idsensor=$idsensor;
END$$

DELIMITER ;

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

--
-- Estrutura para tabela `aluno`
--

CREATE TABLE `aluno` (
  `idaluno` int(10) UNSIGNED NOT NULL,
  `aluno` varchar(45) DEFAULT NULL,
  `contador` int(10) UNSIGNED DEFAULT 0,
  `limite` int(10) UNSIGNED DEFAULT 200
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Despejando dados para a tabela `aluno`
--

INSERT INTO `aluno` (`idaluno`, `aluno`, `contador`, `limite`) VALUES
(1, 'Thyago', 2, 200);

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

--
-- Estrutura para tabela `leiturathyago`
--

CREATE TABLE `leiturathyago` (
  `idleiturathyago` int(10) UNSIGNED NOT NULL,
  `sensor_idsensor` int(10) UNSIGNED NOT NULL,
  `mac_idmac` varchar(17) NOT NULL,
  `aluno_idaluno` int(10) UNSIGNED NOT NULL,
  `dataleitura` date DEFAULT NULL,
  `horaleitura` time DEFAULT NULL,
  `valor` double DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Despejando dados para a tabela `leiturathyago`
--

INSERT INTO `leiturathyago` (`idleiturathyago`, `sensor_idsensor`, `mac_idmac`, `aluno_idaluno`, `dataleitura`, `horaleitura`, `valor`) VALUES
(2, 2, '38:2B:78:03:A8:38', 1, '2026-05-26', '16:27:00', 696712),
(3, 4, '38:2B:78:03:A9:1C', 1, '2026-05-26', '16:33:00', 467);

--
-- Acionadores `leiturathyago`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleiturathyago` AFTER DELETE ON `leiturathyago` FOR EACH ROW BEGIN

UPDATE aluno
SET contador=contador-1
WHERE idaluno=old.aluno_idaluno;

UPDATE mac
SET contador=contador-1
WHERE idmac=old.mac_idmac;

UPDATE sensor
SET contador=contador-1
WHERE idsensor=old.sensor_idsensor;

END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tginsertleiturathyago` AFTER INSERT ON `leiturathyago` FOR EACH ROW BEGIN

UPDATE aluno
SET contador=contador+1
WHERE idaluno=new.aluno_idaluno;

UPDATE mac
SET contador=contador+1
WHERE idmac=new.mac_idmac;

UPDATE sensor
SET contador=contador+1
WHERE idsensor=new.sensor_idsensor;

END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativothyago` BEFORE INSERT ON `leiturathyago` FOR EACH ROW BEGIN
CALL 
verificaativothyago(new.mac_idmac, @$ativo);
IF @$ativo=0 then SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT= 'Esta placa está Inativa';
end if;

END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `verificalimitealunothyago` BEFORE INSERT ON `leiturathyago` FOR EACH ROW begin
CALL
verificalimitealunothyago(new.aluno_idaluno, @$limite, @$contador);
IF @$contador>=@$limite
THEN SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT='Limite de gravações atingido';
END IF;
end
$$
DELIMITER ;

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

--
-- Estrutura para tabela `mac`
--

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

--
-- Despejando dados para a tabela `mac`
--

INSERT INTO `mac` (`idmac`, `nome`, `contador`, `limite`, `ativo`) VALUES
('01:02:03:04', 'Mac teste', 0, 200, NULL),
('38:2B:78:03:A5:7F', 'Murilo&Luiz', 0, 200, 1),
('38:2B:78:03:A8:38', 'Gabi&Julia', 0, 200, 1),
('38:2B:78:03:A9:1C', 'Gabi&Julia', 1, 200, 1),
('60:01:94:09:6B:B4', 'EspOled', 0, 200, 1),
('84:F3:EB:32:26:1D', 'Bruno&JoÃ£o', 0, 200, 1),
(':50:E3:05:19:BA', 'Mac aula do Miguel', 0, 200, 1),
('A8:48:FA:FF:AD:CD', 'Karol&Pedro', 0, 200, 1),
('B8:48:FA:FF:AD:CD', 'Mac aula do Miguel', 0, 200, 1),
('BC:DD:C2:55:C3:E8', 'Jollan', 0, 200, 1),
('BC:DD:C2:56:8B:1D', 'Karol&Pedro', 0, 200, 1),
('BC:ED:C2:56:8B:1D', 'Ana&Helo', 0, 200, 1),
('CC:50:E3:05:19:BA', 'JoÃ£o&Allan', 0, 200, 1),
('CC:50:E3:3B:FE:E9', 'Helo&Mar', 0, 200, 1),
('CC:50:E3:3C:25:ED', 'Ceci&Mi', 0, 200, 1),
('DC:4F:22:0D:61:3B', 'Helo&Ana', 0, 200, 1),
('E8:DB:84:98:B5:DA', 'Felipe&Artur', 0, 200, 1);

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

--
-- Estrutura para tabela `sensor`
--

CREATE TABLE `sensor` (
  `idsensor` int(10) UNSIGNED NOT NULL,
  `nome` varchar(45) DEFAULT NULL,
  `limite` int(10) UNSIGNED DEFAULT 0,
  `contador` int(10) UNSIGNED DEFAULT 200,
  `unidade` varchar(10) DEFAULT NULL,
  `sigla` varchar(3) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Despejando dados para a tabela `sensor`
--

INSERT INTO `sensor` (`idsensor`, `nome`, `limite`, `contador`, `unidade`, `sigla`) VALUES
(2, 'LDR - Sensor de Luz', 200, 1, 'LUZ', 'LUZ'),
(4, 'Sensor de Umidade', 200, 1, 'Resistênci', 'res');

--
-- Índices para tabelas despejadas
--

--
-- Índices de tabela `aluno`
--
ALTER TABLE `aluno`
  ADD PRIMARY KEY (`idaluno`);

--
-- Índices de tabela `leiturathyago`
--
ALTER TABLE `leiturathyago`
  ADD PRIMARY KEY (`idleiturathyago`),
  ADD KEY `leiturathyago_FKIndex1` (`aluno_idaluno`),
  ADD KEY `leiturathyago_FKIndex2` (`mac_idmac`),
  ADD KEY `leiturathyago_FKIndex3` (`sensor_idsensor`);

--
-- Índices de tabela `mac`
--
ALTER TABLE `mac`
  ADD PRIMARY KEY (`idmac`);

--
-- Índices de tabela `sensor`
--
ALTER TABLE `sensor`
  ADD PRIMARY KEY (`idsensor`);

--
-- AUTO_INCREMENT para tabelas despejadas
--

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

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

--
-- AUTO_INCREMENT de tabela `sensor`
--
ALTER TABLE `sensor`
  MODIFY `idsensor` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;

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

--
-- Restrições para tabelas `leiturathyago`
--
ALTER TABLE `leiturathyago`
  ADD CONSTRAINT `leiturathyago_ibfk_1` FOREIGN KEY (`aluno_idaluno`) REFERENCES `aluno` (`idaluno`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leiturathyago_ibfk_2` FOREIGN KEY (`mac_idmac`) REFERENCES `mac` (`idmac`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leiturathyago_ibfk_3` FOREIGN KEY (`sensor_idsensor`) REFERENCES `sensor` (`idsensor`) 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 */;
