<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>学习 on Howe&#39;s Blog</title>
    <link>https://howe.wang/categories/%E5%AD%A6%E4%B9%A0/</link>
    <description>Recent content in 学习 on Howe&#39;s Blog</description>
    <generator>Hugo -- 0.147.7</generator>
    <language>zh-CN</language>
    <lastBuildDate>Sat, 07 Jun 2025 14:02:08 +0800</lastBuildDate>
    <atom:link href="https://howe.wang/categories/%E5%AD%A6%E4%B9%A0/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>ZFile学习笔记——启动！</title>
      <link>https://howe.wang/posts/zfile-start/</link>
      <pubDate>Sat, 07 Jun 2025 14:02:08 +0800</pubDate>
      <guid>https://howe.wang/posts/zfile-start/</guid>
      <description>&lt;h2 id=&#34;项目介绍&#34;&gt;项目介绍&lt;/h2&gt;
&lt;blockquote&gt;
&lt;p&gt;ZFile 是一个适用于个人或小团队的在线网盘程序，可以将多种存储类型统一管理，再也不用登录各种网站管理文件，现在你只需要在 ZFile 中畅快使用！——GitHub README&lt;/p&gt;&lt;/blockquote&gt;
&lt;p&gt;我第一次见到这个项目是在折腾LG手机刷机的时候发现的，有人用它托管刷机包。后来我自己把它部署到服务器上试了一下，发现可以很方便的挂载OneDrive，并且可以直接生成下载链接。&lt;/p&gt;
&lt;p&gt;最近在学习Java项目，但是网上找到的学习项目都是玩具项目(黑马全家桶、各种知识星球项目)，他们很多都存在功能简陋、代码不规范、没有完善的配套前端等等问题&amp;hellip;&amp;hellip;最重要的是项目的需求和功能都是虚拟的，根本没有实际意义。于是想到了之前用过的ZFile恰好就是用Java开发的，并且复杂程度貌似并不高🤨(我猜的)，用来学习实际的Java项目岂不是完美？&lt;/p&gt;
&lt;h2 id=&#34;zfile使用的技术&#34;&gt;ZFile使用的技术&lt;/h2&gt;
&lt;p&gt;把项目从GitHub上克隆下来后我首先查看了maven的配置文件&lt;code&gt;pom.xml&lt;/code&gt;，从中可以查看该项目所使用到的技术。&lt;/p&gt;
&lt;h3 id=&#34;1-springboot与java版本&#34;&gt;1. SpringBoot与Java版本&lt;/h3&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-xml&#34; data-lang=&#34;xml&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;&amp;lt;parent&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;nt&#34;&gt;&amp;lt;groupId&amp;gt;&lt;/span&gt;org.springframework.boot&lt;span class=&#34;nt&#34;&gt;&amp;lt;/groupId&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;nt&#34;&gt;&amp;lt;artifactId&amp;gt;&lt;/span&gt;spring-boot-starter-parent&lt;span class=&#34;nt&#34;&gt;&amp;lt;/artifactId&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;nt&#34;&gt;&amp;lt;version&amp;gt;&lt;/span&gt;3.3.2&lt;span class=&#34;nt&#34;&gt;&amp;lt;/version&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;  &lt;span class=&#34;nt&#34;&gt;&amp;lt;relativePath/&amp;gt;&lt;/span&gt; &lt;span class=&#34;c&#34;&gt;&amp;lt;!-- 不要去本地找父 POM，而是直接去仓库下载它 --&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;&amp;lt;/parent&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;...
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;&amp;lt;java.version&amp;gt;&lt;/span&gt;21&lt;span class=&#34;nt&#34;&gt;&amp;lt;/java.version&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;&amp;lt;maven.compiler.source&amp;gt;&lt;/span&gt;21&lt;span class=&#34;nt&#34;&gt;&amp;lt;/maven.compiler.source&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;&amp;lt;maven.compiler.target&amp;gt;&lt;/span&gt;21&lt;span class=&#34;nt&#34;&gt;&amp;lt;/maven.compiler.target&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;使用&lt;code&gt;Spring Boot 3.3.2&lt;/code&gt;作为基础框架并使用&lt;code&gt;Java 21&lt;/code&gt;，表明这个项目的技术是比较新的。&lt;/p&gt;
&lt;h3 id=&#34;2依赖&#34;&gt;2.依赖&lt;/h3&gt;
&lt;p&gt;依赖分为几大类，反映了项目的功能模块和技术栈：&lt;/p&gt;
&lt;h4 id=&#34;spring-boot相关&#34;&gt;&lt;strong&gt;Spring Boot相关&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;spring-boot-starter-web: 提供Web开发支持，用于构建RESTful API或Web应用。&lt;/li&gt;
&lt;li&gt;spring-boot-starter-aop: 支持面向切面编程（AOP），用于日志、事务等横切关注点。&lt;/li&gt;
&lt;li&gt;spring-boot-configuration-processor: 生成配置元数据，支持Spring Boot的自动配置。&lt;/li&gt;
&lt;li&gt;spring-boot-starter-data-redis: Redis支持，可能用于缓存或会话管理。&lt;/li&gt;
&lt;li&gt;spring-boot-starter-cache: 提供缓存支持，可能与Redis结合使用。&lt;/li&gt;
&lt;li&gt;spring-boot-starter-thymeleaf: Thymeleaf模板引擎，用于服务端渲染HTML页面。&lt;/li&gt;
&lt;li&gt;spring-boot-starter-validation: Hibernate Validator，用于参数校验。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;数据库相关&#34;&gt;&lt;strong&gt;数据库相关&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;mysql-connector-j: MySQL数据库驱动（运行时依赖）。&lt;/li&gt;
&lt;li&gt;sqlite-jdbc: SQLite数据库驱动，支持轻量级数据库。&lt;/li&gt;
&lt;li&gt;flyway-core, flyway-mysql: Flyway数据库迁移工具（版本10.12.0），用于数据库版本管理和Schema迁移。&lt;/li&gt;
&lt;li&gt;mybatis-plus-spring-boot3-starter: MyBatis-Plus（版本3.5.6），增强型ORM框架，简化数据库操作。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;存储策略相关&#34;&gt;&lt;strong&gt;存储策略相关&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;upyun java-sdk: 又拍云存储SDK。&lt;/li&gt;
&lt;li&gt;software.amazon.awssdk:s3: AWS S3存储支持。&lt;/li&gt;
&lt;li&gt;qiniu-java-sdk: 七牛云存储SDK。&lt;/li&gt;
&lt;li&gt;jsch: SSH/SFTP支持，可能用于文件传输。&lt;/li&gt;
&lt;li&gt;sardine: WebDAV协议支持。&lt;/li&gt;
&lt;li&gt;google-api-client: Google API客户端，可能用于Google Drive等存储服务。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;认证权限&#34;&gt;&lt;strong&gt;认证/权限&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;sa-token-spring-boot3-starter: Sa-Token（版本1.38.0），轻量级认证授权框架，可能用于用户登录、权限管理和会话控制。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;api文档&#34;&gt;&lt;strong&gt;API文档&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;knife4j-openapi3-jakarta-spring-boot-starter: Knife4j（版本4.5.0），基于OpenAPI 3的API文档生成工具，提供交互式API文档。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;工具类&#34;&gt;&lt;strong&gt;工具类&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;hutool-all: Hutool工具库，提供丰富的Java工具方法。&lt;/li&gt;
&lt;li&gt;poi-ooxml: Apache POI，用于处理Excel、Word等Office文档。&lt;/li&gt;
&lt;li&gt;commons-compress: 文件压缩/解压支持。&lt;/li&gt;
&lt;li&gt;lombok: 简化Java代码（如自动生成Getter/Setter）。&lt;/li&gt;
&lt;li&gt;commons-net: 网络工具库，支持FTP、Telnet等协议。&lt;/li&gt;
&lt;li&gt;okhttp: HTTP客户端，用于网络请求。&lt;/li&gt;
&lt;li&gt;fastjson2: JSON处理库，性能优异。&lt;/li&gt;
&lt;li&gt;guava: Google Guava工具库，提供集合、缓存等功能。&lt;/li&gt;
&lt;li&gt;mapstruct: 对象映射工具，简化DTO与实体转换。&lt;/li&gt;
&lt;li&gt;commons-chain: 责任链模式实现。&lt;/li&gt;
&lt;li&gt;totp: 时间戳一次性密码（TOTP），可能用于双因素认证。&lt;/li&gt;
&lt;li&gt;jcommander: 命令行参数解析。&lt;/li&gt;
&lt;li&gt;json: JSON处理库。&lt;/li&gt;
&lt;li&gt;httpclient5, httpmime: Apache HttpClient，支持HTTP请求和文件上传。&lt;/li&gt;
&lt;li&gt;bcprov-jdk15on: Bouncy Castle加密库，支持加密操作。&lt;/li&gt;
&lt;li&gt;spring-retry: Spring重试机制，处理失败重试逻辑。&lt;/li&gt;
&lt;li&gt;commons-fileupload: 文件上传支持。&lt;/li&gt;
&lt;li&gt;dns-cache-manipulator: DNS缓存操作，可能用于优化网络请求。&lt;/li&gt;
&lt;li&gt;oshi-core: 系统监控库，用于获取系统资源信息。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;graalvm支持&#34;&gt;&lt;strong&gt;GraalVM支持&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;graal-sdk: GraalVM SDK（版本24.1.0，provided scope），用于支持GraalVM原生镜像编译。&lt;/li&gt;
&lt;/ul&gt;
&lt;h4 id=&#34;构建配置&#34;&gt;&lt;strong&gt;构建配置（&lt;build&gt;）&lt;/strong&gt;&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;插件
&lt;ul&gt;
&lt;li&gt;spring-boot-maven-plugin: Spring Boot构建插件，支持打包可执行JAR。&lt;/li&gt;
&lt;li&gt;maven-compiler-plugin: 配置Java 21编译，启用MapStruct、Lombok等注解处理器。&lt;/li&gt;
&lt;li&gt;flyway-maven-plugin: Flyway数据库迁移插件，用于执行数据库迁移任务。&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Profiles
&lt;ul&gt;
&lt;li&gt;使用 native-maven-plugin（GraalVM构建工具）。&lt;/li&gt;
&lt;li&gt;配置了特定的JVM参数和构建参数（如-march=compatibility, AddAllCharsets等）。&lt;/li&gt;
&lt;li&gt;启用了自定义的AOT（Ahead-of-Time）特性，包括Lambda、加密（Bouncy Castle）和SQLite支持。&lt;/li&gt;
&lt;li&gt;项目支持GraalVM原生编译，以提高启动性能和降低内存占用。&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;zfile的功能&#34;&gt;ZFile的功能&lt;/h2&gt;
&lt;p&gt;在深入ZFile的源码之前我打算先把它的基本功能搞清楚，然后按照不同的功能模块分别去细致地学习代码实现。&lt;/p&gt;</description>
    </item>
    <item>
      <title>计算机中的数字</title>
      <link>https://howe.wang/posts/number-in-computer/</link>
      <pubDate>Wed, 27 Jul 2022 00:00:00 +0000</pubDate>
      <guid>https://howe.wang/posts/number-in-computer/</guid>
      <description>&lt;h2 id=&#34;计算机中的数字是如何表示的&#34;&gt;计算机中的数字是如何表示的&lt;/h2&gt;
