[{"data":1,"prerenderedAt":3830},["ShallowReactive",2],{"search-docs":3,"doc-\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic":886},[4,8,12,16,20,24,28,32,36,40,44,48,52,56,60,64,68,72,76,80,84,88,92,96,100,104,108,112,116,120,124,128,132,136,140,144,148,152,156,159,162,165,169,172,175,178,182,186,190,194,198,202,206,210,214,218,222,226,230,234,238,242,246,250,254,258,262,266,269,273,277,281,285,288,291,294,298,301,304,307,310,313,316,319,322,325,329,332,336,340,344,348,352,356,359,362,365,368,371,374,377,380,383,386,389,393,396,399,402,405,408,411,414,417,420,424,428,432,435,438,442,446,450,454,458,462,466,470,474,477,480,483,487,491,494,497,500,504,507,511,515,518,521,524,527,530,533,536,539,542,545,548,551,554,557,560,563,566,569,572,575,579,583,587,591,595,599,603,606,610,614,617,620,623,626,629,633,637,640,643,646,649,652,655,658,661,664,667,670,673,676,679,682,685,688,691,694,697,700,703,706,709,712,716,720,724,728,732,736,740,744,748,752,756,760,764,768,772,775,779,783,787,790,793,796,799,802,805,808,811,814,818,822,825,829,832,835,838,841,844,848,851,854,858,862,865,869,873,876,879,882],{"path":5,"title":6,"description":7},"\u002Fabout\u002Fauthor","作者相关","只想纯粹的做一个程序员...",{"path":9,"title":10,"description":11},"\u002Fabout\u002Fjourney","心路历程","",{"path":13,"title":14,"description":15},"\u002Fai\u002Fagent\u002Fframeworks","Agent 框架","主流 Agent 框架：LangChain、LlamaIndex、AutoGen、CrewAI",{"path":17,"title":18,"description":19},"\u002Fai\u002Fagent\u002Fhooks","Agent Hooks 与自动化","Claude Agent 的 Hooks 生命周期、事件类型、典型自动化场景",{"path":21,"title":22,"description":23},"\u002Fai\u002Fagent\u002Fintroduction","AI Agent 概述","AI Agent 核心概念：感知、规划、执行、记忆",{"path":25,"title":26,"description":27},"\u002Fai\u002Fagent\u002Fpractice","Agent 实战","AI Agent 实战：构建自主任务执行系统",{"path":29,"title":30,"description":31},"\u002Fai\u002Fagent\u002Fsdk","Claude Agent SDK 开发","使用 Claude Agent SDK 构建自定义 AI Agent：架构、API、生命周期",{"path":33,"title":34,"description":35},"\u002Fai\u002Fagent\u002Fsubagents","Subagents 子代理","用 Subagents 分解复杂任务、并发执行、隔离上下文",{"path":37,"title":38,"description":39},"\u002Fai\u002Fagent\u002Ftool-use","工具调用","AI Agent 工具调用：Function Calling、Tool Use 原理与实践",{"path":41,"title":42,"description":43},"\u002Fai\u002Ffundamentals\u002Fdeep-learning","深度学习入门","深度学习基础知识：前向传播、反向传播、损失函数、优化器",{"path":45,"title":46,"description":47},"\u002Fai\u002Ffundamentals\u002Fml-basics","机器学习基础","机器学习核心概念：监督学习、无监督学习、强化学习",{"path":49,"title":50,"description":51},"\u002Fai\u002Ffundamentals\u002Fneural-networks","神经网络原理","神经网络架构：CNN、RNN、注意力机制",{"path":53,"title":54,"description":55},"\u002Fai\u002Fgetting-started","AI 学习路线","AI 技术学习路线图，从基础到实战的完整指南",{"path":57,"title":58,"description":59},"\u002Fai\u002Fllm\u002Ffine-tuning","模型微调","大模型微调技术：LoRA、QLoRA、全量微调、RLHF",{"path":61,"title":62,"description":63},"\u002Fai\u002Fllm\u002Fintroduction","大模型概述","大语言模型发展历程、核心能力与主流模型对比",{"path":65,"title":66,"description":67},"\u002Fai\u002Fllm\u002Flocal-deploy","本地部署","大模型本地部署：Ollama、vLLM、llama.cpp",{"path":69,"title":70,"description":71},"\u002Fai\u002Fllm\u002Ftransformer","Transformer 架构","Transformer 架构详解：自注意力机制、位置编码、多头注意力",{"path":73,"title":74,"description":75},"\u002Fai\u002Fmcp\u002Fclient","MCP Client 开发","MCP Client 开发指南：连接、调用、集成",{"path":77,"title":78,"description":79},"\u002Fai\u002Fmcp\u002Fdebugging","MCP 调试与排错","MCP Server 开发与集成过程中的常见问题、日志分析、诊断工具",{"path":81,"title":82,"description":83},"\u002Fai\u002Fmcp\u002Fintroduction","MCP 概述","Model Context Protocol 协议概述：架构、核心概念、应用场景",{"path":85,"title":86,"description":87},"\u002Fai\u002Fmcp\u002Fserver","MCP Server 开发","MCP Server 开发指南：资源、工具、提示词的实现",{"path":89,"title":90,"description":91},"\u002Fai\u002Fmcp\u002Ftools","MCP Tools 深入","深入理解 MCP Tools：与 Resources\u002FPrompts 的差异、Schema 设计、Annotations 与权限控制",{"path":93,"title":94,"description":95},"\u002Fai\u002Fprompt\u002Fadvanced","高级 Prompt 模式","高级 Prompt 设计模式：Tree-of-Thought、自我反思、多轮对话策略",{"path":97,"title":98,"description":99},"\u002Fai\u002Fprompt\u002Fbasics","Prompt 基础","Prompt Engineering 入门：基本概念、角色设定、输出格式控制",{"path":101,"title":102,"description":103},"\u002Fai\u002Fprompt\u002Ftechniques","提示词技巧","常用提示词技巧：Few-shot、Chain-of-Thought、ReAct",{"path":105,"title":106,"description":107},"\u002Fai\u002Frag\u002Fembedding","文本嵌入","文本嵌入模型：Embedding 原理、模型选择、相似度计算",{"path":109,"title":110,"description":111},"\u002Fai\u002Frag\u002Fintroduction","RAG 概述","检索增强生成（RAG）架构原理、优势与应用场景",{"path":113,"title":114,"description":115},"\u002Fai\u002Frag\u002Fpractice","RAG 实战","RAG 应用实战：文档问答系统、知识库搭建",{"path":117,"title":118,"description":119},"\u002Fai\u002Frag\u002Fvector-database","向量数据库","主流向量数据库对比：Milvus、Pinecone、Chroma、Weaviate",{"path":121,"title":122,"description":123},"\u002Fai\u002Fskills\u002Fbest-practices","Skill 最佳实践","编写高质量 Skill 的设计原则、常见陷阱与优化技巧",{"path":125,"title":126,"description":127},"\u002Fai\u002Fskills\u002Fcreating","创建自定义 Skill","从零编写一个可被 Agent 自动发现和调用的 Skill",{"path":129,"title":130,"description":131},"\u002Fai\u002Fskills\u002Fintroduction","Agent Skills 概述","Claude Agent Skills 概念、工作原理、与 Tools\u002FMCP 的区别",{"path":133,"title":134,"description":135},"\u002Fgolang\u002Fadvanced\u002Fconcurrency","Go - 并发深入","深入理解 Go 并发编程的核心机制。",{"path":137,"title":138,"description":139},"\u002Fgolang\u002Fadvanced\u002Fgc","Go - 垃圾回收","理解 Go 的垃圾回收机制，掌握 GC 调优方法。",{"path":141,"title":142,"description":143},"\u002Fgolang\u002Fadvanced\u002Fgmp","Go - GMP 调度模型","GMP 是 Go 运行时调度器的核心模型，理解它对于编写高性能 Go 程序至关重要。",{"path":145,"title":146,"description":147},"\u002Fgolang\u002Fadvanced\u002Fgo-concurrency","Go - 并发编程","Go 的并发是其核心特性之一，通过 Goroutine 和 Channel 实现。",{"path":149,"title":150,"description":151},"\u002Fgolang\u002Fadvanced\u002Fmemory","Go - 内存模型","理解 Go 的内存分配机制和内存模型。",{"path":153,"title":154,"description":155},"\u002Fgolang\u002Fadvanced\u002Fprofiling","Go - 性能分析","掌握 Go 的性能分析工具：pprof、trace、benchmark。",{"path":157,"title":158,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-basic","Go - 基础语法",{"path":160,"title":161,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-composite","Go - 复合类型",{"path":163,"title":164,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-control","Go - 流程控制",{"path":166,"title":167,"description":168},"\u002Fgolang\u002Fcore\u002Fgo-error","Go - 错误处理","Go 使用显式的错误返回值来处理错误，而不是异常机制。",{"path":170,"title":171,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-function","Go - 函数",{"path":173,"title":174,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-install","Go - 环境搭建",{"path":176,"title":177,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-interface","Go - 接口",{"path":179,"title":180,"description":181},"\u002Fgolang\u002Fcore\u002Fgo-module","Go - 包管理","Go Modules 是 Go 1.11 引入的官方依赖管理方案，Go 1.16 后成为默认模式。",{"path":183,"title":184,"description":185},"\u002Fgolang\u002Fdistributed\u002Fgrpc","Go - gRPC","gRPC 是 Google 开发的高性能 RPC 框架，使用 Protocol Buffers 作为序列化协议。",{"path":187,"title":188,"description":189},"\u002Fgolang\u002Fdistributed\u002Fmicroservice","Go - 微服务","微服务架构的核心组件：服务发现、负载均衡、熔断降级。",{"path":191,"title":192,"description":193},"\u002Fgolang\u002Fdistributed\u002Fmq","Go - 消息队列","使用 Go 操作 Kafka 和 RabbitMQ。",{"path":195,"title":196,"description":197},"\u002Fgolang\u002Fdistributed\u002Fredis","Go - Redis","使用 go-redis 操作 Redis，实现缓存、分布式锁等功能。",{"path":199,"title":200,"description":201},"\u002Fgolang\u002Fengineering\u002Fconfig","Go - 配置管理","使用 viper 进行配置管理，支持多种配置格式和配置中心。",{"path":203,"title":204,"description":205},"\u002Fgolang\u002Fengineering\u002Fdocker","Go - Docker 部署","使用 Docker 容器化部署 Go 应用。",{"path":207,"title":208,"description":209},"\u002Fgolang\u002Fengineering\u002Fkubernetes","Go - Kubernetes 部署","在 Kubernetes 上部署和管理 Go 应用。",{"path":211,"title":212,"description":213},"\u002Fgolang\u002Fengineering\u002Flogging","Go - 日志系统","使用 zap 和 logrus 构建高性能结构化日志系统。",{"path":215,"title":216,"description":217},"\u002Fgolang\u002Fengineering\u002Ftesting","Go - 单元测试","Go 内置了强大的测试框架，掌握测试是编写高质量代码的基础。",{"path":219,"title":220,"description":221},"\u002Fgolang\u002Fstdlib\u002Fbufio","bufio","在 Go 语言中，bufio 包提供了带缓冲的 I\u002FO 操作，能够提高读写性能。以下是一些常用的 bufio 包 API 及其详细说明：",{"path":223,"title":224,"description":225},"\u002Fgolang\u002Fstdlib\u002Fcontainer","container","在Go语言标准库中，container 包提供了几种常用的数据结构实现，这些数据结构对于高效地管理和操作数据非常有用。以下是 container 包中主要的数据结构：",{"path":227,"title":228,"description":229},"\u002Fgolang\u002Fstdlib\u002Fcrypto","crypto","在 Go 语言中，crypto 包提供了一组用于加密和解密的功能。以下是一些常用的 crypto 包及其子包的 API 及其详细说明：",{"path":231,"title":232,"description":233},"\u002Fgolang\u002Fstdlib\u002Fencoding-csv","encoding\u002Fcsv","在 Go 语言中，encoding\u002Fcsv 包提供了对 CSV（逗号分隔值）文件进行读写的功能。以下是一些常用的 encoding\u002Fcsv 包的 API 及其详细说明：",{"path":235,"title":236,"description":237},"\u002Fgolang\u002Fstdlib\u002Fencoding-json","encoding\u002Fjson","在 Go 语言中，encoding\u002Fjson 包提供了对 JSON 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fjson 包的 API 及其详细说明：",{"path":239,"title":240,"description":241},"\u002Fgolang\u002Fstdlib\u002Fencoding-xml","encoding\u002Fxml","在 Go 语言中，encoding\u002Fxml 包提供了对 XML 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fxml 包的 API 及其详细说明：",{"path":243,"title":244,"description":245},"\u002Fgolang\u002Fstdlib\u002Fflag","flag","在Go语言中，flag 包是用于处理命令行参数的标准库，它提供了一种简单而直接的方式来解析和使用命令行参数。下面是关于 flag 包的一些基本介绍和常用功能：",{"path":247,"title":248,"description":249},"\u002Fgolang\u002Fstdlib\u002Ffmt","fmt","在 Go 语言的标准库中，fmt 包是非常重要的，它提供了处理格式化输入和输出的基本工具。以下是一些 fmt 包内常用的API：",{"path":251,"title":252,"description":253},"\u002Fgolang\u002Fstdlib\u002Fhttp","net\u002Fhttp","在 Go 语言中，net\u002Fhttp 包提供了用于构建 HTTP 客户端和服务器的强大工具。以下是一些常用的 net\u002Fhttp 包的 API 及其详细说明：",{"path":255,"title":256,"description":257},"\u002Fgolang\u002Fstdlib\u002Fio","io","在 Go 语言中，io 包提供了基本的输入输出功能。以下是一些常用的 io 包的 API 及其详细说明：",{"path":259,"title":260,"description":261},"\u002Fgolang\u002Fstdlib\u002Flog","log","在 Go 语言中，log 包提供了简单的日志记录功能。以下是一些常用的 log 包的 API 及其详细说明：",{"path":263,"title":264,"description":265},"\u002Fgolang\u002Fstdlib\u002Fmath","math","在 Go 语言中，math 包提供了基本的数学函数和常量。以下是一些常用的 math 包的 API 及其详细说明：",{"path":267,"title":268,"description":11},"\u002Fgolang\u002Fstdlib\u002Fnet","net",{"path":270,"title":271,"description":272},"\u002Fgolang\u002Fstdlib\u002Fos","os","在Go语言中，os 包是一个非常重要且常用的标准库，它提供了与操作系统交互的功能，包括文件操作、环境变量管理、进程管理等。下面是一些 os 包中常用的功能和API：",{"path":274,"title":275,"description":276},"\u002Fgolang\u002Fstdlib\u002Fsort","order","在 Go 语言中，sort 包提供了对切片和用户定义的集合进行排序的函数。它实现了常见的排序算法，如快速排序（Quicksort）和堆排序（Heapsort），并且为自定义集合提供了接口，使得用户可以根据特定的需求进行排序。",{"path":278,"title":279,"description":280},"\u002Fgolang\u002Fstdlib\u002Fstrconv","strconv","在 Go 语言中，strconv 包提供了字符串和基本数据类型之间的转换函数，例如将整数转换为字符串、字符串转换为整数，以及其他类型之间的转换。这些功能非常有用，特别是在处理用户输入或从外部数据源读取数据时。",{"path":282,"title":283,"description":284},"\u002Fgolang\u002Fstdlib\u002Ftime","time","在 Go 语言中，time 包提供了处理时间和日期的功能。以下是一些常用的 time 包的 API 及其详细说明：",{"path":286,"title":287,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ferror","Gin - 错误处理",{"path":289,"title":290,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ffile","Gin - 文件处理",{"path":292,"title":293,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fmiddleware","Gin - 中间件",{"path":295,"title":296,"description":297},"\u002Fgolang\u002Fweb\u002Fgin\u002Fquickstart","Gin - 快速开始","Gin 是目前最流行的 Go Web 框架，以高性能和简洁 API 著称。",{"path":299,"title":300,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frequest","Gin - 请求处理",{"path":302,"title":303,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fresponse","Gin - 响应处理",{"path":305,"title":306,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frouter","Gin - 路由",{"path":308,"title":309,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fvalidation","Gin - 参数校验",{"path":311,"title":312,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fassociation","GORM - 关联关系",{"path":314,"title":315,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fcrud","GORM - CRUD 操作",{"path":317,"title":318,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fmodel","GORM - 模型定义",{"path":320,"title":321,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fperformance","GORM - 日志与性能",{"path":323,"title":324,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquery","GORM - 高级查询",{"path":326,"title":327,"description":328},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquickstart","GORM - 快速开始","GORM 是 Go 语言最流行的 ORM 库，功能强大，使用简单。",{"path":330,"title":331,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Ftransaction","GORM - 事务与 Hook",{"path":333,"title":334,"description":335},"\u002Finterview\u002Fbasic","计算机基础面经","本章节汇总了面试中常见的通用技术概念，不局限于特定语言或数据库，是考察技术内功的关键考点。",{"path":337,"title":338,"description":339},"\u002Finterview\u002Fgolang","Golang 面试题","Go 语言面试高频考点，覆盖基础语法、数据结构、并发编程、内存管理、GC、调度器等核心知识。",{"path":341,"title":342,"description":343},"\u002Finterview\u002Fk8s","Kubernetes 面试题","Kubernetes（K8s）面试高频考点，覆盖架构原理、核心资源、网络存储、调度策略、运维监控等核心知识。",{"path":345,"title":346,"description":347},"\u002Finterview\u002Fmysql","MySQL 面试题","MySQL 数据库面试高频考点，覆盖索引、事务、锁、优化、主从复制等核心知识。",{"path":349,"title":350,"description":351},"\u002Finterview\u002Fredis","Redis 面试题","Redis 面试高频考点，覆盖数据结构、持久化、集群、缓存一致性、性能优化等核心知识。",{"path":353,"title":354,"description":355},"\u002Finterview\u002Frocketmq","RocketMQ 面试题","RocketMQ 面试高频考点，覆盖消息模型、可靠性、顺序消息、事务消息、存储与高可用等核心知识。",{"path":357,"title":358,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-arraylist","List - ArrayList 源码解析",{"path":360,"title":361,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-linkedlist","List - LinkedList 源码解析",{"path":363,"title":364,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-stack","List - Satck源码解析",{"path":366,"title":367,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-vectore","List - Vector 源码解析",{"path":369,"title":370,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-hashmap","Map - HashMap 源码解析",{"path":372,"title":373,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-linkedhashmap","Map - LinkedHashMap 源码解析",{"path":375,"title":376,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-treemap","Map - TreeMap 源码解析",{"path":378,"title":379,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-deque","Queue - Deque 接口解析",{"path":381,"title":382,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-queue","Queue - Queue 接口解析",{"path":384,"title":385,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-hashset","Set - HashSet源码解析",{"path":387,"title":388,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-linkedhashset","Set - LinkedHashSet 源码解析",{"path":390,"title":391,"description":392},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-treeset","Set - TreeSet源码解析","TreeSet 是一个 Set 集合接口的实现类，与 HashSet 类似，其底层也是通过维护了一个 TreeMap 对象来封装了一些实现方法，故本篇不再对 TreeSet 的底层原理进行详细说明，仅对常用 API 做简单介绍，如需了解 TreeMap 的底层实现原理，请移步 Map - HashMap 源码解析",{"path":394,"title":395,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fannotation","Java核心 - 注解",{"path":397,"title":398,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fbasic-grammar","Java核心 - 基础语法",{"path":400,"title":401,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fclass-and-object","Java核心 - 面向对象",{"path":403,"title":404,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fcommon-classes","Java核心 - 常用类",{"path":406,"title":407,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fexception","Java核心 - 异常处理",{"path":409,"title":410,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fgenerics","Java核心 - 泛型",{"path":412,"title":413,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fjdk-env-path","Java核心 - 环境搭建",{"path":415,"title":416,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Freflection","Java核心 - 反射",{"path":418,"title":419,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fstring","Java核心 - String 字符串",{"path":421,"title":422,"description":423},"\u002Fother\u002Fjava\u002Fio\u002Fbuffer-stream","Java IO - 缓冲流","缓冲流是对基本流的包装，通过内置缓冲区减少系统调用次数，大幅提升读写效率。",{"path":425,"title":426,"description":427},"\u002Fother\u002Fjava\u002Fio\u002Fbyte-stream","Java IO - 字节流","字节流是 Java IO 中最基本的流类型，以字节（byte）为单位进行数据读写，可以处理任意类型的文件。",{"path":429,"title":430,"description":431},"\u002Fother\u002Fjava\u002Fio\u002Fchar-stream","Java IO - 字符流","字符流以字符为单位进行读写，专门用于处理文本文件。相比字节流，字符流能够正确处理字符编码，避免中文乱码问题。",{"path":433,"title":434,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Ffile","Java IO - File 类",{"path":436,"title":437,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Fio-stream-system","Java IO - IO流概述",{"path":439,"title":440,"description":441},"\u002Fother\u002Fjava\u002Fio\u002Fnio","Java IO - NIO","NIO（New IO）是 JDK 1.4 引入的新 IO 模型，提供了更高效的 IO 操作方式，支持非阻塞 IO 和多路复用。",{"path":443,"title":444,"description":445},"\u002Fother\u002Fjava\u002Fjvm\u002Fclass-loading","类加载机制","类加载机制是 JVM 将 .class 文件加载到内存，并对数据进行校验、转换解析和初始化，最终形成可被 JVM 直接使用的 Java 类型的过程。",{"path":447,"title":448,"description":449},"\u002Fother\u002Fjava\u002Fjvm\u002Fgarbage-collection","垃圾回收","垃圾回收（Garbage Collection，GC）是 JVM 自动管理内存的机制，负责回收不再使用的对象所占用的内存。",{"path":451,"title":452,"description":453},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-memory","JVM 内存结构","JVM 在执行 Java 程序时，会把它管理的内存划分为若干个不同的数据区域。这些区域有各自的用途、创建和销毁时间。",{"path":455,"title":456,"description":457},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-tuning","JVM 调优","JVM 调优是优化 Java 应用性能的重要手段，主要包括参数配置、性能监控和问题排查。",{"path":459,"title":460,"description":461},"\u002Fother\u002Fjava\u002Fthread\u002Fatomic","原子类","Java 原子类（Atomic Classes）提供了一种无锁的线程安全方式，基于 CAS（Compare-And-Swap）操作实现。",{"path":463,"title":464,"description":465},"\u002Fother\u002Fjava\u002Fthread\u002Fcompletable-future","CompletableFuture","CompletableFuture 是 JDK 8 引入的异步编程工具，实现了 Future 和 CompletionStage 接口，支持函数式编程和链式调用。",{"path":467,"title":468,"description":469},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-collections","并发集合","Java 并发包提供了多种线程安全的集合类，用于替代传统的同步集合（如 Collections.synchronizedList）。",{"path":471,"title":472,"description":473},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-utils","并发工具类","Java 并发包提供了多种实用的并发工具类，用于控制线程之间的协调与同步。",{"path":475,"title":476,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fsynchronized-lock","同步机制",{"path":478,"title":479,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-basic","线程基础",{"path":481,"title":482,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-pool","线程池",{"path":484,"title":485,"description":486},"\u002Fother\u002Fspring-series\u002Fspring\u002Fannotations-beans","Spring - 基于注解管理Bean","从 Java 5 开始，Java 增加了对注解（Annotation）的支持，它是代码中的一种特殊标记，可以在编译、类加载和运行时被读取，执行相应的处理。开发人员可以通过注解在不改变原有代码和逻辑的情况下，在源代码中嵌入补充信息。",{"path":488,"title":489,"description":490},"\u002Fother\u002Fspring-series\u002Fspring\u002Fimplement-ioc","Spring - 原理手写IoC","Spring 框架的 IOC 是基于 Java 反射机制实现的，在学习手写 IoC 之前，你需要具备一定的 Java 反射相关的知识，参考本站内的 Java 教程。",{"path":492,"title":493,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fintroduction-case","Spring - 入门案例",{"path":495,"title":496,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aop","Spring - 面向切面AOP",{"path":498,"title":499,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aot","Spring - AOT提前编译",{"path":501,"title":502,"description":503},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-data-validation","Spring - 数据校验","在开发中，我们经常遇到参数校验的需求，比如用户注册的时候，要校验用户名不能为空、用户名长度不超过20个字符、手机号是合法的手机号格式等等。如果使用普通方式，我们会把校验的代码和真正的业务处理逻辑耦合在一起，而且如果未来要新增一种校验逻辑也需要在修改多个地方。而spring validation允许通过注解的方式来定义对象校验规则，把校验和业务逻辑分离开，让代码编写更加方便。Spring Validation其实就是对Hibernate Validator进一步的封装，方便在Spring中使用。",{"path":505,"title":506,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-i18n","Spring - 国际化i18n",{"path":508,"title":509,"description":510},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-ioc","Spring - IOC容器","IoC 是 Inversion of Control 的简写，译为“控制反转”，它不是一门技术，而是一种设计思想，是一个重要的面向对象编程法则，能够指导我们如何设计出松耦合、更优良的程序。",{"path":512,"title":513,"description":514},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-junit","Spring - 单元测试JUnit","在之前的测试方法中，几乎都能看到以下的两行代码：",{"path":516,"title":517,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-resources","Spring - 资源操作",{"path":519,"title":520,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-summarize","Spring - Spring概述",{"path":522,"title":523,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-transaction","Spring - 事务",{"path":525,"title":526,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fxml-beans","Spring - 基于XML管理Bean",{"path":528,"title":529,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-config","SpringBoot - 配置详解",{"path":531,"title":532,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-data","SpringBoot - 数据访问",{"path":534,"title":535,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-quickstart","SpringBoot - 快速入门",{"path":537,"title":538,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-web","SpringBoot - Web 开发",{"path":540,"title":541,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-config","SpringCloud - 配置中心",{"path":543,"title":544,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-discovery","SpringCloud - 服务注册与发现",{"path":546,"title":547,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-feign","SpringCloud - 服务调用",{"path":549,"title":550,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-gateway","SpringCloud - 服务网关",{"path":552,"title":553,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-introduction","SpringCloud - 微服务概述",{"path":555,"title":556,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-sentinel","SpringCloud - 服务保护",{"path":558,"title":559,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-databind","SpringMVC - 数据绑定与转换",{"path":561,"title":562,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-exception","SpringMVC - 异常处理",{"path":564,"title":565,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-interceptor","SpringMVC - 拦截器",{"path":567,"title":568,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-introduction","SpringMVC - 简介与环境搭建",{"path":570,"title":571,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-request","SpringMVC - 请求处理",{"path":573,"title":574,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-response","SpringMVC - 响应处理",{"path":576,"title":577,"description":578},"\u002Fproject\u002Frocket-leaf\u002Farchitecture","项目架构","Rocket-Leaf 的目录结构、模块划分、数据流向，以及各层之间的依赖关系。",{"path":580,"title":581,"description":582},"\u002Fproject\u002Frocket-leaf\u002Fbackend-layers","后端分层设计","Rocket-Leaf 的 model \u002F rocketmq \u002F service 三层结构，以及服务之间的依赖关系与设计取舍。",{"path":584,"title":585,"description":586},"\u002Fproject\u002Frocket-leaf\u002Fclient-manager","RocketMQ 客户端管理器","AdminClientManager 的多客户端池、默认连接懒加载、自动重连重试的设计与实现。",{"path":588,"title":589,"description":590},"\u002Fproject\u002Frocket-leaf\u002Fencryption","连接信息加密存储","AES-256-GCM + SHA-256 字段级派生密钥的实现，以及如何在不破坏兼容性的前提下为历史明文数据做透明迁移。",{"path":592,"title":593,"description":594},"\u002Fproject\u002Frocket-leaf\u002Ffrontend","前端结构与类型绑定","React + Vite 目录组织、自动生成的 Wails 绑定、api 薄封装与自定义 hooks 的职责划分。",{"path":596,"title":597,"description":598},"\u002Fproject\u002Frocket-leaf","项目简介","Rocket-Leaf 是一款基于 Wails v3 构建的跨平台 RocketMQ 桌面管理客户端，Go 后端 + React 前端。本文档系列拆解它的架构与关键实现。",{"path":600,"title":601,"description":602},"\u002Fproject\u002Frocket-leaf\u002Fwails-v3","Wails v3 入门","Wails v3 的核心概念、Service 绑定机制，以及 Rocket-Leaf 是如何用它把 Go 后端和 React 前端打通的。",{"path":604,"title":605,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-basic","Docker - 入门基础",{"path":607,"title":608,"description":609},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-compose","Docker - Compose","在部署应用时，常常使用到不止一个容器，那么在部署容器的时候就需要一个一个进行部署，这样的部署过程也相对来说比较繁琐复杂，也容易出问题，那么有没有一种更为简单的方法呢？",{"path":611,"title":612,"description":613},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-container-connection","Docker - 容器互联","在上一个章节中我们学习了 Docker 容器的端口映射，可以将 Docker 容器和本地以及网络中的端口进行连接起来。",{"path":615,"title":616,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-dockerfile","Docker - Dockerfile",{"path":618,"title":619,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-helloworld","Docker - HelloWorld",{"path":621,"title":622,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-install","Docker - 安装",{"path":624,"title":625,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-introduce","Docker - 简介",{"path":627,"title":628,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-object","Docker - 镜像、容器、仓库",{"path":630,"title":631,"description":632},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-warehouse","Docker - 仓库管理","仓库是集中存放资源的地方，代码仓库是存放代码的，那么Docker 中的仓库就是存放 Docker 镜像的。",{"path":634,"title":635,"description":636},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-web-containers","Docker - WEB应用实例","在之前的章节中，仅对普通容器进行了演示，但在实际中常常使用到 Docker 容器中的 WEB 应用程序。",{"path":638,"title":639,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-config","Kubernetes - ConfigMap 与 Secret",{"path":641,"title":642,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","Kubernetes - Helm 包管理",{"path":644,"title":645,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-install","Kubernetes - 集群安装",{"path":647,"title":648,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-introduction","Kubernetes - 简介与架构",{"path":650,"title":651,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-kubectl","Kubernetes - kubectl 命令行工具",{"path":653,"title":654,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-monitoring","Kubernetes - 监控与日志",{"path":656,"title":657,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-network-security","Kubernetes - 网络与安全",{"path":659,"title":660,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-service","Kubernetes - Service 与 Ingress",{"path":662,"title":663,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-storage","Kubernetes - 持久化存储",{"path":665,"title":666,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-workload","Kubernetes - 工作负载资源",{"path":668,"title":669,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-bash","Linux - Bash 基础语法",{"path":671,"title":672,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-file-directory","Linux - 文件与目录操作",{"path":674,"title":675,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-network","Linux - 网络配置",{"path":677,"title":678,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-package","Linux - 软件包管理",{"path":680,"title":681,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-process","Linux - 进程管理",{"path":683,"title":684,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-scripts","Linux - 常用脚本示例",{"path":686,"title":687,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-service","Linux - 服务管理",{"path":689,"title":690,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","Linux - 用户与权限管理",{"path":692,"title":693,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-https","Nginx - HTTPS 配置",{"path":695,"title":696,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","Nginx - 安装与配置",{"path":698,"title":699,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-loadbalance","Nginx - 负载均衡",{"path":701,"title":702,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-optimization","Nginx - 性能优化",{"path":704,"title":705,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-proxy","Nginx - 反向代理",{"path":707,"title":708,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-static","Nginx - 静态资源服务",{"path":710,"title":711,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-vhost","Nginx - 虚拟主机配置",{"path":713,"title":714,"description":715},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-architecture","MySQL 高可用架构","主从复制、读写分离、分库分表。",{"path":717,"title":718,"description":719},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-index","MySQL 索引","索引是帮助 MySQL 高效获取数据的有序数据结构。",{"path":721,"title":722,"description":723},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-lock","MySQL 锁","锁用于解决并发访问时的数据一致性问题。",{"path":725,"title":726,"description":727},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-optimize","MySQL 性能优化","SQL 优化是后端开发必备技能。",{"path":729,"title":730,"description":731},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-transaction","MySQL 事务","事务是一组不可分割的操作，要么全部成功，要么全部失败。",{"path":733,"title":734,"description":735},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-advanced","SQL 进阶","多表查询、子查询、函数、视图、存储过程。",{"path":737,"title":738,"description":739},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","SQL 基础","SQL（Structured Query Language）是操作关系型数据库的标准语言。",{"path":741,"title":742,"description":743},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-advanced","Redis 进阶功能","事务、发布订阅、Lua 脚本、Pipeline。",{"path":745,"title":746,"description":747},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-basic","Redis 基础","Redis 安装配置与基本命令。",{"path":749,"title":750,"description":751},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-cluster","Redis 高可用","主从复制、哨兵、Cluster 集群。",{"path":753,"title":754,"description":755},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-datatype","Redis 数据类型","Redis 5 种基本数据类型 + 4 种特殊类型。",{"path":757,"title":758,"description":759},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-optimize","Redis 性能优化","内存优化、缓存问题、最佳实践。",{"path":761,"title":762,"description":763},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-persistence","Redis 持久化","Redis 提供 RDB 和 AOF 两种持久化方式。",{"path":765,"title":766,"description":767},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-principle","Redis 底层原理","数据结构、线程模型、网络模型。",{"path":769,"title":770,"description":771},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fbehaiver-patterns\u002Fobserver-pattern","观察者模式","观察者模式属于行为型模式，定义了对象之间的一对多的依赖关系，在这种模式中，当一个对象的状态发生变化时，所有依赖于它的对象都会得到通知，并且执行相关操作。观察者模式又被成为“发布—订阅模式”，即发布者发生改变后，会通知所有订阅者。",{"path":773,"title":774,"description":11},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Ffactory-pattern","工厂模式",{"path":776,"title":777,"description":778},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Fsingleton-pattern","单例模式","单例模式是最常用的设计模式之一，他可以保证在整个应用中，某个类只存在一个实例化对象，即全局使用到该类的只有一个对象，这种模式在需要限制某些类的实例数量时非常有用，通常全局只需要一个该对象即可，如一些配置文件映射对象、数据库连接对象等。",{"path":780,"title":781,"description":782},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fstructural-patterns\u002Fadapter-pattern","适配器模式","适配器模式是一种结构型模式，可以将一个类的接口转换成客户端所期望的另一种接口，适配器模式可以帮助开发人员在不修改现有代码的情况下，将不兼容的类组合在一起。",{"path":784,"title":785,"description":786},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-basic-operations","Git 创建版本库","在 Git 上创建版本库有两种方式，一种是直接拷贝远程 Git 仓库到本地，另外一种是我们自己创建本地的版本库。",{"path":788,"title":789,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-branch-manage","Git 分支管理",{"path":791,"title":792,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-content-operations","Git 仓库内容操作",{"path":794,"title":795,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-introduce-install","Git 介绍和安装",{"path":797,"title":798,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-remote-manage","Git 远程管理",{"path":800,"title":801,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-workspace-index-repo","Git 工作原理",{"path":803,"title":804,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fhomebrew","HomeBrew 教程",{"path":806,"title":807,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fidea\u002Fshortcuts","快捷键",{"path":809,"title":810,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fmaven\u002Fintroduce-install-config","Maven - 介绍、安装、配置",{"path":812,"title":813,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fbasic-knowledge","2. 基础知识",{"path":815,"title":816,"description":817},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomponent-communication","9. 组件通信","在前面的章节内，介绍了 Vue 中最核心的内容——组件的介绍和使用，和 Java 等编程语言相反，组件并不近似于这些变成语言中的类，类可以通过类或者其实例化的对象来相互交互，但 Vue 组件之间的作用域是相互独立的，这就意味着不同组件之间的数据无法相互引用。",{"path":819,"title":820,"description":821},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomputed","4. 计算属性","虽然直接在模板中使用表达式方便，但是如果在模板中添加很多逻辑，会让模板变的臃肿且难维护，耦合度较高。有没有一种简单的方式来实现呢？答案是有的。",{"path":823,"title":824,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcreate-vue-project","1. 环境搭建及安装",{"path":826,"title":827,"description":828},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Flife-cycle","6. 生命周期","生命周期是指组件从创建、挂载、更新到销毁的整个过程中所经历的一系列阶段。在 Vue 中，每个组件都有自己的生命周期，可以通过生命周期钩子函数来监听和处理组件在不同阶段的行为和状态。",{"path":830,"title":831,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fother-api","10. 其他 API",{"path":833,"title":834,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fpinia","8. Pinia",{"path":836,"title":837,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter","7. 路由",{"path":839,"title":840,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","3. 指令及模板语法",{"path":842,"title":843,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fvue3-new-component","11. Vue3 新组件",{"path":845,"title":846,"description":847},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fwatch","5. 监视","Watch 是 Vue 提供的一个用于监视响应式数据变化并执行相应操作的 API，能够对响应式数据的变化做出一些操作的功能。Vue3 中的 Watch 支持多种用法，包括监视响应式对象、ref 对象、数组、函数等。",{"path":849,"title":850,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-introduction","Kafka 简介与安装",{"path":852,"title":853,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-producer-consumer","Kafka 生产者与消费者",{"path":855,"title":856,"description":857},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-springboot","Spring Boot 整合 Kafka","Spring Kafka 提供了对 Apache Kafka 的便捷集成。",{"path":859,"title":860,"description":861},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-exchange","RabbitMQ Exchange 详解","Exchange（交换机）是 RabbitMQ 的核心组件，负责接收生产者发送的消息，并根据规则将消息路由到一个或多个队列。",{"path":863,"title":864,"description":11},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-introduction","RabbitMQ 简介与安装",{"path":866,"title":867,"description":868},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-reliability","RabbitMQ 消息可靠性","消息可靠性是消息队列的核心要求，RabbitMQ 提供了多种机制来保证消息不丢失。",{"path":870,"title":871,"description":872},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-springboot","Spring Boot 整合 RabbitMQ","Spring AMQP 提供了对 RabbitMQ 的便捷集成，大大简化了开发工作。",{"path":874,"title":875,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-client","RocketMQ 客户端使用",{"path":877,"title":878,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-concepts","RocketMQ 核心概念",{"path":880,"title":881,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-installation","RocketMQ 安装部署",{"path":883,"title":884,"description":885},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-message-type","RocketMQ 消息类型","RocketMQ 支持多种消息类型，满足不同业务场景需求。",{"id":887,"title":738,"body":888,"description":739,"extension":3825,"meta":3826,"navigation":1027,"path":737,"seo":3827,"stem":3828,"__hash__":3829},"docs\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic.md",{"type":889,"value":890,"toc":3799},"minimark",[891,894,899,982,986,990,1087,1090,1551,1554,1560,1634,1639,1697,1702,1759,1762,1840,1992,1996,2000,2156,2160,2307,2311,2402,2406,2409,2454,2460,2463,2557,2560,2934,2937,3110,3113,3166,3267,3270,3384,3389,3426,3430,3433,3583,3586,3726,3795],[892,893,739],"p",{},[895,896,898],"h2",{"id":897},"sql-分类","SQL 分类",[900,901,902,922],"table",{},[903,904,905],"thead",{},[906,907,908,913,916,919],"tr",{},[909,910,912],"th",{"align":911},"left","分类",[909,914,915],{"align":911},"全称",[909,917,918],{"align":911},"说明",[909,920,921],{"align":911},"关键字",[923,924,925,940,954,968],"tbody",{},[906,926,927,931,934,937],{},[928,929,930],"td",{"align":911},"DDL",[928,932,933],{"align":911},"Data Definition Language",[928,935,936],{"align":911},"数据定义语言",[928,938,939],{"align":911},"CREATE, ALTER, DROP",[906,941,942,945,948,951],{},[928,943,944],{"align":911},"DML",[928,946,947],{"align":911},"Data Manipulation Language",[928,949,950],{"align":911},"数据操作语言",[928,952,953],{"align":911},"INSERT, UPDATE, DELETE",[906,955,956,959,962,965],{},[928,957,958],{"align":911},"DQL",[928,960,961],{"align":911},"Data Query Language",[928,963,964],{"align":911},"数据查询语言",[928,966,967],{"align":911},"SELECT",[906,969,970,973,976,979],{},[928,971,972],{"align":911},"DCL",[928,974,975],{"align":911},"Data Control Language",[928,977,978],{"align":911},"数据控制语言",[928,980,981],{"align":911},"GRANT, REVOKE",[895,983,985],{"id":984},"ddl-数据定义","DDL - 数据定义",[987,988,989],"h3",{"id":989},"数据库操作",[991,992,996],"pre",{"className":993,"code":994,"language":995,"meta":11,"style":11},"language-sql shiki shiki-themes github-light github-light github-dark","-- 创建数据库\nCREATE DATABASE [IF NOT EXISTS] db_name [DEFAULT CHARSET utf8mb4];\n\n-- 删除数据库\nDROP DATABASE [IF EXISTS] db_name;\n\n-- 使用数据库\nUSE db_name;\n\n-- 查看当前数据库\nSELECT DATABASE();\n","sql",[997,998,999,1008,1022,1029,1035,1046,1051,1057,1066,1071,1077],"code",{"__ignoreMap":11},[1000,1001,1004],"span",{"class":1002,"line":1003},"line",1,[1000,1005,1007],{"class":1006},"sCsY4","-- 创建数据库\n",[1000,1009,1011,1015,1018],{"class":1002,"line":1010},2,[1000,1012,1014],{"class":1013},"s8jYJ","CREATE",[1000,1016,1017],{"class":1013}," DATABASE",[1000,1019,1021],{"class":1020},"sxrX7"," [IF NOT EXISTS] db_name [DEFAULT CHARSET utf8mb4];\n",[1000,1023,1025],{"class":1002,"line":1024},3,[1000,1026,1028],{"emptyLinePlaceholder":1027},true,"\n",[1000,1030,1032],{"class":1002,"line":1031},4,[1000,1033,1034],{"class":1006},"-- 删除数据库\n",[1000,1036,1038,1041,1043],{"class":1002,"line":1037},5,[1000,1039,1040],{"class":1013},"DROP",[1000,1042,1017],{"class":1013},[1000,1044,1045],{"class":1020}," [IF EXISTS] db_name;\n",[1000,1047,1049],{"class":1002,"line":1048},6,[1000,1050,1028],{"emptyLinePlaceholder":1027},[1000,1052,1054],{"class":1002,"line":1053},7,[1000,1055,1056],{"class":1006},"-- 使用数据库\n",[1000,1058,1060,1063],{"class":1002,"line":1059},8,[1000,1061,1062],{"class":1013},"USE",[1000,1064,1065],{"class":1020}," db_name;\n",[1000,1067,1069],{"class":1002,"line":1068},9,[1000,1070,1028],{"emptyLinePlaceholder":1027},[1000,1072,1074],{"class":1002,"line":1073},10,[1000,1075,1076],{"class":1006},"-- 查看当前数据库\n",[1000,1078,1080,1082,1084],{"class":1002,"line":1079},11,[1000,1081,967],{"class":1013},[1000,1083,1017],{"class":1013},[1000,1085,1086],{"class":1020},"();\n",[987,1088,1089],{"id":1089},"表操作",[991,1091,1093],{"className":993,"code":1092,"language":995,"meta":11,"style":11},"-- 创建表\nCREATE TABLE user (\n    id          BIGINT PRIMARY KEY AUTO_INCREMENT COMMENT '主键',\n    username    VARCHAR(50) NOT NULL UNIQUE COMMENT '用户名',\n    password    VARCHAR(100) NOT NULL COMMENT '密码',\n    email       VARCHAR(100) COMMENT '邮箱',\n    age         TINYINT UNSIGNED DEFAULT 0 COMMENT '年龄',\n    status      TINYINT DEFAULT 1 COMMENT '状态：0禁用 1启用',\n    create_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',\n    update_time DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间'\n) COMMENT '用户表';\n\n-- 查看表结构\nDESC user;\n\n-- 查看建表语句\nSHOW CREATE TABLE user;\n\n-- 修改表名\nALTER TABLE user RENAME TO t_user;\n\n-- 添加字段\nALTER TABLE user ADD phone VARCHAR(20) COMMENT '手机号';\n\n-- 修改字段类型\nALTER TABLE user MODIFY phone VARCHAR(15);\n\n-- 修改字段名和类型\nALTER TABLE user CHANGE phone mobile VARCHAR(15) COMMENT '手机';\n\n-- 删除字段\nALTER TABLE user DROP mobile;\n\n-- 删除表\nDROP TABLE [IF EXISTS] user;\n\n-- 清空表（保留结构）\nTRUNCATE TABLE user;\n",[997,1094,1095,1100,1114,1135,1167,1191,1210,1234,1255,1273,1293,1303,1308,1314,1323,1328,1334,1346,1351,1357,1374,1379,1385,1415,1420,1426,1450,1455,1461,1484,1489,1495,1509,1514,1520,1530,1535,1541],{"__ignoreMap":11},[1000,1096,1097],{"class":1002,"line":1003},[1000,1098,1099],{"class":1006},"-- 创建表\n",[1000,1101,1102,1104,1107,1111],{"class":1002,"line":1010},[1000,1103,1014],{"class":1013},[1000,1105,1106],{"class":1013}," TABLE",[1000,1108,1110],{"class":1109},"snPdu"," user",[1000,1112,1113],{"class":1020}," (\n",[1000,1115,1116,1119,1122,1125,1128,1132],{"class":1002,"line":1024},[1000,1117,1118],{"class":1020},"    id          ",[1000,1120,1121],{"class":1013},"BIGINT",[1000,1123,1124],{"class":1013}," PRIMARY KEY",[1000,1126,1127],{"class":1020}," AUTO_INCREMENT COMMENT ",[1000,1129,1131],{"class":1130},"sIIMD","'主键'",[1000,1133,1134],{"class":1020},",\n",[1000,1136,1137,1140,1143,1146,1150,1153,1156,1159,1162,1165],{"class":1002,"line":1031},[1000,1138,1139],{"class":1020},"    username    ",[1000,1141,1142],{"class":1013},"VARCHAR",[1000,1144,1145],{"class":1020},"(",[1000,1147,1149],{"class":1148},"sBjJW","50",[1000,1151,1152],{"class":1020},") ",[1000,1154,1155],{"class":1013},"NOT NULL",[1000,1157,1158],{"class":1013}," UNIQUE",[1000,1160,1161],{"class":1020}," COMMENT ",[1000,1163,1164],{"class":1130},"'用户名'",[1000,1166,1134],{"class":1020},[1000,1168,1169,1172,1175,1177,1180,1182,1184,1186,1189],{"class":1002,"line":1037},[1000,1170,1171],{"class":1013},"    password",[1000,1173,1174],{"class":1013},"    VARCHAR",[1000,1176,1145],{"class":1020},[1000,1178,1179],{"class":1148},"100",[1000,1181,1152],{"class":1020},[1000,1183,1155],{"class":1013},[1000,1185,1161],{"class":1020},[1000,1187,1188],{"class":1130},"'密码'",[1000,1190,1134],{"class":1020},[1000,1192,1193,1196,1198,1200,1202,1205,1208],{"class":1002,"line":1048},[1000,1194,1195],{"class":1020},"    email       ",[1000,1197,1142],{"class":1013},[1000,1199,1145],{"class":1020},[1000,1201,1179],{"class":1148},[1000,1203,1204],{"class":1020},") COMMENT ",[1000,1206,1207],{"class":1130},"'邮箱'",[1000,1209,1134],{"class":1020},[1000,1211,1212,1215,1218,1221,1224,1227,1229,1232],{"class":1002,"line":1053},[1000,1213,1214],{"class":1020},"    age         ",[1000,1216,1217],{"class":1013},"TINYINT",[1000,1219,1220],{"class":1020}," UNSIGNED ",[1000,1222,1223],{"class":1013},"DEFAULT",[1000,1225,1226],{"class":1148}," 0",[1000,1228,1161],{"class":1020},[1000,1230,1231],{"class":1130},"'年龄'",[1000,1233,1134],{"class":1020},[1000,1235,1236,1239,1242,1245,1248,1250,1253],{"class":1002,"line":1059},[1000,1237,1238],{"class":1013},"    status",[1000,1240,1241],{"class":1013},"      TINYINT",[1000,1243,1244],{"class":1013}," DEFAULT",[1000,1246,1247],{"class":1148}," 1",[1000,1249,1161],{"class":1020},[1000,1251,1252],{"class":1130},"'状态：0禁用 1启用'",[1000,1254,1134],{"class":1020},[1000,1256,1257,1260,1263,1265,1268,1271],{"class":1002,"line":1068},[1000,1258,1259],{"class":1020},"    create_time ",[1000,1261,1262],{"class":1013},"DATETIME",[1000,1264,1244],{"class":1013},[1000,1266,1267],{"class":1020}," CURRENT_TIMESTAMP COMMENT ",[1000,1269,1270],{"class":1130},"'创建时间'",[1000,1272,1134],{"class":1020},[1000,1274,1275,1278,1280,1282,1285,1288,1290],{"class":1002,"line":1073},[1000,1276,1277],{"class":1020},"    update_time ",[1000,1279,1262],{"class":1013},[1000,1281,1244],{"class":1013},[1000,1283,1284],{"class":1020}," CURRENT_TIMESTAMP ",[1000,1286,1287],{"class":1013},"ON UPDATE",[1000,1289,1267],{"class":1020},[1000,1291,1292],{"class":1130},"'更新时间'\n",[1000,1294,1295,1297,1300],{"class":1002,"line":1079},[1000,1296,1204],{"class":1020},[1000,1298,1299],{"class":1130},"'用户表'",[1000,1301,1302],{"class":1020},";\n",[1000,1304,1306],{"class":1002,"line":1305},12,[1000,1307,1028],{"emptyLinePlaceholder":1027},[1000,1309,1311],{"class":1002,"line":1310},13,[1000,1312,1313],{"class":1006},"-- 查看表结构\n",[1000,1315,1317,1320],{"class":1002,"line":1316},14,[1000,1318,1319],{"class":1013},"DESC",[1000,1321,1322],{"class":1020}," user;\n",[1000,1324,1326],{"class":1002,"line":1325},15,[1000,1327,1028],{"emptyLinePlaceholder":1027},[1000,1329,1331],{"class":1002,"line":1330},16,[1000,1332,1333],{"class":1006},"-- 查看建表语句\n",[1000,1335,1337,1340,1342,1344],{"class":1002,"line":1336},17,[1000,1338,1339],{"class":1020},"SHOW ",[1000,1341,1014],{"class":1013},[1000,1343,1106],{"class":1013},[1000,1345,1322],{"class":1020},[1000,1347,1349],{"class":1002,"line":1348},18,[1000,1350,1028],{"emptyLinePlaceholder":1027},[1000,1352,1354],{"class":1002,"line":1353},19,[1000,1355,1356],{"class":1006},"-- 修改表名\n",[1000,1358,1360,1363,1365,1368,1371],{"class":1002,"line":1359},20,[1000,1361,1362],{"class":1013},"ALTER",[1000,1364,1106],{"class":1013},[1000,1366,1367],{"class":1020}," user RENAME ",[1000,1369,1370],{"class":1013},"TO",[1000,1372,1373],{"class":1020}," t_user;\n",[1000,1375,1377],{"class":1002,"line":1376},21,[1000,1378,1028],{"emptyLinePlaceholder":1027},[1000,1380,1382],{"class":1002,"line":1381},22,[1000,1383,1384],{"class":1006},"-- 添加字段\n",[1000,1386,1388,1390,1392,1395,1398,1401,1403,1405,1408,1410,1413],{"class":1002,"line":1387},23,[1000,1389,1362],{"class":1013},[1000,1391,1106],{"class":1013},[1000,1393,1394],{"class":1020}," user ",[1000,1396,1397],{"class":1013},"ADD",[1000,1399,1400],{"class":1020}," phone ",[1000,1402,1142],{"class":1013},[1000,1404,1145],{"class":1020},[1000,1406,1407],{"class":1148},"20",[1000,1409,1204],{"class":1020},[1000,1411,1412],{"class":1130},"'手机号'",[1000,1414,1302],{"class":1020},[1000,1416,1418],{"class":1002,"line":1417},24,[1000,1419,1028],{"emptyLinePlaceholder":1027},[1000,1421,1423],{"class":1002,"line":1422},25,[1000,1424,1425],{"class":1006},"-- 修改字段类型\n",[1000,1427,1429,1431,1433,1435,1438,1440,1442,1444,1447],{"class":1002,"line":1428},26,[1000,1430,1362],{"class":1013},[1000,1432,1106],{"class":1013},[1000,1434,1394],{"class":1020},[1000,1436,1437],{"class":1013},"MODIFY",[1000,1439,1400],{"class":1020},[1000,1441,1142],{"class":1013},[1000,1443,1145],{"class":1020},[1000,1445,1446],{"class":1148},"15",[1000,1448,1449],{"class":1020},");\n",[1000,1451,1453],{"class":1002,"line":1452},27,[1000,1454,1028],{"emptyLinePlaceholder":1027},[1000,1456,1458],{"class":1002,"line":1457},28,[1000,1459,1460],{"class":1006},"-- 修改字段名和类型\n",[1000,1462,1464,1466,1468,1471,1473,1475,1477,1479,1482],{"class":1002,"line":1463},29,[1000,1465,1362],{"class":1013},[1000,1467,1106],{"class":1013},[1000,1469,1470],{"class":1020}," user CHANGE phone mobile ",[1000,1472,1142],{"class":1013},[1000,1474,1145],{"class":1020},[1000,1476,1446],{"class":1148},[1000,1478,1204],{"class":1020},[1000,1480,1481],{"class":1130},"'手机'",[1000,1483,1302],{"class":1020},[1000,1485,1487],{"class":1002,"line":1486},30,[1000,1488,1028],{"emptyLinePlaceholder":1027},[1000,1490,1492],{"class":1002,"line":1491},31,[1000,1493,1494],{"class":1006},"-- 删除字段\n",[1000,1496,1498,1500,1502,1504,1506],{"class":1002,"line":1497},32,[1000,1499,1362],{"class":1013},[1000,1501,1106],{"class":1013},[1000,1503,1394],{"class":1020},[1000,1505,1040],{"class":1013},[1000,1507,1508],{"class":1020}," mobile;\n",[1000,1510,1512],{"class":1002,"line":1511},33,[1000,1513,1028],{"emptyLinePlaceholder":1027},[1000,1515,1517],{"class":1002,"line":1516},34,[1000,1518,1519],{"class":1006},"-- 删除表\n",[1000,1521,1523,1525,1527],{"class":1002,"line":1522},35,[1000,1524,1040],{"class":1013},[1000,1526,1106],{"class":1013},[1000,1528,1529],{"class":1020}," [IF EXISTS] user;\n",[1000,1531,1533],{"class":1002,"line":1532},36,[1000,1534,1028],{"emptyLinePlaceholder":1027},[1000,1536,1538],{"class":1002,"line":1537},37,[1000,1539,1540],{"class":1006},"-- 清空表（保留结构）\n",[1000,1542,1544,1547,1549],{"class":1002,"line":1543},38,[1000,1545,1546],{"class":1013},"TRUNCATE",[1000,1548,1106],{"class":1013},[1000,1550,1322],{"class":1020},[987,1552,1553],{"id":1553},"数据类型",[892,1555,1556],{},[1557,1558,1559],"strong",{},"整数类型",[900,1561,1562,1578],{},[903,1563,1564],{},[906,1565,1566,1569,1572,1575],{},[909,1567,1568],{"align":911},"类型",[909,1570,1571],{"align":911},"字节",[909,1573,1574],{"align":911},"范围（有符号）",[909,1576,1577],{"align":911},"范围（无符号）",[923,1579,1580,1593,1607,1621],{},[906,1581,1582,1584,1587,1590],{},[928,1583,1217],{"align":911},[928,1585,1586],{"align":911},"1",[928,1588,1589],{"align":911},"-128 ~ 127",[928,1591,1592],{"align":911},"0 ~ 255",[906,1594,1595,1598,1601,1604],{},[928,1596,1597],{"align":911},"SMALLINT",[928,1599,1600],{"align":911},"2",[928,1602,1603],{"align":911},"-32768 ~ 32767",[928,1605,1606],{"align":911},"0 ~ 65535",[906,1608,1609,1612,1615,1618],{},[928,1610,1611],{"align":911},"INT",[928,1613,1614],{"align":911},"4",[928,1616,1617],{"align":911},"-2^31 ~ 2^31-1",[928,1619,1620],{"align":911},"0 ~ 2^32-1",[906,1622,1623,1625,1628,1631],{},[928,1624,1121],{"align":911},[928,1626,1627],{"align":911},"8",[928,1629,1630],{"align":911},"-2^63 ~ 2^63-1",[928,1632,1633],{"align":911},"0 ~ 2^64-1",[892,1635,1636],{},[1557,1637,1638],{},"字符串类型",[900,1640,1641,1652],{},[903,1642,1643],{},[906,1644,1645,1647,1649],{},[909,1646,1568],{"align":911},[909,1648,918],{"align":911},[909,1650,1651],{"align":911},"长度限制",[923,1653,1654,1665,1676,1686],{},[906,1655,1656,1659,1662],{},[928,1657,1658],{"align":911},"CHAR(n)",[928,1660,1661],{"align":911},"定长字符串",[928,1663,1664],{"align":911},"0-255",[906,1666,1667,1670,1673],{},[928,1668,1669],{"align":911},"VARCHAR(n)",[928,1671,1672],{"align":911},"变长字符串",[928,1674,1675],{"align":911},"0-65535",[906,1677,1678,1681,1684],{},[928,1679,1680],{"align":911},"TEXT",[928,1682,1683],{"align":911},"长文本",[928,1685,1675],{"align":911},[906,1687,1688,1691,1694],{},[928,1689,1690],{"align":911},"LONGTEXT",[928,1692,1693],{"align":911},"超长文本",[928,1695,1696],{"align":911},"0-4GB",[892,1698,1699],{},[1557,1700,1701],{},"日期类型",[900,1703,1704,1715],{},[903,1705,1706],{},[906,1707,1708,1710,1713],{},[909,1709,1568],{"align":911},[909,1711,1712],{"align":911},"格式",[909,1714,918],{"align":911},[923,1716,1717,1728,1739,1749],{},[906,1718,1719,1722,1725],{},[928,1720,1721],{"align":911},"DATE",[928,1723,1724],{"align":911},"YYYY-MM-DD",[928,1726,1727],{"align":911},"日期",[906,1729,1730,1733,1736],{},[928,1731,1732],{"align":911},"TIME",[928,1734,1735],{"align":911},"HH:MM:SS",[928,1737,1738],{"align":911},"时间",[906,1740,1741,1743,1746],{},[928,1742,1262],{"align":911},[928,1744,1745],{"align":911},"YYYY-MM-DD HH:MM:SS",[928,1747,1748],{"align":911},"日期时间",[906,1750,1751,1754,1756],{},[928,1752,1753],{"align":911},"TIMESTAMP",[928,1755,1745],{"align":911},[928,1757,1758],{"align":911},"时间戳（自动更新）",[987,1760,1761],{"id":1761},"约束",[900,1763,1764,1774],{},[903,1765,1766],{},[906,1767,1768,1770,1772],{},[909,1769,1761],{"align":911},[909,1771,921],{"align":911},[909,1773,918],{"align":911},[923,1775,1776,1787,1798,1808,1818,1829],{},[906,1777,1778,1781,1784],{},[928,1779,1780],{"align":911},"主键",[928,1782,1783],{"align":911},"PRIMARY KEY",[928,1785,1786],{"align":911},"唯一标识，非空且唯一",[906,1788,1789,1792,1795],{},[928,1790,1791],{"align":911},"唯一",[928,1793,1794],{"align":911},"UNIQUE",[928,1796,1797],{"align":911},"值唯一",[906,1799,1800,1803,1805],{},[928,1801,1802],{"align":911},"非空",[928,1804,1155],{"align":911},[928,1806,1807],{"align":911},"不能为空",[906,1809,1810,1813,1815],{},[928,1811,1812],{"align":911},"默认",[928,1814,1223],{"align":911},[928,1816,1817],{"align":911},"默认值",[906,1819,1820,1823,1826],{},[928,1821,1822],{"align":911},"外键",[928,1824,1825],{"align":911},"FOREIGN KEY",[928,1827,1828],{"align":911},"关联其他表的主键",[906,1830,1831,1834,1837],{},[928,1832,1833],{"align":911},"自增",[928,1835,1836],{"align":911},"AUTO_INCREMENT",[928,1838,1839],{"align":911},"自动递增",[991,1841,1843],{"className":993,"code":1842,"language":995,"meta":11,"style":11},"-- 外键约束\nCREATE TABLE orders (\n    id BIGINT PRIMARY KEY AUTO_INCREMENT,\n    user_id BIGINT NOT NULL,\n    amount DECIMAL(10,2),\n    CONSTRAINT fk_user FOREIGN KEY (user_id) REFERENCES user(id)\n);\n\n-- 添加外键\nALTER TABLE orders ADD CONSTRAINT fk_user \n    FOREIGN KEY (user_id) REFERENCES user(id);\n\n-- 删除外键\nALTER TABLE orders DROP FOREIGN KEY fk_user;\n",[997,1844,1845,1850,1861,1873,1885,1906,1925,1929,1933,1938,1955,1967,1971,1976],{"__ignoreMap":11},[1000,1846,1847],{"class":1002,"line":1003},[1000,1848,1849],{"class":1006},"-- 外键约束\n",[1000,1851,1852,1854,1856,1859],{"class":1002,"line":1010},[1000,1853,1014],{"class":1013},[1000,1855,1106],{"class":1013},[1000,1857,1858],{"class":1109}," orders",[1000,1860,1113],{"class":1020},[1000,1862,1863,1866,1868,1870],{"class":1002,"line":1024},[1000,1864,1865],{"class":1020},"    id ",[1000,1867,1121],{"class":1013},[1000,1869,1124],{"class":1013},[1000,1871,1872],{"class":1020}," AUTO_INCREMENT,\n",[1000,1874,1875,1878,1880,1883],{"class":1002,"line":1031},[1000,1876,1877],{"class":1020},"    user_id ",[1000,1879,1121],{"class":1013},[1000,1881,1882],{"class":1013}," NOT NULL",[1000,1884,1134],{"class":1020},[1000,1886,1887,1890,1893,1895,1898,1901,1903],{"class":1002,"line":1037},[1000,1888,1889],{"class":1020},"    amount ",[1000,1891,1892],{"class":1013},"DECIMAL",[1000,1894,1145],{"class":1020},[1000,1896,1897],{"class":1148},"10",[1000,1899,1900],{"class":1020},",",[1000,1902,1600],{"class":1148},[1000,1904,1905],{"class":1020},"),\n",[1000,1907,1908,1911,1914,1916,1919,1922],{"class":1002,"line":1048},[1000,1909,1910],{"class":1013},"    CONSTRAINT",[1000,1912,1913],{"class":1020}," fk_user ",[1000,1915,1825],{"class":1013},[1000,1917,1918],{"class":1020}," (user_id) ",[1000,1920,1921],{"class":1013},"REFERENCES",[1000,1923,1924],{"class":1020}," user(id)\n",[1000,1926,1927],{"class":1002,"line":1053},[1000,1928,1449],{"class":1020},[1000,1930,1931],{"class":1002,"line":1059},[1000,1932,1028],{"emptyLinePlaceholder":1027},[1000,1934,1935],{"class":1002,"line":1068},[1000,1936,1937],{"class":1006},"-- 添加外键\n",[1000,1939,1940,1942,1944,1947,1949,1952],{"class":1002,"line":1073},[1000,1941,1362],{"class":1013},[1000,1943,1106],{"class":1013},[1000,1945,1946],{"class":1020}," orders ",[1000,1948,1397],{"class":1013},[1000,1950,1951],{"class":1013}," CONSTRAINT",[1000,1953,1954],{"class":1020}," fk_user \n",[1000,1956,1957,1960,1962,1964],{"class":1002,"line":1079},[1000,1958,1959],{"class":1013},"    FOREIGN KEY",[1000,1961,1918],{"class":1020},[1000,1963,1921],{"class":1013},[1000,1965,1966],{"class":1020}," user(id);\n",[1000,1968,1969],{"class":1002,"line":1305},[1000,1970,1028],{"emptyLinePlaceholder":1027},[1000,1972,1973],{"class":1002,"line":1310},[1000,1974,1975],{"class":1006},"-- 删除外键\n",[1000,1977,1978,1980,1982,1984,1986,1989],{"class":1002,"line":1316},[1000,1979,1362],{"class":1013},[1000,1981,1106],{"class":1013},[1000,1983,1946],{"class":1020},[1000,1985,1040],{"class":1013},[1000,1987,1988],{"class":1013}," FOREIGN KEY",[1000,1990,1991],{"class":1020}," fk_user;\n",[895,1993,1995],{"id":1994},"dml-数据操作","DML - 数据操作",[987,1997,1999],{"id":1998},"insert","INSERT",[991,2001,2003],{"className":993,"code":2002,"language":995,"meta":11,"style":11},"-- 插入单条\nINSERT INTO user (username, password, email) \nVALUES ('张三', '123456', 'zhangsan@test.com');\n\n-- 插入多条\nINSERT INTO user (username, password) VALUES \n    ('李四', '123456'),\n    ('王五', '123456');\n\n-- 插入所有字段（不推荐）\nINSERT INTO user VALUES (1, '赵六', '123456', 'zhaoliu@test.com', 18, 1, NOW(), NOW());\n",[997,2004,2005,2010,2024,2048,2052,2057,2072,2086,2099,2103,2108],{"__ignoreMap":11},[1000,2006,2007],{"class":1002,"line":1003},[1000,2008,2009],{"class":1006},"-- 插入单条\n",[1000,2011,2012,2015,2018,2021],{"class":1002,"line":1010},[1000,2013,2014],{"class":1013},"INSERT INTO",[1000,2016,2017],{"class":1020}," user (username, ",[1000,2019,2020],{"class":1013},"password",[1000,2022,2023],{"class":1020},", email) \n",[1000,2025,2026,2029,2032,2035,2038,2041,2043,2046],{"class":1002,"line":1024},[1000,2027,2028],{"class":1013},"VALUES",[1000,2030,2031],{"class":1020}," (",[1000,2033,2034],{"class":1130},"'张三'",[1000,2036,2037],{"class":1020},", ",[1000,2039,2040],{"class":1130},"'123456'",[1000,2042,2037],{"class":1020},[1000,2044,2045],{"class":1130},"'zhangsan@test.com'",[1000,2047,1449],{"class":1020},[1000,2049,2050],{"class":1002,"line":1031},[1000,2051,1028],{"emptyLinePlaceholder":1027},[1000,2053,2054],{"class":1002,"line":1037},[1000,2055,2056],{"class":1006},"-- 插入多条\n",[1000,2058,2059,2061,2063,2065,2067,2069],{"class":1002,"line":1048},[1000,2060,2014],{"class":1013},[1000,2062,2017],{"class":1020},[1000,2064,2020],{"class":1013},[1000,2066,1152],{"class":1020},[1000,2068,2028],{"class":1013},[1000,2070,2071],{"class":1020}," \n",[1000,2073,2074,2077,2080,2082,2084],{"class":1002,"line":1053},[1000,2075,2076],{"class":1020},"    (",[1000,2078,2079],{"class":1130},"'李四'",[1000,2081,2037],{"class":1020},[1000,2083,2040],{"class":1130},[1000,2085,1905],{"class":1020},[1000,2087,2088,2090,2093,2095,2097],{"class":1002,"line":1059},[1000,2089,2076],{"class":1020},[1000,2091,2092],{"class":1130},"'王五'",[1000,2094,2037],{"class":1020},[1000,2096,2040],{"class":1130},[1000,2098,1449],{"class":1020},[1000,2100,2101],{"class":1002,"line":1068},[1000,2102,1028],{"emptyLinePlaceholder":1027},[1000,2104,2105],{"class":1002,"line":1073},[1000,2106,2107],{"class":1006},"-- 插入所有字段（不推荐）\n",[1000,2109,2110,2112,2114,2116,2118,2120,2122,2125,2127,2129,2131,2134,2136,2139,2141,2143,2145,2148,2151,2153],{"class":1002,"line":1079},[1000,2111,2014],{"class":1013},[1000,2113,1394],{"class":1020},[1000,2115,2028],{"class":1013},[1000,2117,2031],{"class":1020},[1000,2119,1586],{"class":1148},[1000,2121,2037],{"class":1020},[1000,2123,2124],{"class":1130},"'赵六'",[1000,2126,2037],{"class":1020},[1000,2128,2040],{"class":1130},[1000,2130,2037],{"class":1020},[1000,2132,2133],{"class":1130},"'zhaoliu@test.com'",[1000,2135,2037],{"class":1020},[1000,2137,2138],{"class":1148},"18",[1000,2140,2037],{"class":1020},[1000,2142,1586],{"class":1148},[1000,2144,2037],{"class":1020},[1000,2146,2147],{"class":1013},"NOW",[1000,2149,2150],{"class":1020},"(), ",[1000,2152,2147],{"class":1013},[1000,2154,2155],{"class":1020},"());\n",[987,2157,2159],{"id":2158},"update","UPDATE",[991,2161,2163],{"className":993,"code":2162,"language":995,"meta":11,"style":11},"-- 更新单个字段\nUPDATE user SET status = 0 WHERE id = 1;\n\n-- 更新多个字段\nUPDATE user SET password = '654321', email = 'new@test.com' WHERE id = 1;\n\n-- 条件更新\nUPDATE user SET age = age + 1 WHERE status = 1;\n\n-- ⚠️ 不带 WHERE 会更新所有记录\nUPDATE user SET status = 1;\n",[997,2164,2165,2170,2200,2204,2209,2243,2247,2252,2282,2286,2291],{"__ignoreMap":11},[1000,2166,2167],{"class":1002,"line":1003},[1000,2168,2169],{"class":1006},"-- 更新单个字段\n",[1000,2171,2172,2174,2176,2179,2182,2185,2187,2190,2193,2196,2198],{"class":1002,"line":1010},[1000,2173,2159],{"class":1013},[1000,2175,1394],{"class":1020},[1000,2177,2178],{"class":1013},"SET",[1000,2180,2181],{"class":1013}," status",[1000,2183,2184],{"class":1013}," =",[1000,2186,1226],{"class":1148},[1000,2188,2189],{"class":1013}," WHERE",[1000,2191,2192],{"class":1020}," id ",[1000,2194,2195],{"class":1013},"=",[1000,2197,1247],{"class":1148},[1000,2199,1302],{"class":1020},[1000,2201,2202],{"class":1002,"line":1024},[1000,2203,1028],{"emptyLinePlaceholder":1027},[1000,2205,2206],{"class":1002,"line":1031},[1000,2207,2208],{"class":1006},"-- 更新多个字段\n",[1000,2210,2211,2213,2215,2217,2220,2222,2225,2228,2230,2233,2235,2237,2239,2241],{"class":1002,"line":1037},[1000,2212,2159],{"class":1013},[1000,2214,1394],{"class":1020},[1000,2216,2178],{"class":1013},[1000,2218,2219],{"class":1013}," password",[1000,2221,2184],{"class":1013},[1000,2223,2224],{"class":1130}," '654321'",[1000,2226,2227],{"class":1020},", email ",[1000,2229,2195],{"class":1013},[1000,2231,2232],{"class":1130}," 'new@test.com'",[1000,2234,2189],{"class":1013},[1000,2236,2192],{"class":1020},[1000,2238,2195],{"class":1013},[1000,2240,1247],{"class":1148},[1000,2242,1302],{"class":1020},[1000,2244,2245],{"class":1002,"line":1048},[1000,2246,1028],{"emptyLinePlaceholder":1027},[1000,2248,2249],{"class":1002,"line":1053},[1000,2250,2251],{"class":1006},"-- 条件更新\n",[1000,2253,2254,2256,2258,2260,2263,2265,2267,2270,2272,2274,2276,2278,2280],{"class":1002,"line":1059},[1000,2255,2159],{"class":1013},[1000,2257,1394],{"class":1020},[1000,2259,2178],{"class":1013},[1000,2261,2262],{"class":1020}," age ",[1000,2264,2195],{"class":1013},[1000,2266,2262],{"class":1020},[1000,2268,2269],{"class":1013},"+",[1000,2271,1247],{"class":1148},[1000,2273,2189],{"class":1013},[1000,2275,2181],{"class":1013},[1000,2277,2184],{"class":1013},[1000,2279,1247],{"class":1148},[1000,2281,1302],{"class":1020},[1000,2283,2284],{"class":1002,"line":1068},[1000,2285,1028],{"emptyLinePlaceholder":1027},[1000,2287,2288],{"class":1002,"line":1073},[1000,2289,2290],{"class":1006},"-- ⚠️ 不带 WHERE 会更新所有记录\n",[1000,2292,2293,2295,2297,2299,2301,2303,2305],{"class":1002,"line":1079},[1000,2294,2159],{"class":1013},[1000,2296,1394],{"class":1020},[1000,2298,2178],{"class":1013},[1000,2300,2181],{"class":1013},[1000,2302,2184],{"class":1013},[1000,2304,1247],{"class":1148},[1000,2306,1302],{"class":1020},[987,2308,2310],{"id":2309},"delete","DELETE",[991,2312,2314],{"className":993,"code":2313,"language":995,"meta":11,"style":11},"-- 删除指定记录\nDELETE FROM user WHERE id = 1;\n\n-- 条件删除\nDELETE FROM user WHERE status = 0;\n\n-- ⚠️ 不带 WHERE 会删除所有记录\nDELETE FROM user;\n\n-- 清空表（更快，不可回滚）\nTRUNCATE TABLE user;\n",[997,2315,2316,2321,2341,2345,2350,2368,2372,2377,2385,2389,2394],{"__ignoreMap":11},[1000,2317,2318],{"class":1002,"line":1003},[1000,2319,2320],{"class":1006},"-- 删除指定记录\n",[1000,2322,2323,2325,2328,2330,2333,2335,2337,2339],{"class":1002,"line":1010},[1000,2324,2310],{"class":1013},[1000,2326,2327],{"class":1013}," FROM",[1000,2329,1394],{"class":1020},[1000,2331,2332],{"class":1013},"WHERE",[1000,2334,2192],{"class":1020},[1000,2336,2195],{"class":1013},[1000,2338,1247],{"class":1148},[1000,2340,1302],{"class":1020},[1000,2342,2343],{"class":1002,"line":1024},[1000,2344,1028],{"emptyLinePlaceholder":1027},[1000,2346,2347],{"class":1002,"line":1031},[1000,2348,2349],{"class":1006},"-- 条件删除\n",[1000,2351,2352,2354,2356,2358,2360,2362,2364,2366],{"class":1002,"line":1037},[1000,2353,2310],{"class":1013},[1000,2355,2327],{"class":1013},[1000,2357,1394],{"class":1020},[1000,2359,2332],{"class":1013},[1000,2361,2181],{"class":1013},[1000,2363,2184],{"class":1013},[1000,2365,1226],{"class":1148},[1000,2367,1302],{"class":1020},[1000,2369,2370],{"class":1002,"line":1048},[1000,2371,1028],{"emptyLinePlaceholder":1027},[1000,2373,2374],{"class":1002,"line":1053},[1000,2375,2376],{"class":1006},"-- ⚠️ 不带 WHERE 会删除所有记录\n",[1000,2378,2379,2381,2383],{"class":1002,"line":1059},[1000,2380,2310],{"class":1013},[1000,2382,2327],{"class":1013},[1000,2384,1322],{"class":1020},[1000,2386,2387],{"class":1002,"line":1068},[1000,2388,1028],{"emptyLinePlaceholder":1027},[1000,2390,2391],{"class":1002,"line":1073},[1000,2392,2393],{"class":1006},"-- 清空表（更快，不可回滚）\n",[1000,2395,2396,2398,2400],{"class":1002,"line":1079},[1000,2397,1546],{"class":1013},[1000,2399,1106],{"class":1013},[1000,2401,1322],{"class":1020},[895,2403,2405],{"id":2404},"dql-数据查询","DQL - 数据查询",[987,2407,2408],{"id":2408},"基本语法",[991,2410,2412],{"className":993,"code":2411,"language":995,"meta":11,"style":11},"SELECT [DISTINCT] 字段列表\nFROM 表名\n[WHERE 条件]\n[GROUP BY 分组字段]\n[HAVING 分组后条件]\n[ORDER BY 排序字段 ASC\u002FDESC]\n[LIMIT 起始索引, 记录数];\n",[997,2413,2414,2421,2429,2434,2439,2444,2449],{"__ignoreMap":11},[1000,2415,2416,2418],{"class":1002,"line":1003},[1000,2417,967],{"class":1013},[1000,2419,2420],{"class":1020}," [DISTINCT] 字段列表\n",[1000,2422,2423,2426],{"class":1002,"line":1010},[1000,2424,2425],{"class":1013},"FROM",[1000,2427,2428],{"class":1020}," 表名\n",[1000,2430,2431],{"class":1002,"line":1024},[1000,2432,2433],{"class":1020},"[WHERE 条件]\n",[1000,2435,2436],{"class":1002,"line":1031},[1000,2437,2438],{"class":1020},"[GROUP BY 分组字段]\n",[1000,2440,2441],{"class":1002,"line":1037},[1000,2442,2443],{"class":1020},"[HAVING 分组后条件]\n",[1000,2445,2446],{"class":1002,"line":1048},[1000,2447,2448],{"class":1020},"[ORDER BY 排序字段 ASC\u002FDESC]\n",[1000,2450,2451],{"class":1002,"line":1053},[1000,2452,2453],{"class":1020},"[LIMIT 起始索引, 记录数];\n",[892,2455,2456,2459],{},[1557,2457,2458],{},"执行顺序","：FROM → WHERE → GROUP BY → HAVING → SELECT → ORDER BY → LIMIT",[987,2461,2462],{"id":2462},"基础查询",[991,2464,2466],{"className":993,"code":2465,"language":995,"meta":11,"style":11},"-- 查询所有\nSELECT * FROM user;\n\n-- 查询指定字段\nSELECT id, username, email FROM user;\n\n-- 别名\nSELECT username AS name, email AS mail FROM user;\n\n-- 去重\nSELECT DISTINCT status FROM user;\n",[997,2467,2468,2473,2484,2488,2493,2504,2508,2513,2537,2541,2546],{"__ignoreMap":11},[1000,2469,2470],{"class":1002,"line":1003},[1000,2471,2472],{"class":1006},"-- 查询所有\n",[1000,2474,2475,2477,2480,2482],{"class":1002,"line":1010},[1000,2476,967],{"class":1013},[1000,2478,2479],{"class":1013}," *",[1000,2481,2327],{"class":1013},[1000,2483,1322],{"class":1020},[1000,2485,2486],{"class":1002,"line":1024},[1000,2487,1028],{"emptyLinePlaceholder":1027},[1000,2489,2490],{"class":1002,"line":1031},[1000,2491,2492],{"class":1006},"-- 查询指定字段\n",[1000,2494,2495,2497,2500,2502],{"class":1002,"line":1037},[1000,2496,967],{"class":1013},[1000,2498,2499],{"class":1020}," id, username, email ",[1000,2501,2425],{"class":1013},[1000,2503,1322],{"class":1020},[1000,2505,2506],{"class":1002,"line":1048},[1000,2507,1028],{"emptyLinePlaceholder":1027},[1000,2509,2510],{"class":1002,"line":1053},[1000,2511,2512],{"class":1006},"-- 别名\n",[1000,2514,2515,2517,2520,2523,2526,2528,2530,2533,2535],{"class":1002,"line":1059},[1000,2516,967],{"class":1013},[1000,2518,2519],{"class":1020}," username ",[1000,2521,2522],{"class":1013},"AS",[1000,2524,2525],{"class":1013}," name",[1000,2527,2227],{"class":1020},[1000,2529,2522],{"class":1013},[1000,2531,2532],{"class":1020}," mail ",[1000,2534,2425],{"class":1013},[1000,2536,1322],{"class":1020},[1000,2538,2539],{"class":1002,"line":1068},[1000,2540,1028],{"emptyLinePlaceholder":1027},[1000,2542,2543],{"class":1002,"line":1073},[1000,2544,2545],{"class":1006},"-- 去重\n",[1000,2547,2548,2551,2553,2555],{"class":1002,"line":1079},[1000,2549,2550],{"class":1013},"SELECT DISTINCT",[1000,2552,2181],{"class":1013},[1000,2554,2327],{"class":1013},[1000,2556,1322],{"class":1020},[987,2558,2559],{"id":2559},"条件查询",[991,2561,2563],{"className":993,"code":2562,"language":995,"meta":11,"style":11},"-- 比较运算\nSELECT * FROM user WHERE age > 18;\nSELECT * FROM user WHERE age >= 18 AND age \u003C= 30;\nSELECT * FROM user WHERE age BETWEEN 18 AND 30;\n\n-- 空值判断\nSELECT * FROM user WHERE email IS NULL;\nSELECT * FROM user WHERE email IS NOT NULL;\n\n-- IN\nSELECT * FROM user WHERE status IN (0, 1);\n\n-- LIKE 模糊查询\nSELECT * FROM user WHERE username LIKE '张%';   -- 以张开头\nSELECT * FROM user WHERE username LIKE '%三';   -- 以三结尾\nSELECT * FROM user WHERE username LIKE '%三%';  -- 包含三\nSELECT * FROM user WHERE username LIKE '张_';   -- 张+一个字符\n\n-- 逻辑运算\nSELECT * FROM user WHERE age > 18 AND status = 1;\nSELECT * FROM user WHERE age > 30 OR status = 0;\nSELECT * FROM user WHERE NOT status = 0;\n",[997,2564,2565,2570,2592,2624,2649,2653,2658,2681,2700,2704,2709,2737,2741,2746,2772,2796,2821,2845,2849,2854,2882,2911],{"__ignoreMap":11},[1000,2566,2567],{"class":1002,"line":1003},[1000,2568,2569],{"class":1006},"-- 比较运算\n",[1000,2571,2572,2574,2576,2578,2580,2582,2584,2587,2590],{"class":1002,"line":1010},[1000,2573,967],{"class":1013},[1000,2575,2479],{"class":1013},[1000,2577,2327],{"class":1013},[1000,2579,1394],{"class":1020},[1000,2581,2332],{"class":1013},[1000,2583,2262],{"class":1020},[1000,2585,2586],{"class":1013},">",[1000,2588,2589],{"class":1148}," 18",[1000,2591,1302],{"class":1020},[1000,2593,2594,2596,2598,2600,2602,2604,2606,2609,2611,2614,2616,2619,2622],{"class":1002,"line":1024},[1000,2595,967],{"class":1013},[1000,2597,2479],{"class":1013},[1000,2599,2327],{"class":1013},[1000,2601,1394],{"class":1020},[1000,2603,2332],{"class":1013},[1000,2605,2262],{"class":1020},[1000,2607,2608],{"class":1013},">=",[1000,2610,2589],{"class":1148},[1000,2612,2613],{"class":1013}," AND",[1000,2615,2262],{"class":1020},[1000,2617,2618],{"class":1013},"\u003C=",[1000,2620,2621],{"class":1148}," 30",[1000,2623,1302],{"class":1020},[1000,2625,2626,2628,2630,2632,2634,2636,2638,2641,2643,2645,2647],{"class":1002,"line":1031},[1000,2627,967],{"class":1013},[1000,2629,2479],{"class":1013},[1000,2631,2327],{"class":1013},[1000,2633,1394],{"class":1020},[1000,2635,2332],{"class":1013},[1000,2637,2262],{"class":1020},[1000,2639,2640],{"class":1013},"BETWEEN",[1000,2642,2589],{"class":1148},[1000,2644,2613],{"class":1013},[1000,2646,2621],{"class":1148},[1000,2648,1302],{"class":1020},[1000,2650,2651],{"class":1002,"line":1037},[1000,2652,1028],{"emptyLinePlaceholder":1027},[1000,2654,2655],{"class":1002,"line":1048},[1000,2656,2657],{"class":1006},"-- 空值判断\n",[1000,2659,2660,2662,2664,2666,2668,2670,2673,2676,2679],{"class":1002,"line":1053},[1000,2661,967],{"class":1013},[1000,2663,2479],{"class":1013},[1000,2665,2327],{"class":1013},[1000,2667,1394],{"class":1020},[1000,2669,2332],{"class":1013},[1000,2671,2672],{"class":1020}," email ",[1000,2674,2675],{"class":1013},"IS",[1000,2677,2678],{"class":1013}," NULL",[1000,2680,1302],{"class":1020},[1000,2682,2683,2685,2687,2689,2691,2693,2695,2698],{"class":1002,"line":1059},[1000,2684,967],{"class":1013},[1000,2686,2479],{"class":1013},[1000,2688,2327],{"class":1013},[1000,2690,1394],{"class":1020},[1000,2692,2332],{"class":1013},[1000,2694,2672],{"class":1020},[1000,2696,2697],{"class":1013},"IS NOT NULL",[1000,2699,1302],{"class":1020},[1000,2701,2702],{"class":1002,"line":1068},[1000,2703,1028],{"emptyLinePlaceholder":1027},[1000,2705,2706],{"class":1002,"line":1073},[1000,2707,2708],{"class":1006},"-- IN\n",[1000,2710,2711,2713,2715,2717,2719,2721,2723,2726,2728,2731,2733,2735],{"class":1002,"line":1079},[1000,2712,967],{"class":1013},[1000,2714,2479],{"class":1013},[1000,2716,2327],{"class":1013},[1000,2718,1394],{"class":1020},[1000,2720,2332],{"class":1013},[1000,2722,2181],{"class":1013},[1000,2724,2725],{"class":1013}," IN",[1000,2727,2031],{"class":1020},[1000,2729,2730],{"class":1148},"0",[1000,2732,2037],{"class":1020},[1000,2734,1586],{"class":1148},[1000,2736,1449],{"class":1020},[1000,2738,2739],{"class":1002,"line":1305},[1000,2740,1028],{"emptyLinePlaceholder":1027},[1000,2742,2743],{"class":1002,"line":1310},[1000,2744,2745],{"class":1006},"-- LIKE 模糊查询\n",[1000,2747,2748,2750,2752,2754,2756,2758,2760,2763,2766,2769],{"class":1002,"line":1316},[1000,2749,967],{"class":1013},[1000,2751,2479],{"class":1013},[1000,2753,2327],{"class":1013},[1000,2755,1394],{"class":1020},[1000,2757,2332],{"class":1013},[1000,2759,2519],{"class":1020},[1000,2761,2762],{"class":1013},"LIKE",[1000,2764,2765],{"class":1130}," '张%'",[1000,2767,2768],{"class":1020},";   ",[1000,2770,2771],{"class":1006},"-- 以张开头\n",[1000,2773,2774,2776,2778,2780,2782,2784,2786,2788,2791,2793],{"class":1002,"line":1325},[1000,2775,967],{"class":1013},[1000,2777,2479],{"class":1013},[1000,2779,2327],{"class":1013},[1000,2781,1394],{"class":1020},[1000,2783,2332],{"class":1013},[1000,2785,2519],{"class":1020},[1000,2787,2762],{"class":1013},[1000,2789,2790],{"class":1130}," '%三'",[1000,2792,2768],{"class":1020},[1000,2794,2795],{"class":1006},"-- 以三结尾\n",[1000,2797,2798,2800,2802,2804,2806,2808,2810,2812,2815,2818],{"class":1002,"line":1330},[1000,2799,967],{"class":1013},[1000,2801,2479],{"class":1013},[1000,2803,2327],{"class":1013},[1000,2805,1394],{"class":1020},[1000,2807,2332],{"class":1013},[1000,2809,2519],{"class":1020},[1000,2811,2762],{"class":1013},[1000,2813,2814],{"class":1130}," '%三%'",[1000,2816,2817],{"class":1020},";  ",[1000,2819,2820],{"class":1006},"-- 包含三\n",[1000,2822,2823,2825,2827,2829,2831,2833,2835,2837,2840,2842],{"class":1002,"line":1336},[1000,2824,967],{"class":1013},[1000,2826,2479],{"class":1013},[1000,2828,2327],{"class":1013},[1000,2830,1394],{"class":1020},[1000,2832,2332],{"class":1013},[1000,2834,2519],{"class":1020},[1000,2836,2762],{"class":1013},[1000,2838,2839],{"class":1130}," '张_'",[1000,2841,2768],{"class":1020},[1000,2843,2844],{"class":1006},"-- 张+一个字符\n",[1000,2846,2847],{"class":1002,"line":1348},[1000,2848,1028],{"emptyLinePlaceholder":1027},[1000,2850,2851],{"class":1002,"line":1353},[1000,2852,2853],{"class":1006},"-- 逻辑运算\n",[1000,2855,2856,2858,2860,2862,2864,2866,2868,2870,2872,2874,2876,2878,2880],{"class":1002,"line":1359},[1000,2857,967],{"class":1013},[1000,2859,2479],{"class":1013},[1000,2861,2327],{"class":1013},[1000,2863,1394],{"class":1020},[1000,2865,2332],{"class":1013},[1000,2867,2262],{"class":1020},[1000,2869,2586],{"class":1013},[1000,2871,2589],{"class":1148},[1000,2873,2613],{"class":1013},[1000,2875,2181],{"class":1013},[1000,2877,2184],{"class":1013},[1000,2879,1247],{"class":1148},[1000,2881,1302],{"class":1020},[1000,2883,2884,2886,2888,2890,2892,2894,2896,2898,2900,2903,2905,2907,2909],{"class":1002,"line":1376},[1000,2885,967],{"class":1013},[1000,2887,2479],{"class":1013},[1000,2889,2327],{"class":1013},[1000,2891,1394],{"class":1020},[1000,2893,2332],{"class":1013},[1000,2895,2262],{"class":1020},[1000,2897,2586],{"class":1013},[1000,2899,2621],{"class":1148},[1000,2901,2902],{"class":1013}," OR",[1000,2904,2181],{"class":1013},[1000,2906,2184],{"class":1013},[1000,2908,1226],{"class":1148},[1000,2910,1302],{"class":1020},[1000,2912,2913,2915,2917,2919,2921,2923,2926,2928,2930,2932],{"class":1002,"line":1381},[1000,2914,967],{"class":1013},[1000,2916,2479],{"class":1013},[1000,2918,2327],{"class":1013},[1000,2920,1394],{"class":1020},[1000,2922,2332],{"class":1013},[1000,2924,2925],{"class":1013}," NOT",[1000,2927,2181],{"class":1013},[1000,2929,2184],{"class":1013},[1000,2931,1226],{"class":1148},[1000,2933,1302],{"class":1020},[987,2935,2936],{"id":2936},"排序与分页",[991,2938,2940],{"className":993,"code":2939,"language":995,"meta":11,"style":11},"-- 单字段排序\nSELECT * FROM user ORDER BY age;          -- 默认升序\nSELECT * FROM user ORDER BY age DESC;     -- 降序\n\n-- 多字段排序\nSELECT * FROM user ORDER BY status DESC, age ASC;\n\n-- 分页\nSELECT * FROM user LIMIT 10;              -- 前 10 条\nSELECT * FROM user LIMIT 0, 10;           -- 第 1 页\nSELECT * FROM user LIMIT 10, 10;          -- 第 2 页\n\n-- 分页公式：LIMIT (page - 1) * pageSize, pageSize\n",[997,2941,2942,2947,2966,2988,2992,2997,3022,3026,3031,3053,3077,3101,3105],{"__ignoreMap":11},[1000,2943,2944],{"class":1002,"line":1003},[1000,2945,2946],{"class":1006},"-- 单字段排序\n",[1000,2948,2949,2951,2953,2955,2957,2960,2963],{"class":1002,"line":1010},[1000,2950,967],{"class":1013},[1000,2952,2479],{"class":1013},[1000,2954,2327],{"class":1013},[1000,2956,1394],{"class":1020},[1000,2958,2959],{"class":1013},"ORDER BY",[1000,2961,2962],{"class":1020}," age;          ",[1000,2964,2965],{"class":1006},"-- 默认升序\n",[1000,2967,2968,2970,2972,2974,2976,2978,2980,2982,2985],{"class":1002,"line":1024},[1000,2969,967],{"class":1013},[1000,2971,2479],{"class":1013},[1000,2973,2327],{"class":1013},[1000,2975,1394],{"class":1020},[1000,2977,2959],{"class":1013},[1000,2979,2262],{"class":1020},[1000,2981,1319],{"class":1013},[1000,2983,2984],{"class":1020},";     ",[1000,2986,2987],{"class":1006},"-- 降序\n",[1000,2989,2990],{"class":1002,"line":1031},[1000,2991,1028],{"emptyLinePlaceholder":1027},[1000,2993,2994],{"class":1002,"line":1037},[1000,2995,2996],{"class":1006},"-- 多字段排序\n",[1000,2998,2999,3001,3003,3005,3007,3009,3011,3014,3017,3020],{"class":1002,"line":1048},[1000,3000,967],{"class":1013},[1000,3002,2479],{"class":1013},[1000,3004,2327],{"class":1013},[1000,3006,1394],{"class":1020},[1000,3008,2959],{"class":1013},[1000,3010,2181],{"class":1013},[1000,3012,3013],{"class":1013}," DESC",[1000,3015,3016],{"class":1020},", age ",[1000,3018,3019],{"class":1013},"ASC",[1000,3021,1302],{"class":1020},[1000,3023,3024],{"class":1002,"line":1053},[1000,3025,1028],{"emptyLinePlaceholder":1027},[1000,3027,3028],{"class":1002,"line":1059},[1000,3029,3030],{"class":1006},"-- 分页\n",[1000,3032,3033,3035,3037,3039,3041,3044,3047,3050],{"class":1002,"line":1068},[1000,3034,967],{"class":1013},[1000,3036,2479],{"class":1013},[1000,3038,2327],{"class":1013},[1000,3040,1394],{"class":1020},[1000,3042,3043],{"class":1013},"LIMIT",[1000,3045,3046],{"class":1148}," 10",[1000,3048,3049],{"class":1020},";              ",[1000,3051,3052],{"class":1006},"-- 前 10 条\n",[1000,3054,3055,3057,3059,3061,3063,3065,3067,3069,3071,3074],{"class":1002,"line":1073},[1000,3056,967],{"class":1013},[1000,3058,2479],{"class":1013},[1000,3060,2327],{"class":1013},[1000,3062,1394],{"class":1020},[1000,3064,3043],{"class":1013},[1000,3066,1226],{"class":1148},[1000,3068,2037],{"class":1020},[1000,3070,1897],{"class":1148},[1000,3072,3073],{"class":1020},";           ",[1000,3075,3076],{"class":1006},"-- 第 1 页\n",[1000,3078,3079,3081,3083,3085,3087,3089,3091,3093,3095,3098],{"class":1002,"line":1079},[1000,3080,967],{"class":1013},[1000,3082,2479],{"class":1013},[1000,3084,2327],{"class":1013},[1000,3086,1394],{"class":1020},[1000,3088,3043],{"class":1013},[1000,3090,3046],{"class":1148},[1000,3092,2037],{"class":1020},[1000,3094,1897],{"class":1148},[1000,3096,3097],{"class":1020},";          ",[1000,3099,3100],{"class":1006},"-- 第 2 页\n",[1000,3102,3103],{"class":1002,"line":1305},[1000,3104,1028],{"emptyLinePlaceholder":1027},[1000,3106,3107],{"class":1002,"line":1310},[1000,3108,3109],{"class":1006},"-- 分页公式：LIMIT (page - 1) * pageSize, pageSize\n",[987,3111,3112],{"id":3112},"聚合函数",[900,3114,3115,3124],{},[903,3116,3117],{},[906,3118,3119,3122],{},[909,3120,3121],{"align":911},"函数",[909,3123,918],{"align":911},[923,3125,3126,3134,3142,3150,3158],{},[906,3127,3128,3131],{},[928,3129,3130],{"align":911},"COUNT()",[928,3132,3133],{"align":911},"统计数量",[906,3135,3136,3139],{},[928,3137,3138],{"align":911},"SUM()",[928,3140,3141],{"align":911},"求和",[906,3143,3144,3147],{},[928,3145,3146],{"align":911},"AVG()",[928,3148,3149],{"align":911},"平均值",[906,3151,3152,3155],{},[928,3153,3154],{"align":911},"MAX()",[928,3156,3157],{"align":911},"最大值",[906,3159,3160,3163],{},[928,3161,3162],{"align":911},"MIN()",[928,3164,3165],{"align":911},"最小值",[991,3167,3169],{"className":993,"code":3168,"language":995,"meta":11,"style":11},"-- 统计\nSELECT COUNT(*) FROM user;\nSELECT COUNT(email) FROM user;  -- 不统计 NULL\n\n-- 求和、平均\nSELECT SUM(age), AVG(age) FROM user;\n\n-- 最大、最小\nSELECT MAX(age), MIN(age) FROM user;\n",[997,3170,3171,3176,3194,3211,3215,3220,3240,3244,3249],{"__ignoreMap":11},[1000,3172,3173],{"class":1002,"line":1003},[1000,3174,3175],{"class":1006},"-- 统计\n",[1000,3177,3178,3180,3183,3185,3188,3190,3192],{"class":1002,"line":1010},[1000,3179,967],{"class":1013},[1000,3181,3182],{"class":1148}," COUNT",[1000,3184,1145],{"class":1020},[1000,3186,3187],{"class":1013},"*",[1000,3189,1152],{"class":1020},[1000,3191,2425],{"class":1013},[1000,3193,1322],{"class":1020},[1000,3195,3196,3198,3200,3203,3205,3208],{"class":1002,"line":1024},[1000,3197,967],{"class":1013},[1000,3199,3182],{"class":1148},[1000,3201,3202],{"class":1020},"(email) ",[1000,3204,2425],{"class":1013},[1000,3206,3207],{"class":1020}," user;  ",[1000,3209,3210],{"class":1006},"-- 不统计 NULL\n",[1000,3212,3213],{"class":1002,"line":1031},[1000,3214,1028],{"emptyLinePlaceholder":1027},[1000,3216,3217],{"class":1002,"line":1037},[1000,3218,3219],{"class":1006},"-- 求和、平均\n",[1000,3221,3222,3224,3227,3230,3233,3236,3238],{"class":1002,"line":1048},[1000,3223,967],{"class":1013},[1000,3225,3226],{"class":1148}," SUM",[1000,3228,3229],{"class":1020},"(age), ",[1000,3231,3232],{"class":1148},"AVG",[1000,3234,3235],{"class":1020},"(age) ",[1000,3237,2425],{"class":1013},[1000,3239,1322],{"class":1020},[1000,3241,3242],{"class":1002,"line":1053},[1000,3243,1028],{"emptyLinePlaceholder":1027},[1000,3245,3246],{"class":1002,"line":1059},[1000,3247,3248],{"class":1006},"-- 最大、最小\n",[1000,3250,3251,3253,3256,3258,3261,3263,3265],{"class":1002,"line":1068},[1000,3252,967],{"class":1013},[1000,3254,3255],{"class":1148}," MAX",[1000,3257,3229],{"class":1020},[1000,3259,3260],{"class":1148},"MIN",[1000,3262,3235],{"class":1020},[1000,3264,2425],{"class":1013},[1000,3266,1322],{"class":1020},[987,3268,3269],{"id":3269},"分组查询",[991,3271,3273],{"className":993,"code":3272,"language":995,"meta":11,"style":11},"-- 按状态分组统计\nSELECT status, COUNT(*) AS count FROM user GROUP BY status;\n\n-- 分组 + 条件\nSELECT status, COUNT(*) AS count \nFROM user \nWHERE age > 18 \nGROUP BY status \nHAVING count > 5;\n",[997,3274,3275,3280,3313,3317,3322,3343,3350,3362,3370],{"__ignoreMap":11},[1000,3276,3277],{"class":1002,"line":1003},[1000,3278,3279],{"class":1006},"-- 按状态分组统计\n",[1000,3281,3282,3284,3286,3288,3291,3293,3295,3297,3299,3302,3304,3306,3309,3311],{"class":1002,"line":1010},[1000,3283,967],{"class":1013},[1000,3285,2181],{"class":1013},[1000,3287,2037],{"class":1020},[1000,3289,3290],{"class":1148},"COUNT",[1000,3292,1145],{"class":1020},[1000,3294,3187],{"class":1013},[1000,3296,1152],{"class":1020},[1000,3298,2522],{"class":1013},[1000,3300,3301],{"class":1020}," count ",[1000,3303,2425],{"class":1013},[1000,3305,1394],{"class":1020},[1000,3307,3308],{"class":1013},"GROUP BY",[1000,3310,2181],{"class":1013},[1000,3312,1302],{"class":1020},[1000,3314,3315],{"class":1002,"line":1024},[1000,3316,1028],{"emptyLinePlaceholder":1027},[1000,3318,3319],{"class":1002,"line":1031},[1000,3320,3321],{"class":1006},"-- 分组 + 条件\n",[1000,3323,3324,3326,3328,3330,3332,3334,3336,3338,3340],{"class":1002,"line":1037},[1000,3325,967],{"class":1013},[1000,3327,2181],{"class":1013},[1000,3329,2037],{"class":1020},[1000,3331,3290],{"class":1148},[1000,3333,1145],{"class":1020},[1000,3335,3187],{"class":1013},[1000,3337,1152],{"class":1020},[1000,3339,2522],{"class":1013},[1000,3341,3342],{"class":1020}," count \n",[1000,3344,3345,3347],{"class":1002,"line":1048},[1000,3346,2425],{"class":1013},[1000,3348,3349],{"class":1020}," user \n",[1000,3351,3352,3354,3356,3358,3360],{"class":1002,"line":1053},[1000,3353,2332],{"class":1013},[1000,3355,2262],{"class":1020},[1000,3357,2586],{"class":1013},[1000,3359,2589],{"class":1148},[1000,3361,2071],{"class":1020},[1000,3363,3364,3366,3368],{"class":1002,"line":1059},[1000,3365,3308],{"class":1013},[1000,3367,2181],{"class":1013},[1000,3369,2071],{"class":1020},[1000,3371,3372,3375,3377,3379,3382],{"class":1002,"line":1068},[1000,3373,3374],{"class":1013},"HAVING",[1000,3376,3301],{"class":1020},[1000,3378,2586],{"class":1013},[1000,3380,3381],{"class":1148}," 5",[1000,3383,1302],{"class":1020},[892,3385,3386],{},[1557,3387,3388],{},"WHERE vs HAVING",[900,3390,3391,3402],{},[903,3392,3393],{},[906,3394,3395,3398,3400],{},[909,3396,3397],{"align":911},"对比",[909,3399,2332],{"align":911},[909,3401,3374],{"align":911},[923,3403,3404,3415],{},[906,3405,3406,3409,3412],{},[928,3407,3408],{"align":911},"执行时机",[928,3410,3411],{"align":911},"分组前过滤",[928,3413,3414],{"align":911},"分组后过滤",[906,3416,3417,3420,3423],{},[928,3418,3419],{"align":911},"能否用聚合",[928,3421,3422],{"align":911},"❌",[928,3424,3425],{"align":911},"✅",[895,3427,3429],{"id":3428},"dcl-权限控制","DCL - 权限控制",[987,3431,3432],{"id":3432},"用户管理",[991,3434,3436],{"className":993,"code":3435,"language":995,"meta":11,"style":11},"-- 创建用户\nCREATE USER 'username'@'localhost' IDENTIFIED BY 'password';\nCREATE USER 'username'@'%' IDENTIFIED BY 'password';  -- 允许远程\n\n-- 修改密码\nALTER USER 'username'@'localhost' IDENTIFIED BY 'new_password';\n\n-- 删除用户\nDROP USER 'username'@'localhost';\n\n-- 查看用户\nSELECT user, host FROM mysql.user;\n",[997,3437,3438,3443,3473,3499,3503,3508,3531,3535,3540,3554,3558,3563],{"__ignoreMap":11},[1000,3439,3440],{"class":1002,"line":1003},[1000,3441,3442],{"class":1006},"-- 创建用户\n",[1000,3444,3445,3447,3450,3453,3456,3459,3462,3465,3468,3471],{"class":1002,"line":1010},[1000,3446,1014],{"class":1013},[1000,3448,3449],{"class":1013}," USER",[1000,3451,3452],{"class":1020}," '",[1000,3454,3455],{"class":1109},"username",[1000,3457,3458],{"class":1020},"'@",[1000,3460,3461],{"class":1130},"'localhost'",[1000,3463,3464],{"class":1020}," IDENTIFIED ",[1000,3466,3467],{"class":1013},"BY",[1000,3469,3470],{"class":1130}," 'password'",[1000,3472,1302],{"class":1020},[1000,3474,3475,3477,3479,3481,3483,3485,3488,3490,3492,3494,3496],{"class":1002,"line":1024},[1000,3476,1014],{"class":1013},[1000,3478,3449],{"class":1013},[1000,3480,3452],{"class":1020},[1000,3482,3455],{"class":1109},[1000,3484,3458],{"class":1020},[1000,3486,3487],{"class":1130},"'%'",[1000,3489,3464],{"class":1020},[1000,3491,3467],{"class":1013},[1000,3493,3470],{"class":1130},[1000,3495,2817],{"class":1020},[1000,3497,3498],{"class":1006},"-- 允许远程\n",[1000,3500,3501],{"class":1002,"line":1031},[1000,3502,1028],{"emptyLinePlaceholder":1027},[1000,3504,3505],{"class":1002,"line":1037},[1000,3506,3507],{"class":1006},"-- 修改密码\n",[1000,3509,3510,3512,3514,3517,3520,3522,3524,3526,3529],{"class":1002,"line":1048},[1000,3511,1362],{"class":1013},[1000,3513,3449],{"class":1013},[1000,3515,3516],{"class":1130}," 'username'",[1000,3518,3519],{"class":1020},"@",[1000,3521,3461],{"class":1130},[1000,3523,3464],{"class":1020},[1000,3525,3467],{"class":1013},[1000,3527,3528],{"class":1130}," 'new_password'",[1000,3530,1302],{"class":1020},[1000,3532,3533],{"class":1002,"line":1053},[1000,3534,1028],{"emptyLinePlaceholder":1027},[1000,3536,3537],{"class":1002,"line":1059},[1000,3538,3539],{"class":1006},"-- 删除用户\n",[1000,3541,3542,3544,3546,3548,3550,3552],{"class":1002,"line":1068},[1000,3543,1040],{"class":1013},[1000,3545,3449],{"class":1013},[1000,3547,3516],{"class":1130},[1000,3549,3519],{"class":1020},[1000,3551,3461],{"class":1130},[1000,3553,1302],{"class":1020},[1000,3555,3556],{"class":1002,"line":1073},[1000,3557,1028],{"emptyLinePlaceholder":1027},[1000,3559,3560],{"class":1002,"line":1079},[1000,3561,3562],{"class":1006},"-- 查看用户\n",[1000,3564,3565,3567,3570,3572,3575,3578,3581],{"class":1002,"line":1305},[1000,3566,967],{"class":1013},[1000,3568,3569],{"class":1020}," user, host ",[1000,3571,2425],{"class":1013},[1000,3573,3574],{"class":1148}," mysql",[1000,3576,3577],{"class":1020},".",[1000,3579,3580],{"class":1148},"user",[1000,3582,1302],{"class":1020},[987,3584,3585],{"id":3585},"权限管理",[991,3587,3589],{"className":993,"code":3588,"language":995,"meta":11,"style":11},"-- 授权\nGRANT ALL PRIVILEGES ON db_name.* TO 'username'@'localhost';\nGRANT SELECT, INSERT ON db_name.table_name TO 'username'@'%';\n\n-- 查看权限\nSHOW GRANTS FOR 'username'@'localhost';\n\n-- 撤销权限\nREVOKE ALL PRIVILEGES ON db_name.* FROM 'username'@'localhost';\n\n-- 刷新权限\nFLUSH PRIVILEGES;\n",[997,3590,3591,3596,3623,3655,3659,3664,3680,3684,3689,3712,3716,3721],{"__ignoreMap":11},[1000,3592,3593],{"class":1002,"line":1003},[1000,3594,3595],{"class":1006},"-- 授权\n",[1000,3597,3598,3601,3604,3607,3610,3612,3615,3617,3619,3621],{"class":1002,"line":1010},[1000,3599,3600],{"class":1013},"GRANT",[1000,3602,3603],{"class":1020}," ALL PRIVILEGES ",[1000,3605,3606],{"class":1013},"ON",[1000,3608,3609],{"class":1020}," db_name.",[1000,3611,3187],{"class":1013},[1000,3613,3614],{"class":1013}," TO",[1000,3616,3516],{"class":1130},[1000,3618,3519],{"class":1020},[1000,3620,3461],{"class":1130},[1000,3622,1302],{"class":1020},[1000,3624,3625,3627,3630,3632,3634,3637,3640,3642,3645,3647,3649,3651,3653],{"class":1002,"line":1024},[1000,3626,3600],{"class":1013},[1000,3628,3629],{"class":1013}," SELECT",[1000,3631,2037],{"class":1020},[1000,3633,1999],{"class":1013},[1000,3635,3636],{"class":1013}," ON",[1000,3638,3639],{"class":1148}," db_name",[1000,3641,3577],{"class":1020},[1000,3643,3644],{"class":1148},"table_name",[1000,3646,3614],{"class":1013},[1000,3648,3516],{"class":1130},[1000,3650,3519],{"class":1020},[1000,3652,3487],{"class":1130},[1000,3654,1302],{"class":1020},[1000,3656,3657],{"class":1002,"line":1031},[1000,3658,1028],{"emptyLinePlaceholder":1027},[1000,3660,3661],{"class":1002,"line":1037},[1000,3662,3663],{"class":1006},"-- 查看权限\n",[1000,3665,3666,3669,3672,3674,3676,3678],{"class":1002,"line":1048},[1000,3667,3668],{"class":1020},"SHOW GRANTS ",[1000,3670,3671],{"class":1013},"FOR",[1000,3673,3516],{"class":1130},[1000,3675,3519],{"class":1020},[1000,3677,3461],{"class":1130},[1000,3679,1302],{"class":1020},[1000,3681,3682],{"class":1002,"line":1053},[1000,3683,1028],{"emptyLinePlaceholder":1027},[1000,3685,3686],{"class":1002,"line":1059},[1000,3687,3688],{"class":1006},"-- 撤销权限\n",[1000,3690,3691,3694,3696,3698,3700,3702,3704,3706,3708,3710],{"class":1002,"line":1068},[1000,3692,3693],{"class":1013},"REVOKE",[1000,3695,3603],{"class":1020},[1000,3697,3606],{"class":1013},[1000,3699,3609],{"class":1020},[1000,3701,3187],{"class":1013},[1000,3703,2327],{"class":1013},[1000,3705,3516],{"class":1130},[1000,3707,3519],{"class":1020},[1000,3709,3461],{"class":1130},[1000,3711,1302],{"class":1020},[1000,3713,3714],{"class":1002,"line":1073},[1000,3715,1028],{"emptyLinePlaceholder":1027},[1000,3717,3718],{"class":1002,"line":1079},[1000,3719,3720],{"class":1006},"-- 刷新权限\n",[1000,3722,3723],{"class":1002,"line":1305},[1000,3724,3725],{"class":1020},"FLUSH PRIVILEGES;\n",[900,3727,3728,3737],{},[903,3729,3730],{},[906,3731,3732,3735],{},[909,3733,3734],{"align":911},"权限",[909,3736,918],{"align":911},[923,3738,3739,3747,3754,3761,3768,3775,3782,3788],{},[906,3740,3741,3744],{},[928,3742,3743],{"align":911},"ALL",[928,3745,3746],{"align":911},"所有权限",[906,3748,3749,3751],{},[928,3750,967],{"align":911},[928,3752,3753],{"align":911},"查询",[906,3755,3756,3758],{},[928,3757,1999],{"align":911},[928,3759,3760],{"align":911},"插入",[906,3762,3763,3765],{},[928,3764,2159],{"align":911},[928,3766,3767],{"align":911},"更新",[906,3769,3770,3772],{},[928,3771,2310],{"align":911},[928,3773,3774],{"align":911},"删除",[906,3776,3777,3779],{},[928,3778,1014],{"align":911},[928,3780,3781],{"align":911},"创建",[906,3783,3784,3786],{},[928,3785,1040],{"align":911},[928,3787,3774],{"align":911},[906,3789,3790,3792],{},[928,3791,1362],{"align":911},[928,3793,3794],{"align":911},"修改",[3796,3797,3798],"style",{},"html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}",{"title":11,"searchDepth":1010,"depth":1010,"links":3800},[3801,3802,3808,3813,3821],{"id":897,"depth":1010,"text":898},{"id":984,"depth":1010,"text":985,"children":3803},[3804,3805,3806,3807],{"id":989,"depth":1024,"text":989},{"id":1089,"depth":1024,"text":1089},{"id":1553,"depth":1024,"text":1553},{"id":1761,"depth":1024,"text":1761},{"id":1994,"depth":1010,"text":1995,"children":3809},[3810,3811,3812],{"id":1998,"depth":1024,"text":1999},{"id":2158,"depth":1024,"text":2159},{"id":2309,"depth":1024,"text":2310},{"id":2404,"depth":1010,"text":2405,"children":3814},[3815,3816,3817,3818,3819,3820],{"id":2408,"depth":1024,"text":2408},{"id":2462,"depth":1024,"text":2462},{"id":2559,"depth":1024,"text":2559},{"id":2936,"depth":1024,"text":2936},{"id":3112,"depth":1024,"text":3112},{"id":3269,"depth":1024,"text":3269},{"id":3428,"depth":1010,"text":3429,"children":3822},[3823,3824],{"id":3432,"depth":1024,"text":3432},{"id":3585,"depth":1024,"text":3585},"md",{},{"title":738,"description":739},"tutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","jSrT0181-NZkqZAUneXtSnA9FVya8mJNzcaSibO73X4",1775496410782]