Вставка ПРОЦЕДУРЫ в query () в PHP - PullRequest
0 голосов
/ 26 октября 2019

Я некоторое время пытался интегрировать процедуру с PHP, но при вызове PHP все равно возникают ошибки:


Обзор:

$database = null;

	function Conecta($server, $user, $port, $bd){
		$GLOBALS['database'] = mysql_connect($server, $user, $port);
		mysql_select_db($bd);
		if ($GLOBALS['database']) {
			return $GLOBALS['database'];
		} else {
    		aviso("ERRO!");
		}
	}

	function aviso($texto){
		?>
			<script>
				alert("<?php echo $texto ?>");
			</script>
		<?php
	}

	function CadastrarFuncionario($nome_fun, $cargo_fun, $nascimento_fun, $cpf_fun, $rg_fun, $estado_fun, $salario_fun){
		$res = $GLOBALS['database']->query("SET @nomefun = '".$nome_fun."'");
		if ($res0) {
			aviso("foi");
		}
		$res .= $GLOBALS['database']->query("SET @cargofun = '".$cargo_fun."'");
		$res2 = $GLOBALS['database']->query("SET @nascimentofun = '".$nascimento_fun."'");
		$res3 = $GLOBALS['database']->query("SET @cpfun = '".$cpf_fun."'");
		$res4 = $GLOBALS['database']->query("SET @rgfun = '".$rg_fun."'");
		$res5 = $GLOBALS['database']->query("SET @estadofun = '".$estado_fun."'");
		$res6 = $GLOBALS['database']->query("SET @salariofun = '".$salario_fun."'");


		$sql = "CALL CadastrarFuncionario(@nomefun, @cargofun, @nascimentofun, @cpfun, @rgfun, @estadofun, @salariofun);";
		$res7 = $GLOBALS['database']->query($sql);
		if ($res7) {
			aviso("funcionário cadastrado com sucesso!");
		} else {
			aviso("erro!");
		}
	}

	function CadastrarDependente($nome_dep, $nascimento_dep, $funcionario_dep, $parentesco_dep, $conexao){
		$res = mysqli_query($conexao, "CALL CadastrarDependente ('".$nome_dep."', '".$nascimento_dep."', ".$funcionario_dep.", '".$parentesco_dep."')", MYSQLI_USE_RESULT);
		if ($res) {
			aviso("dependente cadastrado com sucesso!");
		} else {
			aviso("erro!");
		}
	}

Однако я не знаю, заключается ли проблема в коде или логике программирования, но эта вызванная процедура запрограммирована следующим образом:


Таблицы и процедурыв MySQL:

CREATE TABLE funcionario (
	id INT PRIMARY KEY AUTO_INCREMENT,
	nome VARCHAR(100) NOT NULL,
	cargo VARCHAR(50) NOT NULL,
	nascimento DATE NOT NULL,
	cpf CHAR(20) NOT NULL,
	rg CHAR(20) NOT NULL,
	estado CHAR(50) NOT NULL,
	salario DOUBLE NOT NULL
);

CREATE TABLE dependente (
	id INT PRIMARY KEY AUTO_INCREMENT,
	nome VARCHAR(100) NOT NULL,
	nascimento DATE NOT NULL,
	funcionario_id INT NOT NULL,
	parentesco CHAR(50) NOT NULL,
	FOREIGN KEY (funcionario_id) REFERENCES funcionario (id)
);

# cadastrar

DELIMITER $$
CREATE PROCEDURE CadastrarFuncionario (IN nome_fun VARCHAR(100), IN cargo_fun VARCHAR(50), IN nascimento_fun DATE, IN cpf_fun CHAR(20), IN rg_fun CHAR(20), IN estado_fun CHAR(50), IN salario_fun DOUBLE)
BEGIN
	INSERT INTO funcionario VALUES (null, nome_fun, cargo_fun, nascimento_fun, cpf_fun, rg_fun, estado_fun, salario_fun);
END $$
DELIMITER ;

DELIMITER $$
CREATE PROCEDURE CadastrarDependente (IN nome_dep VARCHAR(100), IN nascimento_dep DATE, IN funcionario_dep INT, IN parentesco_dep CHAR(50))
BEGIN
	INSERT INTO dependente VALUES (null, nome_dep, nascimento_dep, funcionario_dep, parentesco_dep);
END $$
DELIMITER ;

И на сервере PHP настаивает на той же ошибке:


Неустранимая ошибка: вызов функции-члена prepare () для необъекта в C:\ Users \ user \ Desktop \ USBWebserver v8.6 \ root \ recuperacao - tpi \ funcs.php в строке 25

Проблема: из-за каких ошибок сервер возвращает это предупреждение. И что было бы лучше всего создать обычную процедуру и вызвать ее с помощью PHP.

...