-- phpMyAdmin SQL Dump
-- version 5.2.1
-- https://www.phpmyadmin.net/
--
-- Host: 127.0.0.1
-- Tempo de geração: 12/05/2026 às 22:21
-- 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: `provabavaresco`
--

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

END$$

DELIMITER ;

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

--
-- Estrutura para tabela `leiturabavaresco`
--

CREATE TABLE `leiturabavaresco` (
  `idleiturabavaresco` int(10) UNSIGNED NOT NULL,
  `sensorbavaresco_idsensorbavaresco` int(10) UNSIGNED NOT NULL,
  `macbavaresco_idmacbavaresco` varchar(17) NOT NULL,
  `dataleitura` date DEFAULT NULL,
  `horaleitura` time DEFAULT NULL,
  `valor` double DEFAULT NULL,
  `tamanho` double DEFAULT NULL,
  `capacidade` double DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Acionadores `leiturabavaresco`
--
DELIMITER $$
CREATE TRIGGER `tgdeletebavaresco` AFTER DELETE ON `leiturabavaresco` FOR EACH ROW BEGIN
update macbavaresco
set contador = contador - 1
where idmacbavaresco = OLD.macbavaresco_idmacbavaresco;
update sensorbavaresco
set contador = contador - 1
where idsensorbavaresco = OLD.sensorbavaresco_idsensorbavaresco;
END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tginsertbavaresco` AFTER INSERT ON `leiturabavaresco` FOR EACH ROW BEGIN
UPDATE macbavaresco
SET contador = contador + 1
WHERE idmacbavaresco = new.macbavaresco_idmacbavaresco;
UPDATE sensorbavaresco
SET contador = contador + 1
WHERE idsensorbavaresco = new.sensorbavaresco_idsensorbavaresco;


END
$$
DELIMITER ;
DELIMITER $$
CREATE TRIGGER `tgverificaativobavaresco` BEFORE INSERT ON `leiturabavaresco` FOR EACH ROW BEGIN
CALL verificaativobavaresco(new.macbavaresco_idmacbavaresco,@$ativo);
if @$ativo=0
then SIGNAL SQLSTATE '45000' SET
MESSAGE_TEXT = 'Inativa';
end if;
END
$$
DELIMITER ;

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

--
-- Estrutura para tabela `macbavaresco`
--

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

--
-- Despejando dados para a tabela `macbavaresco`
--

INSERT INTO `macbavaresco` (`idmacbavaresco`, `nome`, `ativo`, `contador`, `limite`) VALUES
('01', 'placateste', 1, 0, 100);

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

--
-- Estrutura para tabela `sensorbavaresco`
--

CREATE TABLE `sensorbavaresco` (
  `idsensorbavaresco` int(10) UNSIGNED NOT NULL,
  `nome` varchar(45) DEFAULT NULL,
  `contador` int(10) UNSIGNED DEFAULT 0
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

--
-- Despejando dados para a tabela `sensorbavaresco`
--

INSERT INTO `sensorbavaresco` (`idsensorbavaresco`, `nome`, `contador`) VALUES
(1, 'sensorteste', 0);

--
-- Índices para tabelas despejadas
--

--
-- Índices de tabela `leiturabavaresco`
--
ALTER TABLE `leiturabavaresco`
  ADD PRIMARY KEY (`idleiturabavaresco`),
  ADD KEY `leiturabavaresco_FKIndex1` (`macbavaresco_idmacbavaresco`),
  ADD KEY `leiturabavaresco_FKIndex2` (`sensorbavaresco_idsensorbavaresco`);

--
-- Índices de tabela `macbavaresco`
--
ALTER TABLE `macbavaresco`
  ADD PRIMARY KEY (`idmacbavaresco`);

--
-- Índices de tabela `sensorbavaresco`
--
ALTER TABLE `sensorbavaresco`
  ADD PRIMARY KEY (`idsensorbavaresco`);

--
-- AUTO_INCREMENT para tabelas despejadas
--

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

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

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

--
-- Restrições para tabelas `leiturabavaresco`
--
ALTER TABLE `leiturabavaresco`
  ADD CONSTRAINT `leiturabavaresco_ibfk_1` FOREIGN KEY (`macbavaresco_idmacbavaresco`) REFERENCES `macbavaresco` (`idmacbavaresco`) ON DELETE NO ACTION ON UPDATE NO ACTION,
  ADD CONSTRAINT `leiturabavaresco_ibfk_2` FOREIGN KEY (`sensorbavaresco_idsensorbavaresco`) REFERENCES `sensorbavaresco` (`idsensorbavaresco`) 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 */;
