LAST_INSERT_를 사용하여 여러 테이블에 삽입PDO준비명세서내 아이디
저는 이 주제에 대해 꽤 많은 질의응답이 있다는 것을 알고 있지만, 저는 상당히 개인적인 문제에 직면해 있기 때문에 새로운 질문을 하게 되었습니다.
사용하고 있다PHP7
와 함께mariadb 10.x
및 그PHP
템플릿 엔진Twig 2.x
2개의 관련 테이블에 데이터를 삽입하는 것이 목표입니다.
잘 모르시는 분들을 위해서Twig
이 툴은 기본적으로 분리하는 데 도움이 되는 툴입니다.html
그리고.php
템플릿을 사용하여 코드화합니다.나의.html
따라서 파일은.twig
.
다음 코드를 사용하면INSERT INTO
채워질 뿐이다adresse
가치관을 가지고 있지만person
완전히 비어 있습니다.에러 메시지는 표시되지 않습니다.error.log
.
제가 무엇을 빠뜨리고 있나요?제가 무엇을 잘못했나요?
저도 덧붙였습니다.BEGIN; --preparestmt--; COMMIT;
이 스테이트먼트가 함께 속하며 하나의 트랜잭션으로 취급되어야 한다는 것을 확인합니다.
입력했습니다.SELECT last_insert_id();
그리고 그것이 나에게 결과를 주었다.0
.왜요?
adresse.adresse_id
결국 증가했습니까?왜?last_insert_id()
증가된 값을 취하지는 않지만0
?
내 테이블 구조:
어드레스
- adrese_id(INT, PK, NOT NULL, AUTO_Increment)
- 이름 1
- 스트라세
- 제발
- 행하다
사람인
- person_id(INT, 프라이머리 키, NULL 아님, AUTO_Increment)
- adrese_id (FK)
- adrgruppe_id
- adrstatus_id
- 펑션_id
- 이름.
- 인식하다
- 펑션
- 하지 않다
- 텔레폰
- 텔레폰2
- 텔레폰3
- 텔레폰4
- 메일 주소
- 팩스.
- sb_kuerzel
neuerBauleiter.twig
{% include "headerKundendienst.twig" %}
<body class="maincontent">
<div class="main-content">
<h2>Bauleiter hinzufügen</h2>
<form method="post" action="neuerBauleiter">
<p>
<label class="editSupplierLabel">Nachname</label>
<input class="editSupplier" type="text" name="txtBlName" required>
</p>
<p>
<label class="editSupplierLabel">Vorname</label>
<input class="editSupplier" type="text" name="txtBlVorname" required>
</p>
<p>
<label class="editSupplierLabel">Anschrift</label>
<input class="editSupplier" type="text" name="txtBlAnschrift" required>
</p>
<p>
<label class="editSupplierLabel">PLZ</label>
<input class="editSupplier" type="text" name="txtBlPlz" required>
</p>
<p>
<label class="editSupplierLabel">Ort</label>
<input class="editSupplier" type="text" name="txtBlOrt" required>
</p>
<p>
<label class="editSupplierLabel">Telefon</label>
<input class="editSupplier" type="tel" name="txtBlTel" required>
</p>
<p>
<label class="editSupplierLabel">Telefon2</label>
<input class="editSupplier" type="tel" name="txtBlTel2">
</p>
<p>
<label class="editSupplierLabel">Telefon3</label>
<input class="editSupplier" type="tel" name="txtBlTel3">
</p>
<p>
<label class="editSupplierLabel">E-Mail</label>
<input class="editSupplier" type="email" name="txtBlMail" required>
</p>
<p>
<label class="editSupplierLabel">Fax</label>
<input class="editSupplier" type="tel" name="txtBlFax">
</p>
<p>
<label class="editSupplierLabel">Sachbearbeiter</label>
<input class="editSupplier" type="text" name="txtBlSb" value="{{ loggedUser }}" readonly required>
</p>
<p>
<label class="editSupplierLabel">Adressgruppe-ID</label>
<input class="editSupplier" type="text" name="BlAdrgruppeid" value="1272" readonly required>
</p>
<p>
<label class="editSupplierLabel">Adressstatus-ID</label>
<input class="editSupplier" type="text" name="BlAdrstatusid" value="62" readonly required>
</p>
<p>
<label class="editSupplierLabel">Funktion-ID</label>
<input class="editSupplier" type="text" name="BlFunktionid" value="2" readonly required>
</p>
<p>
<label class="editSupplierLabel">Funktion</label>
<input class="editSupplier" type="text" name="BlFunktion" value="Bauleiter" readonly required>
</p>
<p>
<label class="editSupplierLabel">Abteilung</label>
<input class="editSupplier" type="text" name="BlAbteilung" value="Bauleitung" readonly required>
</p>
<p>
<input class="button_save" type="submit" name="btnSaveBl" value="Speichern">
<a href="listeBauleiter" class="button_delete" style="margin-bottom: 40px; margin-left:150px;">Zurück</a>
</p>
</form>
</div>
</div>
</body>
{% include "footer.twig" %}
뉴어볼리터php
<?php
require_once 'vendor/autoload.php'; // keine pfad anpassung mehr nötig, immer so lassen
require_once "utils/Database.class.php"; // include database configuration
/* Daten für neuen Bauleiter speichern */
if (isset($_POST["btnSaveBl"]))
{
DatabaseLink::getInstance()->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$stmt = DatabaseLink::getInstance()->prepare("INSERT INTO adresse(name1, strasse, plz, ort)
VALUES (:blNachname, :blAnschrift, :blPlz, :blOrt);
INSERT INTO intranet.person(adresse_id, name, vorname,
telefon, telefon2, telefon4, mailadresse, fax, adrgruppe_id, adrstatus_id, funktion_id, funktion, abteilung, sb_kuerzel)
VALUES (last_insert_id(), :blNachname, :blVorname,
:blTel, :blTel2, :blTel4, :blMail, :blFax, :bladrgruppeid, :bladrstatusid, :blfunktionid, :blfunktion,
:blabteilung, :blSachbearbeiter;)");
$result = $stmt->execute(array(
":blNachname" => $_POST["txtBlName"],
":blVorname" => $_POST["txtBlVorname"],
":blAnschrift" => $_POST["txtBlAnschrift"],
":blPlz" => $_POST["txtBlPlz"],
":blOrt" => $_POST["txtBlOrt"],
":blTel" => $_POST["txtBlTel"],
":blTel2" => $_POST["txtBlTel2"],
":blTel4" => $_POST["txtBlTel3"],
":blMail" => $_POST["txtBlMail"],
":blFax" => $_POST["txtBlFax"],
":blSachbearbeiter" => $_POST["txtBlSb"],
":bladrgruppeid" => $_POST["BlAdrgruppeid"],
":bladrstatusid" => $_POST["BlAdrstatusid"],
":blfunktionid" => $_POST["BlFunktionid"],
":blfunktion" => $_POST["BlFunktion"],
":blabteilung" => $_POST["BlAbteilung"]
));
header("Location: listeBauleiter");
}
/* Twig initialisieren */
$loader = new Twig_Loader_Filesystem('template/'); // keine pfad anpassung mehr nötig, immer so lassen
$twig = new Twig_Environment($loader, array(
"debug" => "true",
));
include "utils/injector.php";
$twig->addExtension(new Twig_Extension_Debug());
//templatewerte
$templateName = "neuerBauleiter.twig";
$data = array(
);
//display
echo $twig->render($templateName, $data);
준비된 쿼리에 여러 문을 넣을 수 없습니다.매뉴얼:
준비된 문의 SQL 구문은 다중 문을 지원하지 않습니다.
따라서 아래와 같이 준비를 분할하여 실행해야 합니다.이걸 찾으셔야 합니다.그게 의미하는 건LAST_INSERT_ID()
예상대로 작동하기 시작합니다.
$stmt = DatabaseLink::getInstance()->prepare("INSERT INTO adresse(name1, strasse, plz, ort)
VALUES (:blNachname, :blAnschrift, :blPlz, :blOrt)");
$stmt2 = DatabaseLink::getInstance()->prepare("INSERT INTO intranet.person(adresse_id, name, vorname,
telefon, telefon2, telefon4, mailadresse, fax, adrgruppe_id, adrstatus_id, funktion_id, funktion, abteilung, sb_kuerzel)
VALUES (last_insert_id(), :blNachname, :blVorname, :blTel, :blTel2, :blTel4, :blMail, :blFax, :bladrgruppeid, :bladrstatusid, :blfunktionid, :blfunktion,
:blabteilung, :blSachbearbeiter;)");
$result = $stmt->execute(array(
":blNachname" => $_POST["txtBlName"],
":blVorname" => $_POST["txtBlVorname"],
":blAnschrift" => $_POST["txtBlAnschrift"],
":blPlz" => $_POST["txtBlPlz"],
":blOrt" => $_POST["txtBlOrt"]));
$result2 = $stmt2->execute(array(
":blTel" => $_POST["txtBlTel"],
":blTel2" => $_POST["txtBlTel2"],
":blTel4" => $_POST["txtBlTel3"],
":blMail" => $_POST["txtBlMail"],
":blFax" => $_POST["txtBlFax"],
":blSachbearbeiter" => $_POST["txtBlSb"],
":bladrgruppeid" => $_POST["BlAdrgruppeid"],
":bladrstatusid" => $_POST["BlAdrstatusid"],
":blfunktionid" => $_POST["BlFunktionid"],
":blfunktion" => $_POST["BlFunktion"],
":blabteilung" => $_POST["BlAbteilung"]
));
언급URL : https://stackoverflow.com/questions/51980869/insert-into-multiple-tables-using-last-insert-id-inside-pdo-prepared-statement
'itsource' 카테고리의 다른 글
ResultSet의 데이터를 열 이름과 함께 인쇄합니다. (0) | 2022.09.04 |
---|---|
JavaScript에서 스크립트를 종료하려면 어떻게 해야 합니까? (0) | 2022.09.04 |
JavaScript에서 날짜/시간을 빼는 방법 (0) | 2022.09.04 |
Python에서 목록의 요소 수를 얻으려면 어떻게 해야 합니까? (0) | 2022.09.04 |
64비트 정수를 16진수로 인쇄하는 방법 (0) | 2022.09.03 |