&lt;p&gt;由于计算机所使用的硬件特性，导致了在计算机的底层数字只能以二进制的形式进行表达。二进制和十进制一样，也是一种进位计数制，但是它的基数是 2。二进制表达式中 0 和 1 的位置不同，它所代表的数值也不同。例如，二进制数 &lt;code&gt;0000 1010&lt;/code&gt; 表示十进制数 10。&lt;strong&gt;一个二进制数具有两个基本特点：两个不同的数字符号，即 0 和 1，逢二进一。&lt;/strong&gt;&lt;/p&gt;
&lt;blockquote&gt;
&lt;p&gt;&lt;a href=&#34;https://zh.wikipedia.org/zh-cn/%E4%BA%8C%E8%BF%9B%E5%88%B6&#34;&gt;关于二进制的维基百科解释&lt;/a&gt;&lt;/p&gt;&lt;/blockquote&gt;
&lt;h2 id=&#34;无符号数&#34;&gt;无符号数&lt;/h2&gt;
&lt;p&gt;无符号数顾名思义就是单纯的数字，没有正负号也没有小数点，是非负整数。这一类型的数字表示起来最简单，只需用二进制的方式写出即可。&lt;/p&gt;
&lt;p&gt;为了更加清楚的解释无符号数的表示方法CSAPP中介绍了一种图形化的表示方法来帮助读者理解无符号数的编码方式。&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;图片来自b站up九曲阑干&#34; loading=&#34;lazy&#34; src=&#34;https://images.howe.wang/number-1.webp&#34;&gt;&lt;/p&gt;
&lt;p&gt;二进制数从右往左的第&lt;code&gt;i&lt;/code&gt;位即表示为$2^{i-1}$，将不为0的项相加得到所表示的无符号数。&lt;/p&gt;
&lt;h2 id=&#34;有符号数&#34;&gt;有符号数&lt;/h2&gt;
&lt;p&gt;在现实世界中，无符号数的局限性是相当大的，那么拥有正负号的数字该如何进行编码呢？&lt;/p&gt;
&lt;p&gt;计算机中使用&lt;a href=&#34;https://zh.wikipedia.org/zh-cn/%E4%BA%8C%E8%A3%9C%E6%95%B8&#34;&gt;补码&lt;/a&gt;来表示有符号数，简单的来说就是在无符号数表示方法的基础上新增了一个符号位以表示正负。最高位若为&lt;code&gt;0&lt;/code&gt;则表示正数，最高位若为&lt;code&gt;1&lt;/code&gt;则表示负数。需要注意的是，符号位并不是单纯的表示数的正负性，它代表负权重的概念。&lt;/p&gt;
&lt;p&gt;若一个有符号数的二进制形式如下：&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;图片来自b站up九曲阑干&#34; loading=&#34;lazy&#34; src=&#34;https://images.howe.wang/number-2.webp&#34;&gt;&lt;/p&gt;
&lt;p&gt;那么它的十进制的计算方法为：&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;图片来自b站up九曲阑干&#34; loading=&#34;lazy&#34; src=&#34;https://images.howe.wang/number-3.webp&#34;&gt;&lt;/p&gt;
&lt;p&gt;两个例子：&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;图片来自b站up九曲阑干&#34; loading=&#34;lazy&#34; src=&#34;https://images.howe.wang/number-4.webp&#34;&gt;&lt;/p&gt;
&lt;p&gt;为了便于理解，补码也有对应的图形化表示方式：&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;图片来自b站up九曲阑干&#34; loading=&#34;lazy&#34; src=&#34;https://images.howe.wang/number-5.webp&#34;&gt;&lt;/p&gt;
&lt;p&gt;其中蓝色代表正数，灰色代表负数，由图可知当最高位为&lt;code&gt;1&lt;/code&gt;时得到的必定为负数。&lt;/p&gt;
&lt;h2 id=&#34;数字的表示范围&#34;&gt;数字的表示范围&lt;/h2&gt;
&lt;h3 id=&#34;无符号数的表示范围&#34;&gt;无符号数的表示范围&lt;/h3&gt;
&lt;p&gt;对于无符号数，当字长为n时，其能表示的最大数为：$$1\times 2^{0} +1\times 2^{1} +\dots +1\times 2^{n-1} =2^{n} -1$$&lt;/p&gt;
&lt;p&gt;字长为&lt;code&gt;8&lt;/code&gt;到&lt;code&gt;64&lt;/code&gt;的无符号数所能表示的范围图表：&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;图片来自b站up九曲阑干&#34; loading=&#34;lazy&#34; src=&#34;https://images.howe.wang/number-6.webp&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;有符号数的表示范围&#34;&gt;有符号数的表示范围&lt;/h3&gt;
&lt;p&gt;有符号数与无符号数的区别在于其最高位充当符号位，所以只有&lt;code&gt;n-1&lt;/code&gt;位能够表示数的大小。&lt;/p&gt;
&lt;p&gt;所能表示的最大值为：$$1\times 2^{0} +1\times 2^{1} +\dots +1\times 2^{n-2} - 0\times 2^{n-1} =2^{n-1} -1$$&lt;/p&gt;
&lt;p&gt;所能表示的最小值为：$$0\times 2^{0} +0\times 2^{1} +\dots +0\times 2^{n-2} - 1\times 2^{n-1} =-2^{n-1}$$&lt;/p&gt;</description>
    </item>
    <item>
      <title>Git基础命令</title>
      <link>https://howe.wang/posts/git-use/</link>
      <pubDate>Fri, 08 Apr 2022 00:00:00 +0000</pubDate>
      <guid>https://howe.wang/posts/git-use/</guid>
      <description>&lt;h2 id=&#34;获取-git-仓库&#34;&gt;获取 Git 仓库&lt;/h2&gt;
