Ik ben bezig met mezelf wat aan het verdiepen in de MySQLi wereld (zelf ken ik een kleine basis MySQL & PHP). Nu ben ik terecht gekomen op een goede website waar ik makkelijk het één en ander kan bijleren, maar begrijp toch niet zo goed waar in onderstaande code die "$result" vandaan komt. Iemand die mij even kan bijbrengen waarom die plots opdaagt in een condition en statement? Is dit misschien een default variable?
code:
code:
PHP:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
| $mysqli = new mysqli('host', 'user', 'password', 'database'); if(mysqli_connect_errno()) { trigger_error('Fout bij verbinding: '.$mysqli->error); } // Queries $queries[] = "UPDATE rekeningen SET saldo = saldo - 1000 WHERE klant = 'A'"; $queries[] = "UPDATE rekeningen SET saldo = saldo + 1000 WHERE klant = 'B'"; // Controle query $controle = "SELECT saldo FROM rekeningen WHERE klant = 'A'"; // Zet autocommit op FALSE $mysqli->autocommit(FALSE); // Uitvoeren van queries en controleren of ze gelukt zijn foreach($queries as $query) { if(!$result = $mysqli->query($query)) { $errors[$query] = $mysqli->error; } if($mysqli->affected_rows == 0) { $errors[$query] = 'Er zijn geen rijen gewijzigd in SQL'; } } // Uitvoeren controle query en controleren waarde if(!$result = $mysqli->query($controle)) { $errors[$controle] = $mysqli->error; } else { $row = $result->fetch_assoc(); if($row['saldo'] < 0) { $errors[$controle] = 'Het saldo op een rekening is niet toereikend.'; } } // ROLLBACK of COMMIT if(isset($errors)) { $mysqli->rollback(); foreach($errors as $sql => $error) { echo '<pre>'.$error.' SQL: '.$sql.'</pre>'; } } else { $mysqli->commit(); } |