-- 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:28
-- 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: `projeto4rafael`
--

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

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitealunorafael` (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$$

DELIMITER ;

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

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

CREATE TABLE `aluno` (
  `idaluno` int(10) UNSIGNED NOT NULL,
  `nome` varchar(45) DEFAULT NULL,
  `contador` int(10) UNSIGNED DEFAULT 0,
  `ativo` tinyint(1) DEFAULT NULL,
  `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`, `nome`, `contador`, `ativo`, `limite`) VALUES
(1, 'rafael', 1, NULL, 1);

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

--
-- Estrutura para tabela `leiturarafael`
--

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

--
-- Despejando dados para a tabela `leiturarafael`
--

INSERT INTO `leiturarafael` (`idleiturarafael`, `aluno_idaluno`, `sensor_idsensor`, `mac_idmac`, `dataleitura`, `horaleitura`, `valor`) VALUES
(1, 1, 1, '38:2B:78:03:A5:7F', '2026-05-26', '17:08:43', NULL);

--
-- Acionadores `leiturarafael`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleiturarafael` AFTER DELETE ON `leiturarafael` 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 `tginsertleiturarafael` AFTER INSERT ON `leiturarafael` 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 `tglimitealunorafael` BEFORE INSERT ON `leiturarafael` FOR EACH ROW BEGIN
call verificalimitealunorafael(new.aluno_idaluno,@limite,@$contador);
IF @$ativo = 0 THEN SIGNAL SQLSTATE '45000'

SET MESSAGE_TEXT = 'Limite de gravações atingido';

END IF;



END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativorafael` BEFORE INSERT ON `leiturarafael` FOR EACH ROW BEGIN

CALL verificaativorafael(new.mac_idmac, @$ativo);

IF @$ativo = 0 THEN SIGNAL SQLSTATE '45000'

SET MESSAGE_TEXT = 'ESTA PLACA ESTA INATIVA';

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 NULL,
  `ativo` tinyint(1) DEFAULT NULL,
  `limite` int(10) UNSIGNED DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

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

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

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

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

CREATE TABLE `sensor` (
  `idsensor` int(10) UNSIGNED NOT NULL,
  `nome` varchar(45) DEFAULT NULL,
  `ativo` tinyint(1) DEFAULT NULL,
  `contador` int(10) UNSIGNED DEFAULT NULL,
  `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`, `ativo`, `contador`, `unidade`, `sigla`) VALUES
(1, 'LDR - Luz', NULL, NULL, 'luz', 'luz'),
(2, 'umidade de solo', NULL, NULL, 'resistenci', 'res');

--
-- Índices para tabelas despejadas
--

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

--
-- Índices de tabela `leiturarafael`
--
ALTER TABLE `leiturarafael`
  ADD PRIMARY KEY (`idleiturarafael`),
  ADD KEY `leituraaluno_FKIndex1` (`aluno_idaluno`),
  ADD KEY `leituraaluno_FKIndex2` (`mac_idmac`),
  ADD KEY `leituraaluno_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 `leiturarafael`
--
ALTER TABLE `leiturarafael`
  MODIFY `idleiturarafael` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=2;

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

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

--
-- Restrições para tabelas `leiturarafael`
--
ALTER TABLE `leiturarafael`
  ADD CONSTRAINT `leiturarafael_ibfk_1` FOREIGN KEY (`aluno_idaluno`) REFERENCES `aluno` (`idaluno`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leiturarafael_ibfk_2` FOREIGN KEY (`mac_idmac`) REFERENCES `mac` (`idmac`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leiturarafael_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 */;
