git切分支不要历史提交记录

不及物动词 其他 339

回复

共3条回复 我来回复
  • worktile的头像
    worktile
    Worktile官方账号
    评论

    要在Git上切换分支但不保留历史提交记录,你可以使用以下方法:

    1. 克隆一个新仓库:如果你只需要保留某个特定分支的最新代码,并且不需要保留任何历史记录,可以先克隆一个新的仓库。

    “`bash
    git clone –depth 1 <原仓库地址>
    “`

    使用`–depth 1`参数可以只克隆最新的提交,而不会克隆所有历史记录。

    2. 创建一个空分支:如果你已经克隆了原仓库,可以在当前分支上创建一个新的空分支。

    “`bash
    git checkout –orphan <新分支名>
    git rm -rf .
    “`

    `–orphan`参数可以创建一个没有历史记录的新分支。然后使用`git rm -rf .`命令清除当前分支的所有文件。

    3. 添加新文件并提交:在新的空分支上,添加需要保留的文件,并进行提交。

    “`bash
    git add .
    git commit -m “Initial commit”
    “`

    使用`git add .`命令添加所有文件,并使用`git commit -m “Initial commit”`命令进行初始化提交。

    4. 关联远程仓库并推送:如果需要将新分支推送到远程仓库,可以使用以下命令进行关联并推送。

    “`bash
    git remote add origin <远程仓库地址>
    git push -u origin <新分支名>
    “`

    使用`git remote add origin`命令将新仓库与远程仓库关联,并使用`git push -u origin <新分支名>`命令将新分支推送到远程仓库。

    通过上述步骤,你就可以切换到一个新的分支,并且不保留历史提交记录。请注意,这种方法会丢失所有历史数据,所以请谨慎操作,确保你不需要保留历史记录。

    2年前 0条评论
  • 不及物动词的头像
    不及物动词
    这个人很懒,什么都没有留下~
    评论

    在git中,切分支的操作默认会包括历史提交记录。这是因为分支在git中是基于提交历史的,每个提交都会包含前一个提交的引用,形成一个提交历史链。

    然而,有时候我们可能希望在切分支时不包含历史提交记录,只保留当前状态。这可以通过以下几种方法实现:

    1. 使用git commit –allow-empty命令创建一个空提交。这个空提交没有实际的变更,但会创建一个新的提交记录。我们可以在切换分支之前执行这个命令,以创建一个不包含任何变更的空提交。这样在切换分支时就不会包含任何历史提交记录。

    2. 使用git checkout –orphan命令创建一个孤立分支。这个命令会创建一个与当前分支无关的独立分支,不会包含任何历史提交记录。我们可以在切换分支之前执行这个命令,然后再添加、提交新的文件,形成一个完全独立的分支。

    3. 使用git checkout –orphan命令配合git rm -rf .命令。首先执行git checkout –orphan创建一个孤立分支,然后执行git rm -rf .将当前分支下的所有文件删除。这样就可以创建一个不包含任何历史提交记录和文件的分支。

    4. 使用git cherry-pick命令将指定的提交记录拷贝到新的分支。这个方法适用于只需要选择部分提交记录而不是所有历史记录的情况。我们可以先切换到新的空分支,然后使用git cherry-pick命令拷贝需要的提交记录。

    5. 使用git rebase命令将当前分支的提交记录转移到一个新的分支。这个方法适用于只需要保留部分历史记录的情况。我们可以先切换到一个新的分支,然后执行git rebase <旧分支>来将旧分支的提交记录转移到新分支。

    需要注意的是,这些方法都是不保留历史记录的操作,一旦执行了切换分支操作,原分支上的历史记录将无法恢复。因此,在执行这些操作之前,建议先进行备份或者确认不需要保留历史记录。

    2年前 0条评论
  • fiy的头像
    fiy
    Worktile&PingCode市场小伙伴
    评论

    如果你想切换到一个新的分支,但是不想保留原来分支的历史提交记录,你可以使用以下方法来实现。

    1. 创建新分支并切换到新分支
    “`bash
    git checkout -b new_branch
    “`

    2. 清空分支上的历史记录
    “`bash
    git checkout –orphan temp_branch
    git add -A
    git commit -m “Initial commit”
    “`

    在这里,我们创建了一个临时分支`temp_branch`,它是一个无父提交的孤立分支。我们将所有文件添加到暂存区,并提交它们作为一个初始提交。

    3. 删除原来分支
    “`bash
    git branch -D main_branch
    “`

    注意:在进行这一步之前,请确保你备份了原来分支上的所有重要文件。

    4. 重命名临时分支
    “`bash
    git branch -m new_branch
    “`

    现在,你可以将临时分支重命名为你想要的新分支名称。

    5. 推送新分支
    “`bash
    git push origin new_branch
    “`

    如果你想在远程仓库上创建并推送新分支,你需要进行此步骤。

    请注意,这个方法会创建一个全新的分支,没有任何历史记录。这意味着你将失去所有旧分支上的变更历史。只有在确认不再需要旧分支的历史记录时,才应该使用此方法。

    2年前 0条评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部