2

下面是 show-rev 的 git 输出

$ git name-rev  --all

2651919f941c11581c794b40aadb2028c4f52ab4 joincolumn_issue
2617f2a1410ce0ec8ea268bbb073008b73490e78 master~2
292def505dd3cdbfd9ac974396775683b5f4c288 ls
0ec9116840a3f21c0b800617c29b7ddab5fda928 joincolumn_issue~2
ee9bb706c8fcc329fac4acf69ad6b684f1069170 master~1
d56a6751771b1f62d9ceb0bcce9a2391c004ee44 master^2
3d80a12ed375c6a9572cde39b5be0722c8cb6439 joincolumn_issue~1
df1834dbe560c2c95c8abaeec494eb1767b96a1e master

正如你所看到的那样,有一行master^2master~2 所以,想知道这两者之间有什么区别,而且输出不按时间顺序排列。

进一步的git图显示如下

$ git log --all --oneline --graph

* 2651919 (origin/joincolumn_issue, joincolumn_issue) changing to @JoinColumn(name="country_nm")
* 3d80a12 hibernate ignoring joinColumn value
* 0ec9116 changing name in joinColumn is breaking
| * 292def5 (origin/mappedBy, mappedBy, ls) OneToMany using mappedBy
|/
*   df1834d (HEAD -> master, origin/master) Merge branch 'master' of https://github.com/samshers/graphql-hibernate
|\
| * d56a675 fixed country null issue
* | ee9bb70 fixed country null issue
|/
* 2617f2a hibernate cascade error issue. country field in state table set to null
4

1 回答 1

9

语法BRANCH^表示BRANCH. 语法BRANCH^n表示分支的第 n 个父级。换句话说,BRANCH^等价于BRANCH^1。只有在合并时才可能有多个父级,因此BRANCH^2(并且,对于章鱼合并,BRANCH^3以及更高版本)仅在合并时使用。

语法BRANCH~等价于BRANCH^1, 并且等价于在 的末尾BRANCH~n添加 n 个副本。换句话说,后者是在每种情况下仅跟随第一个父级的第 n 个父级。^1BRANCHBRANCH

通常,第一个父级是主分支,第二个和随后的父级是合并到其中的侧分支,因此这些语法针对这种情况进行了优化。

还有其他使用插入符号的语法,但它们的工作方式不同并且含义不同。您可以使用man gitrevisions.

于 2019-09-14T19:15:33.580 回答