&lt;p&gt;通常有两种获取 Git 项目仓库的方式：&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;将尚未进行版本控制的本地目录转换为 Git 仓库；&lt;/li&gt;
&lt;li&gt;从其它服务器&lt;strong&gt;克隆&lt;/strong&gt;一个已存在的 Git 仓库。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;两种方式都会在你的本地机器上得到一个工作就绪的 Git 仓库。&lt;/p&gt;
&lt;h3 id=&#34;在已存在目录中初始化仓库&#34;&gt;在已存在目录中初始化仓库&lt;/h3&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;git init
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;该命令将创建一个名为&lt;code&gt; .git&lt;/code&gt;的子目录，这个子目录含有你初始化的 Git 仓库中所有的必须文件，这些文件是Git 仓库的骨干。 但是，在这个时候，我们仅仅是做了一个初始化的操作，你的项目里的文件还没有被跟踪。&lt;/p&gt;
&lt;h3 id=&#34;克隆现有的仓库&#34;&gt;克隆现有的仓库&lt;/h3&gt;
&lt;p&gt;克隆仓库的命令是 &lt;code&gt;git clone &amp;lt;url&amp;gt;&lt;/code&gt;。比如，要克隆 Git 的链接库&lt;strong&gt;libgit2&lt;/strong&gt;，可以用下面的命令：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;git clone https://github.com/libgit2/libgit2
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;这会在当前目录下创建一个名为&lt;code&gt;libgit2&lt;/code&gt;的目录，并在这个目录下初始化一个&lt;code&gt; .git&lt;/code&gt;文件夹， 从远程仓库拉取下所有数据放入&lt;code&gt; .git&lt;/code&gt;文件夹，然后从中读取最新版本的文件的拷贝。 如果你进入到这个新建的&lt;code&gt; libgit2&lt;/code&gt;文件夹，你会发现所有的项目文件已经在里面了，准备就绪等待后续的开发和使用。&lt;/p&gt;
&lt;p&gt;如果你想在克隆远程仓库的时候，自定义本地仓库的名字，你可以通过额外的参数指定新的目录名：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;git clone https://github.com/libgit2/libgit2 mylibgit
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;这会执行与上一条命令相同的操作，但目标目录名变为了&lt;code&gt;mylibgit&lt;/code&gt;。&lt;/p&gt;
&lt;h2 id=&#34;记录每次更新到仓库&#34;&gt;记录每次更新到仓库&lt;/h2&gt;
&lt;p&gt;现在我们的机器上有了一个&lt;strong&gt;真实项目&lt;/strong&gt;的 Git 仓库，并从这个仓库中检出了所有文件的&lt;strong&gt;工作副本&lt;/strong&gt;。 通常，你会对这些文件做些修改，每当完成了一个阶段的目标，想要将记录下它时，就将它提交到仓库。&lt;/p&gt;
&lt;p&gt;请记住，你工作目录下的每一个文件都不外乎这两种状态：&lt;strong&gt;已跟踪(tracked)&lt;strong&gt;或&lt;/strong&gt;未跟踪(untracked)&lt;/strong&gt;。 已跟踪的文件是指那些被纳入了版本控制的文件，在上一次快照中有它们的记录，在工作一段时间后， 它们的状态可能是未修改，已修改或已放入暂存区。简而言之，已跟踪的文件就是 Git 已经知道的文件。&lt;/p&gt;
&lt;p&gt;工作目录中除已跟踪文件外的其它所有文件都属于未跟踪文件，它们既不存在于上次快照的记录中，也没有被放入暂存区。 初次克隆某个仓库的时候，工作目录中的所有文件都属于已跟踪文件，并处于未修改状态，因为 Git刚刚检出了它们， 而你尚未编辑过它们。&lt;/p&gt;
&lt;p&gt;编辑过某些文件之后，由于自上次提交后你对它们做了修改，Git 将它们标记为已修改文件。 在工作时，你可以选择性地将这些修改过的文件放入暂存区，然后提交所有已暂存的修改，如此反复。&lt;/p&gt;
&lt;p&gt;&lt;img alt=&#34;文件的状态变化周期&#34; loading=&#34;lazy&#34; src=&#34;https://cdn.jsdelivr.net/gh/aahowe/image@main/screen_2022-04-08%2022.25.14.jpg&#34;&gt;&lt;/p&gt;
&lt;h3 id=&#34;检查当前文件状态&#34;&gt;检查当前文件状态&lt;/h3&gt;
&lt;p&gt;可以用 &lt;code&gt;git status&lt;/code&gt;命令查看哪些文件处于什么状态。如果在克隆仓库后立即使用此命令，会看到类似这样的输出：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;$ git status 
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;On branch master
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;Your branch is up-to-date with &lt;span class=&#34;s1&#34;&gt;&amp;#39;origin/master&amp;#39;&lt;/span&gt;.
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;nothing to commit, working directory clean
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;跟踪新文件&#34;&gt;跟踪新文件&lt;/h3&gt;
&lt;p&gt;使用命令&lt;code&gt;git add&lt;/code&gt;开始跟踪一个文件。所以，要跟踪&lt;code&gt;README&lt;/code&gt;文件，运行：&lt;/p&gt;</description>
    </item>
    <item>
      <title>SQL语句笔记</title>
      <link>https://howe.wang/posts/sql/</link>
      <pubDate>Wed, 30 Mar 2022 00:00:00 +0000</pubDate>
      <guid>https://howe.wang/posts/sql/</guid>
      <description>&lt;h2 id=&#34;本文所使用的数据库&#34;&gt;本文所使用的数据库&lt;/h2&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-sql&#34; data-lang=&#34;sql&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;o&#34;&gt;//&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;学生：学号&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;S&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;姓名&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Sname&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;性别&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Ssex&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;年龄&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Sage&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;所属系别&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;D&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;，班级&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Sclass&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Student&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;S&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;8&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Sname&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;10&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Ssex&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;2&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Sage&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;integer&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;D&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;2&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Sclass&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;6&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;//&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;院系：系别&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;D&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;，系名&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Dname&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;系主任&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Dean&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Dept&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;D&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;2&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Dname&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;10&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Dean&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;10&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;//&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;课程：课号&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;C&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;课名&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Cname&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;教师编号&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;  &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;学时&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Chours&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;，学分&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Credit&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Course&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;C&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;3&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Cname&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;12&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Chours&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;integer&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Credit&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;float&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;1&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;3&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;//&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;教师：教师编号&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;，教师名&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Tname&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;所属院系&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;D&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;，工资&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Salary&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Teacher&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;T&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;3&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Tname&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;10&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;D&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;2&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Salary&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;float&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;2&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;//&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;选课：学号&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;S&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;课号&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;C&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;成绩&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Score&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;SC&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;S&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;8&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;C&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;#&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;char&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;3&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;),&lt;/span&gt;&lt;span class=&#34;n&#34;&gt;Score&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;nb&#34;&gt;float&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;mi&#34;&gt;1&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;))&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h2 id=&#34;建立数据库&#34;&gt;建立数据库&lt;/h2&gt;
