-- 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:41
-- 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 `verificaativomiguel` (IN `$idmac` VARCHAR(17), OUT `$ativo` TINYINT)   BEGIN
select ativo into $ativo
from mac where idmac=$idmac;
END$$

CREATE DEFINER=`root`@`localhost` PROCEDURE `verificalimitealunomiguel` (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 `verificalimitemacmiguel` (IN `$idmac` VARCHAR(17), OUT `$limitemac` INT, OUT `$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 `verificalimitesensormiguel` (IN `$idsensor` INT, OUT `$limitesensor` INT, OUT `$contadorsensor` INT)   begin

select limite into $limitesensor
from sensor
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,
  `nome` 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`, `nome`, `contador`, `limite`) VALUES
(1, 'Miguel Debarba', 1, 1);

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

--
-- Estrutura para tabela `leituramiguel`
--

CREATE TABLE `leituramiguel` (
  `idleituramiguel` 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 `leituramiguel`
--

INSERT INTO `leituramiguel` (`idleituramiguel`, `sensor_idsensor`, `mac_idmac`, `aluno_idaluno`, `dataleitura`, `horaleitura`, `valor`) VALUES
(4, 1, '38:2B:78:03:A5:7F', 1, '2026-05-26', '15:52:26', 135);

--
-- Acionadores `leituramiguel`
--
DELIMITER $$
CREATE TRIGGER `tgdeleteleituramiguel` AFTER DELETE ON `leituramiguel` 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 `tginsertleituramiguel` AFTER INSERT ON `leituramiguel` 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 `tgverificaativomiguel` BEFORE INSERT ON `leituramiguel` FOR EACH ROW BEGIN
CALL verificaativomiguel(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 `tgverificalimitealunomiguel` BEFORE INSERT ON `leituramiguel` FOR EACH ROW begin
CALL verificalimitealunomiguel(new.aluno_idaluno,@$limite,@$contador);
IF @$contador>=@$limite
THEN SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT='Limite de gravações atingido';
END IF;
end
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificalimitemacmiguel` BEFORE INSERT ON `leituramiguel` FOR EACH ROW begin
CALL verificalimitemacmiguel(new.mac_idmac,@$limite,@$contador);
IF @$contador>=@$limite
THEN SIGNAL SQLSTATE '45000'
SET MESSAGE_TEXT='Limite de gravações atingido';
END IF;
end
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificalimitesensormiguel` BEFORE INSERT ON `leituramiguel` FOR EACH ROW begin
CALL verificalimitesensormiguel(new.sensor_idsensor,@$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 1
) 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', 1, 200, 1),
('38:2B:78:03:A8:38', 'Gabi&Julia', 0, 200, 1),
('38:2B:78:03:A9:1C', 'Gabi&Julia', 0, 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,
  `contador` int(10) UNSIGNED DEFAULT 0,
  `limite` 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`, `contador`, `limite`, `unidade`, `sigla`) VALUES
(1, 'LDR - Sensor de Luz', 1, 200, 'Luz', 'luz'),
(2, 'Umidade do solo', 0, 200, 'Resistênci', 'res');

--
-- Índices para tabelas despejadas
--

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

--
-- Índices de tabela `leituramiguel`
--
ALTER TABLE `leituramiguel`
  ADD PRIMARY KEY (`idleituramiguel`),
  ADD KEY `leituramiguel_FKIndex1` (`aluno_idaluno`),
  ADD KEY `leituramiguel_FKIndex2` (`mac_idmac`),
  ADD KEY `leituramiguel_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 `leituramiguel`
--
ALTER TABLE `leituramiguel`
  MODIFY `idleituramiguel` int(10) UNSIGNED NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=6;

--
-- 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 `leituramiguel`
--
ALTER TABLE `leituramiguel`
  ADD CONSTRAINT `leituramiguel_ibfk_1` FOREIGN KEY (`aluno_idaluno`) REFERENCES `aluno` (`idaluno`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leituramiguel_ibfk_2` FOREIGN KEY (`mac_idmac`) REFERENCES `mac` (`idmac`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leituramiguel_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 */;
