index.html 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464
  1. <!DOCTYPE html><html><head>
  2. <title>index</title>
  3. <meta charset="utf-8">
  4. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  5. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.16.11/dist/katex.min.css">
  6. <style>
  7. pre{font-family:Menlo,Monaco,Consolas,'Courier New',monospace;direction:ltr;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;padding:1em;margin:.5em 0;overflow:auto;line-height:1.5;tab-size:4;hyphens:none;color:#555;background-color:#f0f0f0!important;border:#d6d6d6;border-radius:3px}pre[class*=language-]{padding:1em}code[class*=language-] .token.cdata,code[class*=language-] .token.comment,code[class*=language-] .token.doctype,code[class*=language-] .token.prolog,pre[class*=language-] .token.cdata,pre[class*=language-] .token.comment,pre[class*=language-] .token.doctype,pre[class*=language-] .token.prolog{color:#998;font-style:italic}code[class*=language-] .token.punctuation,pre[class*=language-] .token.punctuation{color:#920b2d}code[class*=language-] .namespace,pre[class*=language-] .namespace{opacity:.7}code[class*=language-] .token.property,pre[class*=language-] .token.property{font-weight:700;color:#333}code[class*=language-] .token.boolean,code[class*=language-] .token.function-name,code[class*=language-] .token.number,pre[class*=language-] .token.boolean,pre[class*=language-] .token.function-name,pre[class*=language-] .token.number{color:#d14}code[class*=language-] .token.tag,pre[class*=language-] .token.tag{color:#d14}code[class*=language-] .token.symbol,pre[class*=language-] .token.symbol{color:#990073}code[class*=language-] .token.selector,pre[class*=language-] .token.selector{color:teal}code[class*=language-] .token.attr-name,pre[class*=language-] .token.attr-name{color:#458;font-weight:700}code[class*=language-] .token.string,pre[class*=language-] .token.string{color:#d14}code[class*=language-] .token.char,pre[class*=language-] .token.char{color:#606aa1}code[class*=language-] .token.url,pre[class*=language-] .token.url{color:#888}code[class*=language-] .token.atrule,code[class*=language-] .token.attr-value,code[class*=language-] .token.keyword,pre[class*=language-] .token.atrule,pre[class*=language-] .token.attr-value,pre[class*=language-] .token.keyword{color:#222;font-weight:700}code[class*=language-] .token.function,pre[class*=language-] .token.function{color:#900}code[class*=language-] .token.class-name,pre[class*=language-] .token.class-name{text-decoration:underline;color:#606aa1}code[class*=language-] .token.variable,pre[class*=language-] .token.variable{color:teal}code[class*=language-] .token.bold,code[class*=language-] .token.important,pre[class*=language-] .token.bold,pre[class*=language-] .token.important{font-weight:700}code[class*=language-] .token.italic,pre[class*=language-] .token.italic{font-style:italic}code[class*=language-] .token.entity,pre[class*=language-] .token.entity{cursor:help}pre[data-line]{position:relative;padding:1em 0 1em 3em}pre[data-line] .line-highlight-wrapper{position:absolute;top:0;left:0;background-color:transparent;display:block;width:100%}pre[data-line] .line-highlight{position:absolute;left:0;right:0;padding:inherit 0;margin-top:1em;background:hsla(24,20%,50%,.08);background:linear-gradient(to right,hsla(24,20%,50%,.1) 70%,hsla(24,20%,50%,0));pointer-events:none;line-height:inherit;white-space:pre}pre[data-line] .line-highlight:before,pre[data-line] .line-highlight[data-end]:after{content:attr(data-start);position:absolute;top:.4em;left:.6em;min-width:1em;padding:0 .5em;background-color:hsla(24,20%,50%,.4);color:#f4f1ef;font:bold 65%/1.5 sans-serif;text-align:center;vertical-align:.3em;border-radius:999px;text-shadow:none;box-shadow:0 1px #fff}pre[data-line] .line-highlight[data-end]:after{content:attr(data-end);top:auto;bottom:.4em}html body{font-family:'Helvetica Neue',Helvetica,'Segoe UI',Arial,freesans,sans-serif;font-size:16px;line-height:1.6;color:#555;background-color:#fff;overflow:initial;box-sizing:border-box;word-wrap:break-word}html body>:first-child{margin-top:0}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{line-height:1.2;margin-top:1em;margin-bottom:16px;color:#030303}html body h1{font-size:2.25em;font-weight:300;padding-bottom:.3em}html body h2{font-size:1.75em;font-weight:400;padding-bottom:.3em}html body h3{font-size:1.5em;font-weight:500}html body h4{font-size:1.25em;font-weight:600}html body h5{font-size:1.1em;font-weight:600}html body h6{font-size:1em;font-weight:600}html body h1,html body h2,html body h3,html body h4,html body h5{font-weight:600}html body h5{font-size:1em}html body h6{color:#7e7e7e}html body strong{color:#030303}html body del{color:#7e7e7e}html body a:not([href]){color:inherit;text-decoration:none}html body a{color:#08c;text-decoration:none}html body a:hover{color:#00a3f5;text-decoration:none}html body img{max-width:100%}html body>p{margin-top:0;margin-bottom:16px;word-wrap:break-word}html body>ol,html body>ul{margin-bottom:16px}html body ol,html body ul{padding-left:2em}html body ol.no-list,html body ul.no-list{padding:0;list-style-type:none}html body ol ol,html body ol ul,html body ul ol,html body ul ul{margin-top:0;margin-bottom:0}html body li{margin-bottom:0}html body li.task-list-item{list-style:none}html body li>p{margin-top:0;margin-bottom:0}html body .task-list-item-checkbox{margin:0 .2em .25em -1.8em;vertical-align:middle}html body .task-list-item-checkbox:hover{cursor:pointer}html body blockquote{margin:16px 0;font-size:inherit;padding:0 15px;color:#7e7e7e;background-color:#f0f0f0;border-left:4px solid #d6d6d6}html body blockquote>:first-child{margin-top:0}html body blockquote>:last-child{margin-bottom:0}html body hr{height:4px;margin:32px 0;background-color:#d6d6d6;border:0 none}html body table{margin:10px 0 15px 0;border-collapse:collapse;border-spacing:0;display:block;width:100%;overflow:auto;word-break:normal;word-break:keep-all}html body table th{font-weight:700;color:#030303}html body table td,html body table th{border:1px solid #d6d6d6;padding:6px 13px}html body dl{padding:0}html body dl dt{padding:0;margin-top:16px;font-size:1em;font-style:italic;font-weight:700}html body dl dd{padding:0 16px;margin-bottom:16px}html body code{font-family:Menlo,Monaco,Consolas,'Courier New',monospace;font-size:.85em;color:#030303;background-color:#f0f0f0;border-radius:3px;padding:.2em 0}html body code::after,html body code::before{letter-spacing:-.2em;content:'\00a0'}html body pre>code{padding:0;margin:0;word-break:normal;white-space:pre;background:0 0;border:0}html body .highlight{margin-bottom:16px}html body .highlight pre,html body pre{padding:1em;overflow:auto;line-height:1.45;border:#d6d6d6;border-radius:3px}html body .highlight pre{margin-bottom:0;word-break:normal}html body pre code,html body pre tt{display:inline;max-width:initial;padding:0;margin:0;overflow:initial;line-height:inherit;word-wrap:normal;background-color:transparent;border:0}html body pre code:after,html body pre code:before,html body pre tt:after,html body pre tt:before{content:normal}html body blockquote,html body dl,html body ol,html body p,html body pre,html body ul{margin-top:0;margin-bottom:16px}html body kbd{color:#030303;border:1px solid #d6d6d6;border-bottom:2px solid #c7c7c7;padding:2px 4px;background-color:#f0f0f0;border-radius:3px}@media print{html body{background-color:#fff}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{color:#030303;page-break-after:avoid}html body blockquote{color:#7e7e7e}html body pre{page-break-inside:avoid}html body table{display:table}html body img{display:block;max-width:100%;max-height:100%}html body code,html body pre{word-wrap:break-word;white-space:pre}}.markdown-preview{width:100%;height:100%;box-sizing:border-box}.markdown-preview ul{list-style:disc}.markdown-preview ul ul{list-style:circle}.markdown-preview ul ul ul{list-style:square}.markdown-preview ol{list-style:decimal}.markdown-preview ol ol,.markdown-preview ul ol{list-style-type:lower-roman}.markdown-preview ol ol ol,.markdown-preview ol ul ol,.markdown-preview ul ol ol,.markdown-preview ul ul ol{list-style-type:lower-alpha}.markdown-preview .newpage,.markdown-preview .pagebreak{page-break-before:always}.markdown-preview pre.line-numbers{position:relative;padding-left:3.8em;counter-reset:linenumber}.markdown-preview pre.line-numbers>code{position:relative}.markdown-preview pre.line-numbers .line-numbers-rows{position:absolute;pointer-events:none;top:1em;font-size:100%;left:0;width:3em;letter-spacing:-1px;border-right:1px solid #999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.markdown-preview pre.line-numbers .line-numbers-rows>span{pointer-events:none;display:block;counter-increment:linenumber}.markdown-preview pre.line-numbers .line-numbers-rows>span:before{content:counter(linenumber);color:#999;display:block;padding-right:.8em;text-align:right}.markdown-preview .mathjax-exps .MathJax_Display{text-align:center!important}.markdown-preview:not([data-for=preview]) .code-chunk .code-chunk-btn-group{display:none}.markdown-preview:not([data-for=preview]) .code-chunk .status{display:none}.markdown-preview:not([data-for=preview]) .code-chunk .output-div{margin-bottom:16px}.markdown-preview .md-toc{padding:0}.markdown-preview .md-toc .md-toc-link-wrapper .md-toc-link{display:inline;padding:.25rem 0}.markdown-preview .md-toc .md-toc-link-wrapper .md-toc-link div,.markdown-preview .md-toc .md-toc-link-wrapper .md-toc-link p{display:inline}.markdown-preview .md-toc .md-toc-link-wrapper.highlighted .md-toc-link{font-weight:800}.scrollbar-style::-webkit-scrollbar{width:8px}.scrollbar-style::-webkit-scrollbar-track{border-radius:10px;background-color:transparent}.scrollbar-style::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(150,150,150,.66);border:4px solid rgba(150,150,150,.66);background-clip:content-box}html body[for=html-export]:not([data-presentation-mode]){position:relative;width:100%;height:100%;top:0;left:0;margin:0;padding:0;overflow:auto}html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{position:relative;top:0;min-height:100vh}@media screen and (min-width:914px){html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{padding:2em calc(50% - 457px + 2em)}}@media screen and (max-width:914px){html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{padding:2em}}@media screen and (max-width:450px){html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{font-size:14px!important;padding:1em}}@media print{html body[for=html-export]:not([data-presentation-mode]) #sidebar-toc-btn{display:none}}html body[for=html-export]:not([data-presentation-mode]) #sidebar-toc-btn{position:fixed;bottom:8px;left:8px;font-size:28px;cursor:pointer;color:inherit;z-index:99;width:32px;text-align:center;opacity:.4}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] #sidebar-toc-btn{opacity:1}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc{position:fixed;top:0;left:0;width:300px;height:100%;padding:32px 0 48px 0;font-size:14px;box-shadow:0 0 4px rgba(150,150,150,.33);box-sizing:border-box;overflow:auto;background-color:inherit}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar{width:8px}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar-track{border-radius:10px;background-color:transparent}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(150,150,150,.66);border:4px solid rgba(150,150,150,.66);background-clip:content-box}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc a{text-decoration:none}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc{padding:0 16px}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper .md-toc-link{display:inline;padding:.25rem 0}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper .md-toc-link div,html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper .md-toc-link p{display:inline}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper.highlighted .md-toc-link{font-weight:800}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{left:300px;width:calc(100% - 300px);padding:2em calc(50% - 457px - 300px / 2);margin:0;box-sizing:border-box}@media screen and (max-width:1274px){html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{padding:2em}}@media screen and (max-width:450px){html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{width:100%}}html body[for=html-export]:not([data-presentation-mode]):not([html-show-sidebar-toc]) .markdown-preview{left:50%;transform:translateX(-50%)}html body[for=html-export]:not([data-presentation-mode]):not([html-show-sidebar-toc]) .md-sidebar-toc{display:none}
  8. /* Please visit the URL below for more information: */
  9. /* https://shd101wyy.github.io/markdown-preview-enhanced/#/customize-css */
  10. </style>
  11. <!-- The content below will be included at the end of the <head> element. --><script type="text/javascript">
  12. document.addEventListener("DOMContentLoaded", function () {
  13. // your code here
  14. });
  15. </script></head><body for="html-export">
  16. <div class="crossnote markdown-preview ">
  17. <h2 id="系统架构">系统架构 </h2>
  18. <h3 id="技术选型">技术选型 </h3>
  19. <ul>
  20. <li>php8.3</li>
  21. <li>mysql8.0</li>
  22. <li>nginx</li>
  23. <li>redis</li>
  24. <li>rabbitmq</li>
  25. <li>uniapp(vue3)</li>
  26. </ul>
  27. <h3 id="一-快速后台开发解决方案">一、快速后台开发解决方案 </h3>
  28. <p></p><h4 id="1-快速开发框架选型">1. 快速开发框架选型 </h4>
  29. <ul>
  30. <li>框架名称:dcat-admin</li>
  31. <li>官方资料:
  32. <ul>
  33. <li>官网:<a href="https://github.com/jqhph/dcat-admin">https://github.com/jqhph/dcat-admin</a></li>
  34. <li>文档:<a href="https://learnku.com/docs/dcat-admin/2.x">https://learnku.com/docs/dcat-admin/2.x</a></li>
  35. </ul>
  36. </li>
  37. <li>选型原因:
  38. <ul>
  39. <li>基于laravel开发,架构优秀</li>
  40. <li>文档详细,上手快</li>
  41. <li>功能齐全,可扩展可定制能力强,二次开发成本低</li>
  42. <li>laravel文档:<a href="https://learnku.com/docs/laravel/9.x/installation/12200#1dabc3">https://learnku.com/docs/laravel/9.x/installation/12200#1dabc3</a></li>
  43. </ul>
  44. </li>
  45. </ul>
  46. <h4 id="2-安装配置步骤">2. 安装配置步骤 </h4>
  47. <ol>
  48. <li>安装bt面板等继承环境
  49. <ul>
  50. <li>安装php8.1</li>
  51. <li>安装composer2.6.6</li>
  52. <li>配置php扩展和禁用函数</li>
  53. <li>安装nginx</li>
  54. <li>安装frpc</li>
  55. <li>安装redis</li>
  56. <li>安装mysql 8.0</li>
  57. </ul>
  58. </li>
  59. <li>安装配置laravel,熟悉laravel框架</li>
  60. <li>安装dcat-admin: <a href="https://learnku.com/docs/dcat-admin/2.x/install/8081#fa405f">https://learnku.com/docs/dcat-admin/2.x/install/8081#fa405f</a></li>
  61. </ol>
  62. <h4 id="3-快速开发后台管理系统">3. 快速开发后台管理系统 </h4>
  63. <ol>
  64. <li>数据库完成评审工作后,通过scaffold生成基础模块CRUD代码</li>
  65. <li>通过scaffold生成基础模块CRUD代码</li>
  66. </ol>
  67. <ul>
  68. <li><a href="https://learnku.com/docs/dcat-admin/2.x/basic-use/8140#8b8ca1">https://learnku.com/docs/dcat-admin/2.x/basic-use/8140#8b8ca1</a></li>
  69. </ul>
  70. <ol start="3">
  71. <li>手动增加菜单</li>
  72. <li>访问查看基础效果</li>
  73. </ol>
  74. <h4 id="4-ai-prompt提示词技巧">4. AI prompt提示词技巧 </h4>
  75. <h5 id="41-调优管理界面">4.1 调优管理界面 </h5>
  76. <p>打开生成的模块ctroller或service文件,通过AI快速调优管理界面,prompt举例:</p>
  77. <pre data-role="codeBlock" data-info="" class="language-text"><code>请修改:
  78. 服务封面 -&gt; 图片
  79. 所属分类 -&gt; 下拉单选 分类列表
  80. 服务价格、原价、物料费 -&gt; 金额,单位:元
  81. 销量 -&gt; 数字,单位:单
  82. 服务时长 -&gt; 数字,单位:分
  83. 分佣比例 -&gt; 数字,单位:%
  84. 加钟服务、支持到店、支持上门 -&gt; 开关按钮
  85. 排序 -&gt; 数字
  86. 项目介绍、禁忌说明、下单须知 -&gt; 富文本编辑
  87. 其他列,隐藏
  88. 列表操作列,增加:
  89. 1. “取消订单”按钮,并参照以下逻辑实现handler:
  90. 这里面请复制你设计好的那个接口的后台逻辑描述
  91. 2. “删除”按钮,并参照以下逻辑实现handler:
  92. 这里面请复制你设计好的那个接口的后台逻辑描述
  93. </code></pre><h5 id="42-给技巧起个名字">4.2 给技巧起个名字 </h5>
  94. <blockquote>
  95. <p>待补充,研发过程中再补充,新的AI prompt提示词 技巧</p>
  96. </blockquote>
  97. <p></p>
  98. <h3 id="二-工具类库">二、工具类库 </h3>
  99. <p></p><blockquote>
  100. <p>以下工具类库,默认基于laravel框架</p>
  101. </blockquote>
  102. <blockquote>
  103. <p>开始开发前,每个项目参与者都必须对laravel、dcat中的一些模块或概念有个基本的认识。否则将无法有效提供AI提示词,则无法加快研发效率。 要求每个人在业余时间对官方文档提供的每一个功能点,做一个开发和测试,这样建立基本的认识。</p>
  104. </blockquote>
  105. <h4 id="1-事务处理">1. 事务处理 </h4>
  106. <h5 id="场景说明">场景说明 </h5>
  107. <ul>
  108. <li>
  109. <p><strong>串行化 (SERIALIZABLE)</strong>:适用于需要严格事务隔离的场景,例如银行转账,确保事务完全隔离,避免所有并发问题,但可能会影响性能。</p>
  110. </li>
  111. <li>
  112. <p><strong>可重复读 (REPEATABLE READ)</strong>:适用于需要保证在同一事务中多次读取同一数据的一致性的场景,例如库存查询和减少操作,避免在事务过程中数据被其他事务修改。</p>
  113. </li>
  114. <li>
  115. <p><strong>读已提交 (READ COMMITTED)</strong>:适用于大多数需要避免脏读的场景,每次读取都能看到其他事务的最新提交结果,但可能会出现不可重复读和幻读。</p>
  116. </li>
  117. <li>
  118. <p><strong>读未提交 (READ UNCOMMITTED)</strong>:适用于读操作对数据一致性要求不高的场景,允许读取到其他事务未提交的数据,可能会导致脏读、不可重复读和幻读。</p>
  119. </li>
  120. </ul>
  121. <h5 id="用法举例">用法举例 </h5>
  122. <pre data-role="codeBlock" data-info="php" class="language-php php"><code><span class="token comment">// 串行化 (SERIALIZABLE) - 最严格的隔离级别,完全隔离,事务串行执行</span>
  123. <span class="token keyword keyword-use">use</span> <span class="token package">Illuminate<span class="token punctuation">\</span>Support<span class="token punctuation">\</span>Facades<span class="token punctuation">\</span>DB</span><span class="token punctuation">;</span>
  124. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">transaction</span><span class="token punctuation">(</span><span class="token keyword keyword-function">function</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  125. <span class="token comment">// 操作1:读取用户A的当前余额</span>
  126. <span class="token variable">$balanceA</span> <span class="token operator">=</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">where</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'user_id'</span><span class="token punctuation">,</span> <span class="token variable">$userIdA</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">value</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'balance'</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  127. <span class="token comment">// 操作2:减少用户A的余额</span>
  128. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">where</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'user_id'</span><span class="token punctuation">,</span> <span class="token variable">$userIdA</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">decrement</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'balance'</span><span class="token punctuation">,</span> <span class="token variable">$amount</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  129. <span class="token comment">// 操作3:增加用户B的余额</span>
  130. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">where</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'user_id'</span><span class="token punctuation">,</span> <span class="token variable">$userIdB</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">increment</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'balance'</span><span class="token punctuation">,</span> <span class="token variable">$amount</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  131. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token constant">TRANSACTION_SERIALIZABLE</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  132. </code></pre><pre data-role="codeBlock" data-info="php" class="language-php php"><code><span class="token comment">// 可重复读 (REPEATABLE READ) - 保证事务中每次读取结果都相同,避免不可重复读和脏读</span>
  133. <span class="token keyword keyword-use">use</span> <span class="token package">Illuminate<span class="token punctuation">\</span>Support<span class="token punctuation">\</span>Facades<span class="token punctuation">\</span>DB</span><span class="token punctuation">;</span>
  134. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">transaction</span><span class="token punctuation">(</span><span class="token keyword keyword-function">function</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  135. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token constant">TRANSACTION_REPEATABLE_READ</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  136. </code></pre><pre data-role="codeBlock" data-info="php" class="language-php php"><code><span class="token comment">// 读已提交 (READ COMMITTED) - 每次读取只能看到其他事务已经提交的数据,避免脏读</span>
  137. <span class="token keyword keyword-use">use</span> <span class="token package">Illuminate<span class="token punctuation">\</span>Support<span class="token punctuation">\</span>Facades<span class="token punctuation">\</span>DB</span><span class="token punctuation">;</span>
  138. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">transaction</span><span class="token punctuation">(</span><span class="token keyword keyword-function">function</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  139. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token constant">TRANSACTION_READ_COMMITTED</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  140. </code></pre><pre data-role="codeBlock" data-info="php" class="language-php php"><code><span class="token comment">// 读未提交 (READ UNCOMMITTED) - 最宽松的隔离级别,可能会读取到其他事务未提交的数据(脏读)</span>
  141. <span class="token keyword keyword-use">use</span> <span class="token package">Illuminate<span class="token punctuation">\</span>Support<span class="token punctuation">\</span>Facades<span class="token punctuation">\</span>DB</span><span class="token punctuation">;</span>
  142. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">transaction</span><span class="token punctuation">(</span><span class="token keyword keyword-function">function</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  143. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token constant">TRANSACTION_READ_UNCOMMITTED</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  144. </code></pre><h5 id="事务嵌套">事务嵌套 </h5>
  145. <p>在 Laravel 中,如果你在一个 DB::transaction 回调中调用另一个也使用 DB::transaction 的方法,将会出现以下情况:</p>
  146. <pre class="language-text">嵌套事务:Laravel 支持嵌套事务。当你在事务中调用另一个事务时,Laravel 会使用保存点(Savepoints)来处理嵌套的事务。保存点允许你在事务中设置一个点,之后可以回滚到这个点,而不影响事务中之前的操作。
  147. 保存点的创建:对于每个嵌套的事务,Laravel 会创建一个保存点。如果内部事务成功提交,保存点会被释放;如果内部事务失败并回滚,只有内部事务的更改会被回滚到保存点,外部事务的其他操作不受影响。
  148. 事务的回滚:如果内部事务中抛出异常,整个内部事务会被回滚到最近的保存点。如果外部事务中抛出异常,整个外部事务(包括所有内部事务)会被回滚。
  149. </pre>
  150. <p>下面是一个示例,说明这种情况:</p>
  151. <pre data-role="codeBlock" data-info="php" class="language-php php"><code><span class="token keyword keyword-use">use</span> <span class="token package">Illuminate<span class="token punctuation">\</span>Support<span class="token punctuation">\</span>Facades<span class="token punctuation">\</span>DB</span><span class="token punctuation">;</span>
  152. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">transaction</span><span class="token punctuation">(</span><span class="token keyword keyword-function">function</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  153. <span class="token comment">// 外部事务开始</span>
  154. <span class="token comment">// 一些数据库操作</span>
  155. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">insert</span><span class="token punctuation">(</span><span class="token punctuation">[</span><span class="token operator">...</span><span class="token punctuation">]</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  156. <span class="token this keyword">$this</span><span class="token operator">-&gt;</span><span class="token function">nestedTransaction</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span> <span class="token comment">// 调用包含内部事务的方法</span>
  157. <span class="token comment">// 更多数据库操作</span>
  158. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">update</span><span class="token punctuation">(</span><span class="token punctuation">[</span><span class="token operator">...</span><span class="token punctuation">]</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  159. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token constant">TRANSACTION_SERIALIZABLE</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  160. <span class="token comment">// 包含内部事务的方法</span>
  161. <span class="token keyword keyword-protected">protected</span> <span class="token keyword keyword-function">function</span> <span class="token function-definition function">nestedTransaction</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  162. <span class="token punctuation">{</span>
  163. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">transaction</span><span class="token punctuation">(</span><span class="token keyword keyword-function">function</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  164. <span class="token comment">// 内部事务开始</span>
  165. <span class="token comment">// 一些数据库操作</span>
  166. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">insert</span><span class="token punctuation">(</span><span class="token punctuation">[</span><span class="token operator">...</span><span class="token punctuation">]</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  167. <span class="token comment">// 假设这里发生了错误,内部事务会回滚</span>
  168. <span class="token keyword keyword-throw">throw</span> <span class="token keyword keyword-new">new</span> <span class="token class-name">Exception</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'Something went wrong!'</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  169. <span class="token comment">// 更多数据库操作,如果内部事务成功,这些操作会执行</span>
  170. <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token function">table</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'accounts'</span><span class="token punctuation">)</span><span class="token operator">-&gt;</span><span class="token function">update</span><span class="token punctuation">(</span><span class="token punctuation">[</span><span class="token operator">...</span><span class="token punctuation">]</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  171. <span class="token punctuation">}</span><span class="token punctuation">,</span> <span class="token scope">DB<span class="token punctuation">::</span></span><span class="token constant">TRANSACTION_SERIALIZABLE</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  172. <span class="token punctuation">}</span>
  173. </code></pre><blockquote>
  174. <p>在这个例子中,如果 nestedTransaction 方法中的内部事务因为抛出异常而失败,只有内部事务中的操作会被回滚。外部事务中的操作(在调用 nestedTransaction 之前和之后的操作)不会受到影响,除非外部事务本身抛出异常。</p>
  175. </blockquote>
  176. <h4 id="2-队列处理">2. 队列处理 </h4>
  177. <p><a href="https://learnku.com/docs/laravel/9.x/queues/12236#0796f7">参考laravel官方文档</a></p>
  178. <h4 id="3-缓存处理">3. 缓存处理 </h4>
  179. <p><a href="https://learnku.com/docs/laravel/9.x/redis/12250#e11144">参考laravel官方文档</a></p>
  180. <h4 id="4-日志记录">4. 日志记录 </h4>
  181. <p><a href="https://learnku.com/docs/laravel/9.x/logging/12237#0796f7">参考laravel官方文档</a></p>
  182. <h4 id="5-其他请参考官方文档">5. 其他请参考官方文档 </h4>
  183. <p><a href="https://learnku.com/docs/laravel/9.x">laravel官方文档</a></p>
  184. <p><a href="https://learnku.com/docs/dcat-admin/2.x">dcat文档</a></p>
  185. <p></p>
  186. <h3 id="websocket解决方案">WebSocket解决方案 </h3>
  187. <p></p><blockquote>
  188. <p>WebSocket解决方案</p>
  189. </blockquote>
  190. <p></p>
  191. <h3 id="swaggerapi文档解决方案">SwaggerAPI文档解决方案 </h3>
  192. <p></p><blockquote>
  193. <p>SwaggerAPI文档解决方案</p>
  194. </blockquote>
  195. <p></p>
  196. <h3 id="多级配置参数设置解决方案">多级配置参数设置解决方案 </h3>
  197. <p></p><blockquote>
  198. <p>多级配置参数设置解决方案</p>
  199. </blockquote>
  200. <p></p>
  201. <h3 id="统一支付汇付天下解决方案">统一支付(汇付天下)解决方案 </h3>
  202. <p></p><blockquote>
  203. <p>统一支付(汇付天下)解决方案</p>
  204. </blockquote>
  205. <p></p>
  206. <h3 id="基于lbs的near算法解决方案">基于LBS的Near算法解决方案 </h3>
  207. <p></p><blockquote>
  208. <p>基于LBS的Near算法解决方案</p>
  209. </blockquote>
  210. <ul>
  211. <li>方案一:使用redis geo 实现</li>
  212. <li>方案二:使用mysql空间扩展,实现geohash与mysql索引结合,实现附近技师检索。</li>
  213. <li>方案三:使用第三方地图API,实现附近技师检索。</li>
  214. </ul>
  215. <p></p>
  216. <h3 id="技师抢单解决方案">技师抢单解决方案 </h3>
  217. <p></p><blockquote>
  218. <p>技师抢单解决方案</p>
  219. </blockquote>
  220. <p></p>
  221. <h3 id="订单状态机解决方案">订单状态机解决方案 </h3>
  222. <p></p><blockquote>
  223. <p>订单状态机解决方案</p>
  224. </blockquote>
  225. <ul>
  226. <li>方案一:使用laravel-state-machine实现</li>
  227. <li>方案二:使用php-enum实现</li>
  228. <li>方案三:使用数据库实现</li>
  229. <li>方案四:使用laravel-activitylog实现</li>
  230. </ul>
  231. <p></p>
  232. <h3 id="技师排班的解决方案技师排班的解决方案html"><a href="./%E6%8A%80%E5%B8%88%E6%8E%92%E7%8F%AD%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88.html">技师排班的解决方案</a> </h3>
  233. <h3 id="saas多租户解决方案">SaaS多租户解决方案 </h3>
  234. <p></p><blockquote>
  235. <p>SaaS多租户解决方案</p>
  236. </blockquote>
  237. <ul>
  238. <li>方案一:使用laravel-tenancy实现</li>
  239. <li>方案二:使用database实现</li>
  240. </ul>
  241. <p></p>
  242. <h3 id="告警监控解决方案">告警监控解决方案 </h3>
  243. <p></p><blockquote>
  244. <p>告警监控解决方案</p>
  245. </blockquote>
  246. <ul>
  247. <li>方案一:使用laravel-monitor实现</li>
  248. <li>方案二:使用laravel-health实现</li>
  249. </ul>
  250. <p></p>
  251. </div>
  252. <div class="md-sidebar-toc">
  253. <div class="md-toc">
  254. <details style="padding:0;;padding-left:0px;" open="">
  255. <summary class="md-toc-link-wrapper">
  256. <a href="#系统架构" class="md-toc-link"><p>系统架构</p>
  257. </a>
  258. </summary>
  259. <div>
  260. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  261. <a href="#技术选型" class="md-toc-link">
  262. <p>技术选型</p>
  263. </a></div><details style="padding:0;;padding-left:24px;" open="">
  264. <summary class="md-toc-link-wrapper">
  265. <a href="#一-快速后台开发解决方案" class="md-toc-link"><p>一、快速后台开发解决方案</p>
  266. </a>
  267. </summary>
  268. <div>
  269. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  270. <a href="#1-快速开发框架选型" class="md-toc-link">
  271. <ol>
  272. <li>快速开发框架选型</li>
  273. </ol>
  274. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  275. <a href="#2-安装配置步骤" class="md-toc-link">
  276. <ol start="2">
  277. <li>安装配置步骤</li>
  278. </ol>
  279. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  280. <a href="#3-快速开发后台管理系统" class="md-toc-link">
  281. <ol start="3">
  282. <li>快速开发后台管理系统</li>
  283. </ol>
  284. </a></div><details style="padding:0;;padding-left:24px;" open="">
  285. <summary class="md-toc-link-wrapper">
  286. <a href="#4-ai-prompt提示词技巧" class="md-toc-link"><ol start="4">
  287. <li>AI prompt提示词技巧</li>
  288. </ol>
  289. </a>
  290. </summary>
  291. <div>
  292. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  293. <a href="#41-调优管理界面" class="md-toc-link">
  294. <p>4.1 调优管理界面</p>
  295. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  296. <a href="#42-给技巧起个名字" class="md-toc-link">
  297. <p>4.2 给技巧起个名字</p>
  298. </a></div>
  299. </div>
  300. </details>
  301. </div>
  302. </details>
  303. <details style="padding:0;;padding-left:24px;" open="">
  304. <summary class="md-toc-link-wrapper">
  305. <a href="#二-工具类库" class="md-toc-link"><p>二、工具类库</p>
  306. </a>
  307. </summary>
  308. <div>
  309. <details style="padding:0;;padding-left:24px;" open="">
  310. <summary class="md-toc-link-wrapper">
  311. <a href="#1-事务处理" class="md-toc-link"><ol>
  312. <li>事务处理</li>
  313. </ol>
  314. </a>
  315. </summary>
  316. <div>
  317. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  318. <a href="#场景说明" class="md-toc-link">
  319. <p>场景说明</p>
  320. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  321. <a href="#用法举例" class="md-toc-link">
  322. <p>用法举例</p>
  323. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  324. <a href="#事务嵌套" class="md-toc-link">
  325. <p>事务嵌套</p>
  326. </a></div>
  327. </div>
  328. </details>
  329. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  330. <a href="#2-队列处理" class="md-toc-link">
  331. <ol start="2">
  332. <li>队列处理</li>
  333. </ol>
  334. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  335. <a href="#3-缓存处理" class="md-toc-link">
  336. <ol start="3">
  337. <li>缓存处理</li>
  338. </ol>
  339. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  340. <a href="#4-日志记录" class="md-toc-link">
  341. <ol start="4">
  342. <li>日志记录</li>
  343. </ol>
  344. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  345. <a href="#5-其他请参考官方文档" class="md-toc-link">
  346. <ol start="5">
  347. <li>其他请参考官方文档</li>
  348. </ol>
  349. </a></div>
  350. </div>
  351. </details>
  352. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  353. <a href="#websocket解决方案" class="md-toc-link">
  354. <p>WebSocket解决方案</p>
  355. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  356. <a href="#swaggerapi文档解决方案" class="md-toc-link">
  357. <p>SwaggerAPI文档解决方案</p>
  358. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  359. <a href="#多级配置参数设置解决方案" class="md-toc-link">
  360. <p>多级配置参数设置解决方案</p>
  361. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  362. <a href="#统一支付汇付天下解决方案" class="md-toc-link">
  363. <p>统一支付(汇付天下)解决方案</p>
  364. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  365. <a href="#基于lbs的near算法解决方案" class="md-toc-link">
  366. <p>基于LBS的Near算法解决方案</p>
  367. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  368. <a href="#技师抢单解决方案" class="md-toc-link">
  369. <p>技师抢单解决方案</p>
  370. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  371. <a href="#订单状态机解决方案" class="md-toc-link">
  372. <p>订单状态机解决方案</p>
  373. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  374. <a href="#技师排班的解决方案技师排班的解决方案html" class="md-toc-link">
  375. </a><p><a href="#技师排班的解决方案技师排班的解决方案html" class="md-toc-link"></a><a href="./%E6%8A%80%E5%B8%88%E6%8E%92%E7%8F%AD%E7%9A%84%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88.html">技师排班的解决方案</a></p>
  376. </div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  377. <a href="#saas多租户解决方案" class="md-toc-link">
  378. <p>SaaS多租户解决方案</p>
  379. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  380. <a href="#告警监控解决方案" class="md-toc-link">
  381. <p>告警监控解决方案</p>
  382. </a></div>
  383. </div>
  384. </details>
  385. </div>
  386. </div>
  387. <a id="sidebar-toc-btn">≡</a>
  388. <script>
  389. document.body.setAttribute('html-show-sidebar-toc', true)
  390. var sidebarTOCBtn = document.getElementById('sidebar-toc-btn')
  391. sidebarTOCBtn.addEventListener('click', function(event) {
  392. event.stopPropagation()
  393. if (document.body.hasAttribute('html-show-sidebar-toc')) {
  394. document.body.removeAttribute('html-show-sidebar-toc')
  395. } else {
  396. document.body.setAttribute('html-show-sidebar-toc', true)
  397. }
  398. })
  399. </script>
  400. </body></html>