&lt;h3 id=&#34;定义数据库和表&#34;&gt;定义数据库和表&lt;/h3&gt;
&lt;h4 id=&#34;创建database&#34;&gt;创建Database&lt;/h4&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;数据库(Database&lt;/strong&gt;)是若干具有相互关联关系的&lt;code&gt;Table/Relation&lt;/code&gt;的集合&lt;/li&gt;
&lt;li&gt;数据库可以看作是一个集中存放若干&lt;code&gt;Table&lt;/code&gt;的大型文件&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;创建数据库的简单语法形式：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-sql&#34; data-lang=&#34;sql&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;k&#34;&gt;create&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;k&#34;&gt;database&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;数据库名&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;示例：创建课程学习数据库SCT&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-sql&#34; data-lang=&#34;sql&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;k&#34;&gt;create&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;k&#34;&gt;database&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;n&#34;&gt;SCT&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h4 id=&#34;创建table&#34;&gt;创建Table&lt;/h4&gt;
&lt;p&gt;创建table简单语法形式：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-sql&#34; data-lang=&#34;sql&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;k&#34;&gt;Create&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;k&#34;&gt;table&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;表名&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;(&lt;/span&gt;&lt;span class=&#34;err&#34;&gt;列名&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;数据类型&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;[&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;Primary&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;k&#34;&gt;key&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;|&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;Unique&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;][&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;Notnull&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;][,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;列名&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;err&#34;&gt;数据类型&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;[&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;Primary&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;k&#34;&gt;key&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;|&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;Unique&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;][&lt;/span&gt;&lt;span class=&#34;k&#34;&gt;Notnull&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;]&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;,&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;...&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;])&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;p&#34;&gt;;&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;ul&gt;
&lt;li&gt;
&lt;p&gt;&lt;strong&gt;“[ ] ”表示其括起的内容可以省略，“| ”表示其隔开的两项可取其一&lt;/strong&gt;&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
