Bevor wir mit dem Codieren beginnen, müssen wir uns an einige der Probleme erinnern, mit denen wir täglich konfrontiert sind, oder an schlechte Erfahrungen
Bei der Implementierung von Geschäftslogik Wenn wir auf die folgenden ähnlichen Szenarien stoßen:
Überprüfen Sie, ob Herr A (id=233) Mitglied ist. Wenn ja, ändern Sie das Feld „Status“ auf „aktiv“, andernfalls deleteIt
wird normalerweise so geschrieben, wenn kein Framework vorhanden ist (der folgende Code überspringt die gesamte pdo-Logik)
// 首先查询A先生的数据, 获取他的身份 $a = 'select * from users where id = 233'; // 判定是否为会员 if($a->member === true) // 是就修改字段 $b = 'update users set status = 'active' where id = 233'; else // 否就删除数据 $b= 'delete from users where id = 233';
Beachten Sie, dass dies daran liegt, dass wir alle Schritte von pdo vereinfacht haben. Ich habe Tausende von Zeilen gesehen, die mit SQL-Anweisungen gefüllt sind, und die Rekonstruktion ist inkompetent
Warum müssen wir also so viel schreiben?
Wenn die Daten zurückgegeben werden, werden sie in eine Instanz umgewandelt , die mit Funktion geliefert wird, kann bestimmte Operationen ausführen
Aus diesem Grund werden im Abfrageartikel die zurückgegebenen Daten zur Konvertierung in die Funktion cast()
verwenden Sie können dies nach der Kapselung tun// 首先查询A先生的数据, 获取他的身份 $a = User::find(233); // 判定是否存在该id和该id是否为会员 if($a & $a->member) // 是就修改字段 $b = $a->update(['status'=>'active']); else // 否就删除数据 $b= $a->delete();Als nächstes müssen wir darüber nachdenken
Wie ändert man die Datenbankdaten?Dies ist meine eigene oberflächliche Antwort
In häufigen Situationen müssen wir bedingte Syntax verwenden, um den Datenbereich anzugeben, der geändert werden muss, und die Daten zu filtern, die nicht neu geschrieben werden müssenGemäß der obigen Erklärung gibt es drei Beispiele
Ändern Sie alle Daten in der Tabelle
update Actor set first_name = 'new data'
update Actor set first_name = 'new data' where first_name like '%L%'
Schlüssel oder eindeutigen Schlüssel der Tabelle
update Actor set first_name = 'new data' where actor_id = 10
PS: Ich kann die zu erweiterte Update-Anweisung aufgrund meiner Unerfahrenheit nicht verstehen/habe sie nie verwendet. Bitte hinterlassen Sie eine Nachricht
// 改写数据库数据 public function update(array $values) { // 如果写保护已经开启,跳出错误 if($this->writeLock) throw new Exception("data is not allow to update"); // 编译update语句 $sql = $this->grammar->compileUpdate($this, $values); // 将所有变量的值合成一个数组, 其中包括条件语句部分 $bindings = array_values(array_merge($values, $this->getBindings())); // 返回改写结果,成功true失败false return $this->connector->update($sql, $bindings); }
public function compileUpdate(Builder $query, $values) { // 循环$values, 记得引用 foreach ($values as $key => &$value) // 将所有$value改成对应的$key=? $value = $key.' = ?'; // 将$values中的之全部掏出在连接起来 $columns = implode(', ', array_values($values)); // 附上where语句如果有 // 由于更复杂的sql update语句我还没试过, 为了不坑人, 所以限制只有where语法有效 // 欢迎提供更复杂的where语句 $where = is_null($query->wheres) ? '' : $this->compileWheres($query); // 返回update语句 return trim("update $query->from set $columns $where"); }
// 一种更快捷的update方式 public function save() { return $this->update((array)$this->data); }
$a = Actor::where('first_name', 'ANGELINA') ->update(['last_name'=>'changed']); dd($a);
$a = Actor::where('first_name', 'ANGELINA') ->first(); dd($a->update(['last_name'=>'again']));
$a = Actor::where('first_name', 'ANGELINA') ->first(); $a->last_name = 'save'; dd($a->save());das Ergebnis zurückgeben
boolean true // 失败返回false
Das obige ist der detaillierte Inhalt vonSo schreiben Sie Ihr eigenes Datenbankpaket (5). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!