构建自个儿的PHP框架-实现Model类(3)
构建自己的PHP框架--实现Model类(3)
在之前的博客中,我们实现并完善了Model类的findOne方法,下面我们来实现其中的其他方法。
先来看findAll方法,这个方法和findOne很相似。
<code class="sourceCode php"> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> findOne<span class="ot">(</span><span class="kw">$condition</span> = <span class="kw">null</span><span class="ot">)</span> { <span class="kw">$sql</span> = <span class="st">'select * from '</span> . <span class="kw">static</span>::tableName<span class="ot">();</span> <span class="kw">$params</span> = <span class="ot">[];</span> <span class="co">// 判空</span> <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">empty</span><span class="ot">(</span><span class="kw">$condition</span><span class="ot">))</span> { <span class="kw">$sql</span> .= <span class="st">' where '</span><span class="ot">;</span> <span class="kw">$params</span> = <span class="fu">array_values</span><span class="ot">(</span><span class="kw">$condition</span><span class="ot">);</span> <span class="kw">$keys</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$condition</span> <span class="kw">as</span> <span class="kw">$key</span> => <span class="kw">$value</span><span class="ot">)</span> { <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$keys</span><span class="ot">,</span> <span class="st">"</span><span class="kw">$key</span><span class="st"> = ?"</span><span class="ot">);</span> } <span class="kw">$sql</span> .= <span class="fu">implode</span><span class="ot">(</span><span class="st">' and '</span><span class="ot">,</span> <span class="kw">$keys</span><span class="ot">);</span> } <span class="kw">$stmt</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->prepare<span class="ot">(</span><span class="kw">$sql</span><span class="ot">);</span> <span class="kw">$rs</span> = <span class="kw">$stmt</span>->execute<span class="ot">(</span><span class="kw">$params</span><span class="ot">);</span> <span class="kw">$models</span> = <span class="ot">[];</span> <span class="kw">if</span> <span class="ot">(</span><span class="kw">$rs</span><span class="ot">)</span> { <span class="co">// 直接获取出所有符合条件的</span> <span class="kw">$rows</span> = <span class="kw">$stmt</span>->fetchAll<span class="ot">(</span><span class="kw">PDO</span>::<span class="kw">FETCH_ASSOC</span><span class="ot">);</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$rows</span> <span class="kw">as</span> <span class="kw">$row</span><span class="ot">)</span> { <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">empty</span><span class="ot">(</span><span class="kw">$row</span><span class="ot">))</span> { <span class="kw">$model</span> = <span class="kw">new</span> <span class="kw">static</span><span class="ot">();</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$row</span> <span class="kw">as</span> <span class="kw">$rowKey</span> => <span class="kw">$rowValue</span><span class="ot">)</span> { <span class="kw">$model</span>-><span class="kw">$rowKey</span> = <span class="kw">$rowValue</span><span class="ot">;</span> } <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$models</span><span class="ot">,</span> <span class="kw">$model</span><span class="ot">);</span> } } } <span class="kw">return</span> <span class="kw">null</span><span class="ot">;</span> }</code>
你会发现有findOne和findAll方法很相似,明显可以将公共的部分抽出来,然后我们就多了如下两个方法:
<code class="sourceCode php"> <span class="co">/**</span><span class="co"> * Build a sql where part</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">mixed</span><span class="co"> $condition a set of column values</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> string</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> buildWhere<span class="ot">(</span><span class="kw">$condition</span><span class="ot">,</span> <span class="kw">$params</span> = <span class="kw">null</span><span class="ot">)</span> { <span class="kw">if</span> <span class="ot">(</span><span class="fu">is_null</span><span class="ot">(</span><span class="kw">$params</span><span class="ot">))</span> { <span class="kw">$params</span> = <span class="ot">[];</span> } <span class="kw">$where</span> = <span class="st">''</span><span class="ot">;</span> <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">empty</span><span class="ot">(</span><span class="kw">$condition</span><span class="ot">))</span> { <span class="kw">$where</span> .= <span class="st">' where '</span><span class="ot">;</span> <span class="kw">$keys</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$condition</span> <span class="kw">as</span> <span class="kw">$key</span> => <span class="kw">$value</span><span class="ot">)</span> { <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$keys</span><span class="ot">,</span> <span class="st">"</span><span class="kw">$key</span><span class="st"> = ?"</span><span class="ot">);</span> <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$params</span><span class="ot">,</span> <span class="kw">$value</span><span class="ot">);</span> } <span class="kw">$where</span> .= <span class="fu">implode</span><span class="ot">(</span><span class="st">' and '</span><span class="ot">,</span> <span class="kw">$keys</span><span class="ot">);</span> } <span class="kw">return</span> <span class="ot">[</span><span class="kw">$where</span><span class="ot">,</span> <span class="kw">$params</span><span class="ot">];</span> } <span class="co">/**</span><span class="co"> * Convert array to model</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">mixed</span><span class="co"> $row the row data from database</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> arr2Model<span class="ot">(</span><span class="kw">$row</span><span class="ot">)</span> { <span class="kw">$model</span> = <span class="kw">new</span> <span class="kw">static</span><span class="ot">();</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$row</span> <span class="kw">as</span> <span class="kw">$rowKey</span> => <span class="kw">$rowValue</span><span class="ot">)</span> { <span class="kw">$model</span>-><span class="kw">$rowKey</span> = <span class="kw">$rowValue</span><span class="ot">;</span> } <span class="kw">return</span> <span class="kw">$model</span><span class="ot">;</span> }</code>
分别是构建sql中where部分的方法和将查找到的Array转换成Model的方法。大家会奇怪第一个方法中为什么需要params参数和返回值,其实这个为了之后的updateAll方法的使用。其实这个地方跟适合使用引用传值。
这样我们的findOne和findAll就便成了如下内容:
<code class="sourceCode php"> <span class="co">/**</span><span class="co"> * Returns a single model instance by a primary key or an array of column values.</span><span class="co"> *</span><span class="co"> * ```php</span><span class="co"> * // find the first customer whose age is 30 and whose status is 1</span><span class="co"> * $customer = Customer::findOne(['age' => 30, 'status' => 1]);</span><span class="co"> * ```</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">mixed</span><span class="co"> $condition a set of column values</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> static|null Model instance matching the condition, or null if nothing matches.</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> findOne<span class="ot">(</span><span class="kw">$condition</span> = <span class="kw">null</span><span class="ot">)</span> { <span class="fu">list</span><span class="ot">(</span><span class="kw">$where</span><span class="ot">,</span> <span class="kw">$params</span><span class="ot">)</span> = <span class="kw">static</span>::buildWhere<span class="ot">(</span><span class="kw">$condition</span><span class="ot">);</span> <span class="kw">$sql</span> = <span class="st">'select * from '</span> . <span class="kw">static</span>::tableName<span class="ot">()</span> . <span class="kw">$where</span><span class="ot">;</span> <span class="kw">$stmt</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->prepare<span class="ot">(</span><span class="kw">$sql</span><span class="ot">);</span> <span class="kw">$rs</span> = <span class="kw">$stmt</span>->execute<span class="ot">(</span><span class="kw">$params</span><span class="ot">);</span> <span class="kw">if</span> <span class="ot">(</span><span class="kw">$rs</span><span class="ot">)</span> { <span class="kw">$row</span> = <span class="kw">$stmt</span>->fetch<span class="ot">(</span><span class="kw">PDO</span>::<span class="kw">FETCH_ASSOC</span><span class="ot">);</span> <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">empty</span><span class="ot">(</span><span class="kw">$row</span><span class="ot">))</span> { <span class="kw">return</span> <span class="kw">static</span>::arr2Model<span class="ot">(</span><span class="kw">$row</span><span class="ot">);</span> } } <span class="kw">return</span> <span class="kw">null</span><span class="ot">;</span> } <span class="co">/**</span><span class="co"> * Returns a list of models that match the specified primary key value(s) or a set of column values.</span><span class="co"> *</span><span class="co"> * ```php</span><span class="co"> * // find customers whose age is 30 and whose status is 1</span><span class="co"> * $customers = Customer::findAll(['age' => 30, 'status' => 1]);</span><span class="co"> * ```</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">mixed</span><span class="co"> $condition a set of column values</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> array an array of Model instance, or an empty array if nothing matches.</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> findAll<span class="ot">(</span><span class="kw">$condition</span> = <span class="kw">null</span><span class="ot">)</span> { <span class="fu">list</span><span class="ot">(</span><span class="kw">$where</span><span class="ot">,</span> <span class="kw">$params</span><span class="ot">)</span> = <span class="kw">static</span>::buildWhere<span class="ot">(</span><span class="kw">$condition</span><span class="ot">);</span> <span class="kw">$sql</span> = <span class="st">'select * from '</span> . <span class="kw">static</span>::tableName<span class="ot">()</span> . <span class="kw">$where</span><span class="ot">;</span> <span class="kw">$stmt</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->prepare<span class="ot">(</span><span class="kw">$sql</span><span class="ot">);</span> <span class="kw">$rs</span> = <span class="kw">$stmt</span>->execute<span class="ot">(</span><span class="kw">$params</span><span class="ot">);</span> <span class="kw">$models</span> = <span class="ot">[];</span> <span class="kw">if</span> <span class="ot">(</span><span class="kw">$rs</span><span class="ot">)</span> { <span class="kw">$rows</span> = <span class="kw">$stmt</span>->fetchAll<span class="ot">(</span><span class="kw">PDO</span>::<span class="kw">FETCH_ASSOC</span><span class="ot">);</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$rows</span> <span class="kw">as</span> <span class="kw">$row</span><span class="ot">)</span> { <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">empty</span><span class="ot">(</span><span class="kw">$row</span><span class="ot">))</span> { <span class="kw">$model</span> = <span class="kw">static</span>::arr2Model<span class="ot">(</span><span class="kw">$row</span><span class="ot">);</span> <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$models</span><span class="ot">,</span> <span class="kw">$model</span><span class="ot">);</span> } } } <span class="kw">return</span> <span class="kw">$models</span><span class="ot">;</span> }</code>
剩下的updateAll/deleteAll/insert/update和delete方法就不一一详细说明了,直接给出代码。其基本思想都是一致的,都是按照规则拼接SQL语句。
<code class="sourceCode php"> <span class="co">/**</span><span class="co"> * Updates models using the provided attribute values and conditions.</span><span class="co"> * For example, to change the status to be 2 for all customers whose status is 1:</span><span class="co"> *</span><span class="co"> * ~~~</span><span class="co"> * Customer::updateAll(['status' => 1], ['status' => '2']);</span><span class="co"> * ~~~</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">array</span><span class="co"> $attributes attribute values (name-value pairs) to be saved for the model.</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">array</span><span class="co"> $condition the condition that matches the models that should get updated.</span><span class="co"> * An empty condition will match all models.</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> integer the number of rows updated</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> updateAll<span class="ot">(</span><span class="kw">$condition</span><span class="ot">,</span> <span class="kw">$attributes</span><span class="ot">)</span> { <span class="kw">$sql</span> = <span class="st">'update '</span> . <span class="kw">static</span>::tableName<span class="ot">();</span> <span class="kw">$params</span> = <span class="ot">[];</span> <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">empty</span><span class="ot">(</span><span class="kw">$attributes</span><span class="ot">))</span> { <span class="kw">$sql</span> .= <span class="st">' set '</span><span class="ot">;</span> <span class="kw">$params</span> = <span class="fu">array_values</span><span class="ot">(</span><span class="kw">$attributes</span><span class="ot">);</span> <span class="kw">$keys</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$attributes</span> <span class="kw">as</span> <span class="kw">$key</span> => <span class="kw">$value</span><span class="ot">)</span> { <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$keys</span><span class="ot">,</span> <span class="st">"</span><span class="kw">$key</span><span class="st"> = ?"</span><span class="ot">);</span> } <span class="kw">$sql</span> .= <span class="fu">implode</span><span class="ot">(</span><span class="st">' , '</span><span class="ot">,</span> <span class="kw">$keys</span><span class="ot">);</span> } <span class="fu">list</span><span class="ot">(</span><span class="kw">$where</span><span class="ot">,</span> <span class="kw">$params</span><span class="ot">)</span> = <span class="kw">static</span>::buildWhere<span class="ot">(</span><span class="kw">$condition</span><span class="ot">,</span> <span class="kw">$params</span><span class="ot">);</span> <span class="kw">$sql</span> .= <span class="kw">$where</span><span class="ot">;</span> <span class="kw">$stmt</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->prepare<span class="ot">(</span><span class="kw">$sql</span><span class="ot">);</span> <span class="kw">$execResult</span> = <span class="kw">$stmt</span>->execute<span class="ot">(</span><span class="kw">$params</span><span class="ot">);</span> <span class="kw">if</span> <span class="ot">(</span><span class="kw">$execResult</span><span class="ot">)</span> { <span class="co">// 获取更新的行数</span> <span class="kw">$execResult</span> = <span class="kw">$stmt</span>->rowCount<span class="ot">();</span> } <span class="kw">return</span> <span class="kw">$execResult</span><span class="ot">;</span> } <span class="co">/**</span><span class="co"> * Deletes models using the provided conditions.</span><span class="co"> * WARNING: If you do not specify any condition, this method will delete ALL rows in the table.</span><span class="co"> *</span><span class="co"> * For example, to delete all customers whose status is 3:</span><span class="co"> *</span><span class="co"> * ~~~</span><span class="co"> * Customer::deleteAll([status = 3]);</span><span class="co"> * ~~~</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@param</span><span class="co"> </span><span class="kw">array</span><span class="co"> $condition the condition that matches the models that should get deleted.</span><span class="co"> * An empty condition will match all models.</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> integer the number of rows deleted</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">static</span> <span class="kw">function</span> deleteAll<span class="ot">(</span><span class="kw">$condition</span><span class="ot">)</span> { <span class="fu">list</span><span class="ot">(</span><span class="kw">$where</span><span class="ot">,</span> <span class="kw">$params</span><span class="ot">)</span> = <span class="kw">static</span>::buildWhere<span class="ot">(</span><span class="kw">$condition</span><span class="ot">);</span> <span class="kw">$sql</span> = <span class="st">'delete from '</span> . <span class="kw">static</span>::tableName<span class="ot">()</span> . <span class="kw">$where</span><span class="ot">;</span> <span class="kw">$stmt</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->prepare<span class="ot">(</span><span class="kw">$sql</span><span class="ot">);</span> <span class="kw">$execResult</span> = <span class="kw">$stmt</span>->execute<span class="ot">(</span><span class="kw">$params</span><span class="ot">);</span> <span class="kw">if</span> <span class="ot">(</span><span class="kw">$execResult</span><span class="ot">)</span> { <span class="co">// 获取删除的行数</span> <span class="kw">$execResult</span> = <span class="kw">$stmt</span>->rowCount<span class="ot">();</span> } <span class="kw">return</span> <span class="kw">$execResult</span><span class="ot">;</span> } <span class="co">/**</span><span class="co"> * Inserts the model into the database using the attribute values of this record.</span><span class="co"> *</span><span class="co"> * Usage example:</span><span class="co"> *</span><span class="co"> * ```php</span><span class="co"> * $customer = new Customer;</span><span class="co"> * $customer->name = $name;</span><span class="co"> * $customer->email = $email;</span><span class="co"> * $customer->insert();</span><span class="co"> * ```</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> boolean whether the model is inserted successfully.</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">function</span> insert<span class="ot">()</span> { <span class="kw">$sql</span> = <span class="st">'insert into '</span> . <span class="kw">static</span>::tableName<span class="ot">();</span> <span class="kw">$params</span> = <span class="ot">[];</span> <span class="kw">$keys</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$this</span> <span class="kw">as</span> <span class="kw">$key</span> => <span class="kw">$value</span><span class="ot">)</span> { <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$keys</span><span class="ot">,</span> <span class="kw">$key</span><span class="ot">);</span> <span class="fu">array_push</span><span class="ot">(</span><span class="kw">$params</span><span class="ot">,</span> <span class="kw">$value</span><span class="ot">);</span> } <span class="co">// 构建由?组成的数组,其个数与参数相等数相同</span> <span class="kw">$holders</span> = <span class="fu">array_fill</span><span class="ot">(</span><span class="dv">0</span><span class="ot">,</span> <span class="fu">count</span><span class="ot">(</span><span class="kw">$keys</span><span class="ot">),</span> <span class="st">'?'</span><span class="ot">);</span> <span class="kw">$sql</span> .= <span class="st">' ('</span> . <span class="fu">implode</span><span class="ot">(</span><span class="st">' , '</span><span class="ot">,</span> <span class="kw">$keys</span><span class="ot">)</span> . <span class="st">') values ( '</span> . <span class="fu">implode</span><span class="ot">(</span><span class="st">' , '</span><span class="ot">,</span> <span class="kw">$holders</span><span class="ot">)</span> . <span class="st">')'</span><span class="ot">;</span> <span class="kw">$stmt</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->prepare<span class="ot">(</span><span class="kw">$sql</span><span class="ot">);</span> <span class="kw">$execResult</span> = <span class="kw">$stmt</span>->execute<span class="ot">(</span><span class="kw">$params</span><span class="ot">);</span> <span class="co">// 将一些自增值赋回Model中</span> <span class="kw">$primaryKeys</span> = <span class="kw">static</span>::primaryKey<span class="ot">();</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$primaryKeys</span> <span class="kw">as</span> <span class="kw">$name</span><span class="ot">)</span> { <span class="co">// Get the primary key</span> <span class="kw">$lastId</span> = <span class="kw">static</span>::getDb<span class="ot">()</span>->lastInsertId<span class="ot">(</span><span class="kw">$name</span><span class="ot">);</span> <span class="kw">$this</span>-><span class="kw">$name</span> = <span class="dt">(int)</span> <span class="kw">$lastId</span><span class="ot">;</span> } <span class="kw">return</span> <span class="kw">$execResult</span><span class="ot">;</span> } <span class="co">/**</span><span class="co"> * Saves the changes to this model into the database.</span><span class="co"> *</span><span class="co"> * Usage example:</span><span class="co"> *</span><span class="co"> * ```php</span><span class="co"> * $customer = Customer::findOne(['id' => $id]);</span><span class="co"> * $customer->name = $name;</span><span class="co"> * $customer->email = $email;</span><span class="co"> * $customer->update();</span><span class="co"> * ```</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> integer|boolean the number of rows affected.</span><span class="co"> * Note that it is possible that the number of rows affected is 0, even though the</span><span class="co"> * update execution is successful.</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">function</span> update<span class="ot">()</span> { <span class="kw">$primaryKeys</span> = <span class="kw">static</span>::primaryKey<span class="ot">();</span> <span class="kw">$condition</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$primaryKeys</span> <span class="kw">as</span> <span class="kw">$name</span><span class="ot">)</span> { <span class="kw">$condition</span><span class="ot">[</span><span class="kw">$name</span><span class="ot">]</span> = <span class="fu">isset</span><span class="ot">(</span><span class="kw">$this</span>-><span class="kw">$name</span><span class="ot">)</span> <span class="ot">?</span> <span class="kw">$this</span>-><span class="kw">$name</span> <span class="ot">:</span> <span class="kw">null</span><span class="ot">;</span> } <span class="kw">$attributes</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$this</span> <span class="kw">as</span> <span class="kw">$key</span> => <span class="kw">$value</span><span class="ot">)</span> { <span class="kw">if</span> <span class="ot">(</span>!<span class="fu">in_array</span><span class="ot">(</span><span class="kw">$key</span><span class="ot">,</span> <span class="kw">$primaryKeys</span><span class="ot">,</span> <span class="kw">true</span><span class="ot">))</span> { <span class="kw">$attributes</span><span class="ot">[</span><span class="kw">$key</span><span class="ot">]</span> = <span class="kw">$value</span><span class="ot">;</span> } } <span class="kw">return</span> <span class="kw">static</span>::updateAll<span class="ot">(</span><span class="kw">$condition</span><span class="ot">,</span> <span class="kw">$attributes</span><span class="ot">)</span> !== <span class="kw">false</span><span class="ot">;</span> } <span class="co">/**</span><span class="co"> * Deletes the model from the database.</span><span class="co"> *</span><span class="co"> * </span><span class="kw">@return</span><span class="co"> integer|boolean the number of rows deleted.</span><span class="co"> * Note that it is possible that the number of rows deleted is 0, even though the deletion execution is successful.</span><span class="co"> */</span> <span class="kw">public</span> <span class="kw">function</span> delete<span class="ot">()</span> { <span class="kw">$primaryKeys</span> = <span class="kw">static</span>::primaryKey<span class="ot">();</span> <span class="kw">$condition</span> = <span class="ot">[];</span> <span class="kw">foreach</span> <span class="ot">(</span><span class="kw">$primaryKeys</span> <span class="kw">as</span> <span class="kw">$name</span><span class="ot">)</span> { <span class="kw">$condition</span><span class="ot">[</span><span class="kw">$name</span><span class="ot">]</span> = <span class="fu">isset</span><span class="ot">(</span><span class="kw">$this</span>-><span class="kw">$name</span><span class="ot">)</span> <span class="ot">?</span> <span class="kw">$this</span>-><span class="kw">$name</span> <span class="ot">:</span> <span class="kw">null</span><span class="ot">;</span> } <span class="kw">return</span> <span class="kw">static</span>::deleteAll<span class="ot">(</span><span class="kw">$condition</span><span class="ot">)</span> !== <span class="kw">false</span><span class="ot">;</span> }</code>
这样基本的Model就算是暂时完成了,虽然可能还有很多问题和局限,但暂时先这样了,我们之后有机会会一步一步的去完善。
好了,今天就先到这里。项目内容和博客内容也都会放到Github上,欢迎大家提建议。
code:https://github.com/CraryPrimitiveMan/simple-framework/tree/0.7
blog project:https://github.com/CraryPrimitiveMan/create-your-own-php-framework

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在許多中心化交易所出現問題後,越來越多的幣圈投資者開始將資產轉移到冷錢包中,以減少中心化交易所帶來的風險。本文將介紹全球最早的冷錢包供應商Trezor,自2014年推出首款冷錢包至今,在全球多個國家銷售。 Trezor的產品包括2014年推出的ModelOne和2018年推出的進階版本ModelT。以下將繼續介紹這兩款產品與其他冷錢包的差異。什麼是Trezor冷錢包? 2014年,Trezor推出了第一款冷皮夾ModelOne。除了常見的BTC、ETH、USDT等幣種外,該錢包還支援超過1000種其

c語言static的作用與用法:1、變數作用域;2、生命週期;3、函數內部;4、修飾全域變數;5、修飾函數;6、其他用途;詳細介紹:1、變數作用域,當一個變數前有static關鍵字,那麼這個變數的作用域被限制在聲明它的檔案內,也就是說,這個變數是“檔案層級作用域”,這對於防止變數的“重複定義”問題很有用; 2、生命週期,靜態變數在程式開始執行時初始化一次,並在程式結束時銷毀等等。

一、static 請先看下面這段程式:publicclassHello{publicstaticvoidmain(String[]args){//(1)System.out.println("Hello,world!");//(2)}}看過這段程序,對於大多數學過Java的從來說,都不陌生。即使沒有學過Java,而學過其它的高階語言,例如C,那你也應該能看懂這段程式碼的意思。它只是簡單的輸出“Hello,world”,一點別的用處都沒有,然而,它卻展示了static關鍵字的主

C語言中static關鍵字的實際應用場景及使用技巧一、概述static是C語言中的關鍵字,用來修飾變數與函數。它的作用是改變其在程式運行過程中的生命週期和可見性,使得變數和函數具有靜態的特性。本文將介紹static關鍵字的實際應用場景及使用技巧,並透過具體的程式碼範例進行說明。二、靜態變數延長變數的生命週期使用static關鍵字修飾局部變數可以將其生命週期

Django是一個開源的Pythonweb框架,它採用了MVT(Model-View-Template)的架構模式,將應用程式分為模型(Model)、視圖(View)和模板(Template)三個部分。其中,Model是Django框架中的一個基礎元件,用於對資料進行定義和管理。本文將對Django框架中的Model進行詳解。什麼是Model在Django

修飾符abstract(抽象的)一、abstract可以修飾類別(1)被abstract修飾的類別稱為抽象類別(2)語法:abstractclass類別名稱{}(3)特點:抽象類別不能單獨建立對象,但是可以聲明引用抽象類別類別名稱引用名稱;(4)抽象類別可以定義成員變數和成員方法(5)抽象類別有建構方法,用於建立子類別物件時,jvm預設建立一個父類別物件;抽象的建構方法應用在jvm建立父類別物件時應用。二、abstract可以修飾方法(1)被asbtract修飾的方法稱為抽象方法(2)語法:存取修飾符abstract回傳值

static的作用:1、變數;2、方法;3、類別;4、其他用途;5、多執行緒環境;6、效能最佳化;7、單例模式;8、常數;9、局部變數;10、記憶體佈局優化;11、避免重複初始化;12、在函數中使用。詳細介紹:1、變量,靜態變量,當一個變量被聲明為static時,它屬於類級別,而不是實例級別,這意味著無論創建多少個對象,都只有一個靜態變量存在,所有對像都共享這個靜態變數等等。

Springboot讀取pro檔案注入static靜態變數mailConfig.properties#伺服器mail.host=smtp.qq.com#連接埠號mail.port=587#郵件帳號mail.userName=hzy_daybreak_lc@foxmail.com#信箱授權碼mail.passWord =vxbkycyjkceocbdc#時間延遲mail.timeout=25000#發送人mail.emailForm=hzy_daybreak_lc@foxmail.com#寄件者mai
