Skip to content

Commit

Permalink
Deployed 3688fca with MkDocs version: 1.6.0
Browse files Browse the repository at this point in the history
  • Loading branch information
jrycw committed Aug 4, 2024
1 parent 08e19d3 commit af56db7
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 10 deletions.
22 changes: 13 additions & 9 deletions scenes/scene03/scene03/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -1997,15 +1997,19 @@ <h3 id="insert-criminalrecord"><code>insert</code> <code>CriminalRecord</code></
</details>
<details class="info">
<summary>如果<code>insert</code>順序很重要</summary>
<p>由於<code>EdgeDBset</code>是無序的,所以<code>insert</code>的順序並不能保證。如果想要有確定的<code>insert</code>順序,可以將<code>records</code>改為<code>array</code>
<div class="language-sql highlight"><pre><span></span><code><span id="__span-15-1"><a id="__codelineno-15-1" name="__codelineno-15-1" href="#__codelineno-15-1"></a><span class="k">with</span><span class="w"> </span><span class="n">records</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="p">[(</span><span class="n">ref_no</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="ss">&quot;CCR9314768&quot;</span><span class="p">,</span><span class="w"> </span><span class="n">code</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="ss">&quot;OFFNCE: A.O.A.B.H &quot;</span><span class="p">),</span><span class="w"> </span><span class="p">(</span><span class="n">ref_no</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="ss">&quot;RN992317&quot;</span><span class="p">,</span><span class="w"> </span><span class="n">code</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="ss">&quot;CD-POD &quot;</span><span class="p">)],</span>
</span><span id="__span-15-2"><a id="__codelineno-15-2" name="__codelineno-15-2" href="#__codelineno-15-2"></a><span class="k">for</span><span class="w"> </span><span class="n">record</span><span class="w"> </span><span class="k">in</span><span class="w"> </span><span class="n">records</span>
</span><span id="__span-15-3"><a id="__codelineno-15-3" name="__codelineno-15-3" href="#__codelineno-15-3"></a><span class="k">union</span><span class="w"> </span><span class="p">(</span><span class="k">insert</span><span class="w"> </span><span class="n">CriminalRecord</span><span class="w"> </span><span class="err">{</span>
</span><span id="__span-15-4"><a id="__codelineno-15-4" name="__codelineno-15-4" href="#__codelineno-15-4"></a><span class="w"> </span><span class="n">ref_no</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">record</span><span class="p">.</span><span class="n">ref_no</span><span class="p">,</span>
</span><span id="__span-15-5"><a id="__codelineno-15-5" name="__codelineno-15-5" href="#__codelineno-15-5"></a><span class="w"> </span><span class="n">code</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">record</span><span class="p">.</span><span class="n">code</span><span class="p">,</span>
</span><span id="__span-15-6"><a id="__codelineno-15-6" name="__codelineno-15-6" href="#__codelineno-15-6"></a><span class="w"> </span><span class="n">involved</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">chen</span><span class="p">,</span>
</span><span id="__span-15-7"><a id="__codelineno-15-7" name="__codelineno-15-7" href="#__codelineno-15-7"></a><span class="err">}</span><span class="p">);</span>
</span></code></pre></div></p>
<p>由於<code>EdgeDBset</code>是無序的,所以<code>insert</code>的順序並不能保證。如果想要有確定的<code>insert</code>順序,需要搭配<code>array</code><a href="https://www.edgedb.com/docs/stdlib/range#function::std::range_unpack"><code>range_unpack</code></a>
<div class="language-sql highlight"><pre><span></span><code><span id="__span-15-1"><a id="__codelineno-15-1" name="__codelineno-15-1" href="#__codelineno-15-1"></a><span class="k">with</span><span class="w"> </span><span class="n">records</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="p">[(</span><span class="ss">&quot;CCR9314768&quot;</span><span class="p">,</span><span class="w"> </span><span class="ss">&quot;OFFNCE: A.O.A.B.H &quot;</span><span class="p">),</span><span class="w"> </span><span class="p">(</span><span class="ss">&quot;RN992317&quot;</span><span class="p">,</span><span class="w"> </span><span class="ss">&quot;CD-POD &quot;</span><span class="p">)],</span>
</span><span id="__span-15-2"><a id="__codelineno-15-2" name="__codelineno-15-2" href="#__codelineno-15-2"></a><span class="w"> </span><span class="n">record_len</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">len</span><span class="p">(</span><span class="n">records</span><span class="p">),</span>
</span><span id="__span-15-3"><a id="__codelineno-15-3" name="__codelineno-15-3" href="#__codelineno-15-3"></a><span class="k">for</span><span class="w"> </span><span class="n">i</span><span class="w"> </span><span class="k">in</span><span class="w"> </span><span class="n">range_unpack</span><span class="p">(</span><span class="n">range</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="w"> </span><span class="n">record_len</span><span class="p">))</span>
</span><span id="__span-15-4"><a id="__codelineno-15-4" name="__codelineno-15-4" href="#__codelineno-15-4"></a><span class="k">union</span><span class="w"> </span><span class="p">(</span><span class="k">insert</span><span class="w"> </span><span class="n">CriminalRecord</span><span class="w"> </span><span class="err">{</span>
</span><span id="__span-15-5"><a id="__codelineno-15-5" name="__codelineno-15-5" href="#__codelineno-15-5"></a><span class="w"> </span><span class="n">ref_no</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">array_get</span><span class="p">(</span><span class="n">records</span><span class="p">,</span><span class="w"> </span><span class="n">i</span><span class="p">).</span><span class="mi">0</span><span class="p">,</span>
</span><span id="__span-15-6"><a id="__codelineno-15-6" name="__codelineno-15-6" href="#__codelineno-15-6"></a><span class="w"> </span><span class="n">code</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">array_get</span><span class="p">(</span><span class="n">records</span><span class="p">,</span><span class="w"> </span><span class="n">i</span><span class="p">).</span><span class="mi">1</span><span class="p">,</span>
</span><span id="__span-15-7"><a id="__codelineno-15-7" name="__codelineno-15-7" href="#__codelineno-15-7"></a><span class="w"> </span><span class="n">ref_no</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">record</span><span class="p">.</span><span class="n">ref_no</span><span class="p">,</span>
</span><span id="__span-15-8"><a id="__codelineno-15-8" name="__codelineno-15-8" href="#__codelineno-15-8"></a><span class="w"> </span><span class="n">code</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">record</span><span class="p">.</span><span class="n">code</span><span class="p">,</span>
</span><span id="__span-15-9"><a id="__codelineno-15-9" name="__codelineno-15-9" href="#__codelineno-15-9"></a><span class="w"> </span><span class="n">involved</span><span class="p">:</span><span class="o">=</span><span class="w"> </span><span class="n">chen</span><span class="p">,</span>
</span><span id="__span-15-10"><a id="__codelineno-15-10" name="__codelineno-15-10" href="#__codelineno-15-10"></a><span class="err">}</span><span class="p">);</span>
</span></code></pre></div>
其原理是<code>array</code>是有序的,可以使用<a href="https://www.edgedb.com/docs/stdlib/array#function::std::array_get"><code>array_get</code></a>來索引,而<code>range_unpack</code>可以有序地返回<code>range</code>內的值。不過,這樣的需求應該不太常見。</p>
</details>
<h3 id="select-criminalrecord"><code>select</code> <code>CriminalRecord {**}</code></h3>
<p>我們可以使用<a href="https://www.edgedb.com/docs/edgeql/select#splats"><code>splat</code></a>的語法,來看看兩次<code>insert</code>是否成功。</p>
Expand Down
2 changes: 1 addition & 1 deletion search/search_index.json

Large diffs are not rendered by default.

0 comments on commit af56db7

Please sign in to comment.