热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

gitlog查看提交记录gitlog查看提交记录

 gitlog查看提交记录1.gitlog查看提交历史记录2.gitlog--oneline或者gitlog--prettyoneline以精简模式显示3.gitlog--grap
 

git log 查看提交记录

1. git log 查看提交历史记录
2. git log --oneline 或者 git log --pretty=oneline 以精简模式显示
3. git log --graph 以图形模式显示
4. git log --stat 显示文件更改列表
5. git log --author= 'name' 显示某个作者的日志
6. git log -p filepath 查看某个文件的详细修改
7. git log -L start,end:filepath 查看某个文件某几行范围内的修改记录
8. git log --stat commitId 或者 git show --stat commitId 查看某一次提交的文件修改列表

 

git diff 文件对比
1. git diff filepath 工作区与暂存区比较
2. git diff HEAD filepath 工作区与HEAD ( 当前工作分支) 比较
3. git diff --staged 或 --cached filepath 暂存区与HEAD比较
4. git diff branchName filepath 当前分支的文件与branchName 分支的文件进行比较
5. git diff commitId filepath 与某一次提交进行比较

 

git log 有两个高级用法:一是自定义提交的输出格式,二是过滤输出哪些提交.

格式化 Log 输出

#只显示提交ID和提交信息的第一行
git log --oneline

#知道每个提交关联的分支或者标签
git log --oneline --decorate

Diff

文件名后面 + 和 - 的数量是这个提交造成的更改中增删的相对比例.

#--stat 选项显示每次提交的文件增删数量
git log --stat
# -p 如果你想知道每次提交删改的绝对数量
git log -p

Shortlog

#它把每个提交按作者分类,显示提交信息的第一行。这样可以容易地看到谁做了什么。
git shortlog

默认情况下,git shortlog 把输出按作者名字排序,但你可以传入 -n 选项来按每个作者提交数量排序。

Graph

#--graph 选项绘制一个 ASCII 图像来展示提交历史的分支结构
#星号表明这个提交所在的分支
git log --graph --oneline --decorate

按内容

#当你想要知道 Hello, World! 字符串是什么时候加到项目中哪个文件中去的
git log -S "Hello, World!"

按范围

#master..feature 范围包含了在 feature 分支而不在 master 分支中所有的提交
git log master..feature

 

git log用于查询版本的历史,命令形式如下:
git log [] [..] [[--] ...]

 

 

这条命令有很多参数选项
一、不带参数
  1. 如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者、提交日期、和提交说明
  2. 如果记录过多,则按Page Up、Page Down、↓、↑来控制显示
  3. 按q退出历史记录列表
 
二、显示参数
  1. -p:按补丁显示每个更新间的差异,比下一条- -stat命令信息更全
  2. --stat:显示每次更新的修改文件的统计信息,每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计
  3. --shortstat:只显示--stat中最后的行数添加修改删除统计
  4. --name-only:尽在已修改的提交信息后显示文件清单
  5. --name-status:显示新增、修改和删除的文件清单
  6. --abbrev-commit:仅显示SHA-1的前几个字符,而非所有的40个字符
  7. --relative-date:使用较短的相对时间显示(例如:"two weeks ago")
  8. --graph:显示ASCII图形表示的分支合并历史
  9. —pretty=:使用其他格式显示历史提交信息,可选项有:oneline,short,medium,full,fuller,email,raw以及format:,默认为medium,如:
    1. --pretty=oneline:一行显示,只显示哈希值和提交说明(--online本身也可以作为单独的属性)
    2. --pretty=format:” ":控制显示的记录格式,如:
      1. %H  提交对象(commit)的完整哈希字串
      2. %h  提交对象的简短哈希字串
      3. %T  树对象(tree)的完整哈希字串
      4. %t  树对象的简短哈希字串
      5. %P  父对象(parent)的完整哈希字串
      6. %p  父对象的简短哈希字串
      7. %an 作者(author)的名字
      8. %ae 作者的电子邮件地址
      9. %ad 作者修订日期(可以用 -date= 选项定制格式)
      10. %ar 作者修订日期,按多久以前的方式显示
      11. %cn 提交者(committer)的名字
        1. 作者和提交者的区别不知道是啥?
        2. 作者与提交者的关系:作者是程序的修改者,提交者是代码提交人(自己的修改不提交是怎么能让别人拉下来再提交的?)
        3. 其实作者指的是实际作出修改的人,提交者指的是最后将此工作成果提交到仓库的人。所以,当你为某个项目发布补丁,然后某个核心成员将你的补丁并入项目时,你就是作者,而那个核心成员就是提交者(soga)
      12. %ce 提交者的电子邮件地址
      13. %cd 提交日期(可以用 -date= 选项定制格式)
      14. %cr 提交日期,按多久以前的方式显示
      15. %s  提交说明
    3. 带颜色的--pretty=format:” ",这个另外写出来分析
      1. 以这句为例:%Cred%h%Creset -%C(yellow)%d%Cblue %s %Cgreen(%cd) %C(bold blue)<%an>
      2. 它的效果是:   git log 查看提交记录
    


            
git log 查看提交记录

         

      3. 先断句:[%Cred%h][%Creset   -][%C(yellow)%d ][%Cblue%s][%Cgreen(%cd)][%C(bold blue)<%an>]
      4. 然后就是很明显能得到的规律了
        1. 一个颜色+一个内容
        2. 颜色以%C开头,后边接几种颜色,还可以设置字体,如果要设置字体的话,要一块加个括号
          1. 能设置的颜色值包括:reset(默认的灰色),normal, black, red, green, yellow, blue, magenta, cyan, white.
          2. 字体属性则有bold, dim, ul, blink, reverse.  
        3. 内容可以是占位元字符,也可以是直接显示的普通字符
  10. --date= (relative|local|default|iso|rfc|short|raw):定制后边如果出现%ad或%cd时的日期格式
    1. 有几个默认选项
      1. --date=relative:shows dates relative to the current time, e.g. "2 hours ago".
      2. --date=local:shows timestamps in user’s local timezone.
      3. --date=iso (or --date=iso8601):shows timestamps in ISO 8601 format.
      4. --date=rfc (or --date=rfc2822):shows timestamps in RFC 2822 format,often found in E-mail messages.
      5. --date=short:shows only date but not time, in YYYY-MM-DD format.这个挺好用
      6. --date=raw:shows the date in the internal raw git format %s %z format.
      7. --date=default:shows timestamps in the original timezone (either committer’s or author’s).
    2. 也可以自定义格式(需要git版本2.6.0以上),比如--date=format:'%Y-%m-%d %H:%M:%S' 会格式化成:2016-01-13 11:32:13,其他的格式化占位符如下:
      1. %a:Abbreviated weekday name
      2. %A:Full weekday name
      3. %b:Abbreviated month name
      4. %B:Full month name
      5. %c:Date and time representation appropriate for locale
      6. %d:Day of month as decimal number (01 – 31)
      7. %H: Hour in 24-hour format (00 – 23)
      8. %I:Hour in 12-hour format (01 – 12)
      9. %j:Day of year as decimal number (001 – 366)
      10. %m:Month as decimal number (01 – 12)
      11. %M:Minute as decimal number (00 – 59)
      12. %p:Current locale's A.M./P.M. indicator for 12-hour clock
      13. %S:Second as decimal number (00 – 59)
      14. %U:Week of year as decimal number, with Sunday as first day of week (00 – 53)
      15. %w:Weekday as decimal number (0 – 6; Sunday is 0)
      16. %W:Week of year as decimal number, with Monday as first day of week (00 – 53)
      17. %x:Date representation for current locale
      18. %X:Time representation for current locale
      19. %y:Year without century, as decimal number (00 – 99)
      20. %Y:Year with century, as decimal number
      21. %z, %Z:Either the time-zone name or time zone abbreviation, depending on registry settings; no characters if time zone is unknown
      22. %%:Percent sign
 
三、筛选参数:
  1. 按数量
    1. -n:显示前n条log
  2. 按日期
    1. --after=
      1. 比如git log --after="2014-7-1”,显示2014年7月1号之后的commit(包含7月1号)
      2. 后边的日期还可以用相对时间表示,比如"1 week ago"和”yesterday",比如git log --after="yesterday"
      3. 这里的格式可以是什么?
    2. --before=
      1. 同上
      2. 另外这两条命令可以同时使用表示时间段,比如git log --after="2014-7-1" --before="2014-7-4"
      3. 另外--since --until和 --after --before是一个意思,都可以用
  3. 按作者
    1. --author=
      1. 比如git log --author=“John",显示John贡献的commit
      2. 注意:作者名不需要精确匹配,只需要包含就行了
      3. 而且:可以使用正则表达式,比如git log --author="John\|Mary”,搜索Marry和John贡献的commit
      4. 而且:这个--author不仅包含名还包含email, 所以你可以用这个搜索email
  4. 按commit描述
    1. --grep=
      1. 比如:git log --grep="JRA-224"
      2. 而且:可以传入-i用来忽略大小写
      3. 注意:如果想同时使用--grep和--author,必须在附加一个--all-match参数
  5. 按文件
    1. - -(空格)或[没有]
      1. 有时你可能只对某个文件的修改感兴趣, 你只想查看跟某个文件相关的历史信息, 你只需要插入你感兴趣文件的路径[对,是路径,所以经常是不太好用]就可以了
      2. 比如:git log -- foo.py bar.py ,只返回和foo.py或bar.py相关的commit
      3. 这里的--是告诉Git后面的参数是文件路径而不是branch的名字. 如果后面的文件路径不会和某个branch产生混淆, 你可以省略- -,比如git log foo.py 
      4. 另外,后边的路径还支持正则,比如:git log  *install.md 是,指定项目路径下的所有以install.md结尾的文件的提交历史
      5. 另外,文件名应该放到参数的最后位置,通常在前面加上--并用空格隔开表示是文件
      6. 另外,git log file/ 查看file文件夹下所有文件的提交记录
  6. 按分支
    1. - -
      1. --branchName branchName为任意一个分支名字,查看某个分支上的提交记录
      2. 需要放到参数中的最后位置处
      3. 如果分支名与文件名相同,系统会提示错 误,可通过--选项来指定给定的参数是分支名还是文件名
        1. 比如:在当前分支中有一个名为v1的文件,同时还存在一个名为v1的分支
        2. git log v1 -- 此时的v1代表的是分支名字(--后边是空的)
        3. git log -- v1 此时的v1代表的是名为v1的文件
        4. git log v1 -- v1 代表v1分支下的v1文件
  7. 按内容
    1. -S""、-G""
      1. 有时你想搜索和新增或删除某行代码相关的commit. 可以使用这条命令
      2. 假设你想知道Hello, World!这句话是什么时候加入到项目里去的,可以用:git log -S"Hello,World!"
      3. 另外:如果你想使用正则表达式去匹配而不是字符串, 那么你可以使用-G代替-S.
      4. 这是一个非常有用的debug工具, 使用他你可以定位所有跟某行代码相关的commit. 甚至可以查看某行是什么时候被copy的, 什么时候移到另外一个文件中去的
      5. 注:-S后没有"=",与查询内容之间也没有空格符
  8. 按范围
    1. git log ..
      1. 这个命令可以查看某个范围的commit
      2. 这个命令非常有用当你使用branch做为range参数的时候. 能很方便的显示2个branch之间的不同
      3. 比如:git log master..feature,master..feature这个range包含了在feature有而在master没有的所有commit,同样,如果是feature..master包含所有master有但是feature没有的commit
      4. 另外,如果是三个点,表示或的意思:git log master...test 查询master或test分支中的提交记录
  9. 过滤掉merge commit
    1. --no-merges
      1. 默认情况下git log会输出merge commit.  你可以通过--no-merges标记来过滤掉merge commit,git log --no-merges
      2. 另外,如果你只对merge commit感兴趣可以使用—merges,git log --merges
  10. 按标签tag
    1. git log v1.0
      1. 直接这样是查询标签之前的commit
      2. 加两个点git log v1.0.. 查询从v1.0以后的提交历史记录(不包含v1.0)
  11. 按commit
    1. git log commit :查询commit之前的记录,包含commit
    2. git log commit1 commit2:查询commit1与commit2之间的记录,包括commit1和commit2
    3. git log commit1..commit2:同上,但是不包括commit1
      1. 其中,commit可以是提交哈希值的简写模式,也可以使用HEAD代替
        1. HEAD代表最后一次提交,HEAD^为最后一个提交的父提交,等同于HEAD~1
        2. HEAD~2代表倒数第二次提交

 

git log 查看提交记录

1. git log 查看提交历史记录
2. git log --oneline 或者 git log --pretty=oneline 以精简模式显示
3. git log --graph 以图形模式显示
4. git log --stat 显示文件更改列表
5. git log --author= 'name' 显示某个作者的日志
6. git log -p filepath 查看某个文件的详细修改
7. git log -L start,end:filepath 查看某个文件某几行范围内的修改记录
8. git log --stat commitId 或者 git show --stat commitId 查看某一次提交的文件修改列表

 

git diff 文件对比
1. git diff filepath 工作区与暂存区比较
2. git diff HEAD filepath 工作区与HEAD ( 当前工作分支) 比较
3. git diff --staged 或 --cached filepath 暂存区与HEAD比较
4. git diff branchName filepath 当前分支的文件与branchName 分支的文件进行比较
5. git diff commitId filepath 与某一次提交进行比较

 

git log 有两个高级用法:一是自定义提交的输出格式,二是过滤输出哪些提交.

格式化 Log 输出

#只显示提交ID和提交信息的第一行
git log --oneline

#知道每个提交关联的分支或者标签
git log --oneline --decorate

Diff

文件名后面 + 和 - 的数量是这个提交造成的更改中增删的相对比例.

#--stat 选项显示每次提交的文件增删数量
git log --stat
# -p 如果你想知道每次提交删改的绝对数量
git log -p

Shortlog

#它把每个提交按作者分类,显示提交信息的第一行。这样可以容易地看到谁做了什么。
git shortlog

默认情况下,git shortlog 把输出按作者名字排序,但你可以传入 -n 选项来按每个作者提交数量排序。

Graph

#--graph 选项绘制一个 ASCII 图像来展示提交历史的分支结构
#星号表明这个提交所在的分支
git log --graph --oneline --decorate

按内容

#当你想要知道 Hello, World! 字符串是什么时候加到项目中哪个文件中去的
git log -S "Hello, World!"

按范围

#master..feature 范围包含了在 feature 分支而不在 master 分支中所有的提交
git log master..feature

 

git log用于查询版本的历史,命令形式如下:
git log [] [..] [[--] ...]

 

 

这条命令有很多参数选项
一、不带参数
  1. 如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者、提交日期、和提交说明
  2. 如果记录过多,则按Page Up、Page Down、↓、↑来控制显示
  3. 按q退出历史记录列表
 
二、显示参数
  1. -p:按补丁显示每个更新间的差异,比下一条- -stat命令信息更全
  2. --stat:显示每次更新的修改文件的统计信息,每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计
  3. --shortstat:只显示--stat中最后的行数添加修改删除统计
  4. --name-only:尽在已修改的提交信息后显示文件清单
  5. --name-status:显示新增、修改和删除的文件清单
  6. --abbrev-commit:仅显示SHA-1的前几个字符,而非所有的40个字符
  7. --relative-date:使用较短的相对时间显示(例如:"two weeks ago")
  8. --graph:显示ASCII图形表示的分支合并历史
  9. —pretty=:使用其他格式显示历史提交信息,可选项有:oneline,short,medium,full,fuller,email,raw以及format:,默认为medium,如:
    1. --pretty=oneline:一行显示,只显示哈希值和提交说明(--online本身也可以作为单独的属性)
    2. --pretty=format:” ":控制显示的记录格式,如:
      1. %H  提交对象(commit)的完整哈希字串
      2. %h  提交对象的简短哈希字串
      3. %T  树对象(tree)的完整哈希字串
      4. %t  树对象的简短哈希字串
      5. %P  父对象(parent)的完整哈希字串
      6. %p  父对象的简短哈希字串
      7. %an 作者(author)的名字
      8. %ae 作者的电子邮件地址
      9. %ad 作者修订日期(可以用 -date= 选项定制格式)
      10. %ar 作者修订日期,按多久以前的方式显示
      11. %cn 提交者(committer)的名字
        1. 作者和提交者的区别不知道是啥?
        2. 作者与提交者的关系:作者是程序的修改者,提交者是代码提交人(自己的修改不提交是怎么能让别人拉下来再提交的?)
        3. 其实作者指的是实际作出修改的人,提交者指的是最后将此工作成果提交到仓库的人。所以,当你为某个项目发布补丁,然后某个核心成员将你的补丁并入项目时,你就是作者,而那个核心成员就是提交者(soga)
      12. %ce 提交者的电子邮件地址
      13. %cd 提交日期(可以用 -date= 选项定制格式)
      14. %cr 提交日期,按多久以前的方式显示
      15. %s  提交说明
    3. 带颜色的--pretty=format:” ",这个另外写出来分析
      1. 以这句为例:%Cred%h%Creset -%C(yellow)%d%Cblue %s %Cgreen(%cd) %C(bold blue)<%an>
      2. 它的效果是:   git log 查看提交记录
    


            
git log 查看提交记录

         

      3. 先断句:[%Cred%h][%Creset   -][%C(yellow)%d ][%Cblue%s][%Cgreen(%cd)][%C(bold blue)<%an>]
      4. 然后就是很明显能得到的规律了
        1. 一个颜色+一个内容
        2. 颜色以%C开头,后边接几种颜色,还可以设置字体,如果要设置字体的话,要一块加个括号
          1. 能设置的颜色值包括:reset(默认的灰色),normal, black, red, green, yellow, blue, magenta, cyan, white.
          2. 字体属性则有bold, dim, ul, blink, reverse.  
        3. 内容可以是占位元字符,也可以是直接显示的普通字符
  10. --date= (relative|local|default|iso|rfc|short|raw):定制后边如果出现%ad或%cd时的日期格式
    1. 有几个默认选项
      1. --date=relative:shows dates relative to the current time, e.g. "2 hours ago".
      2. --date=local:shows timestamps in user’s local timezone.
      3. --date=iso (or --date=iso8601):shows timestamps in ISO 8601 format.
      4. --date=rfc (or --date=rfc2822):shows timestamps in RFC 2822 format,often found in E-mail messages.
      5. --date=short:shows only date but not time, in YYYY-MM-DD format.这个挺好用
      6. --date=raw:shows the date in the internal raw git format %s %z format.
      7. --date=default:shows timestamps in the original timezone (either committer’s or author’s).
    2. 也可以自定义格式(需要git版本2.6.0以上),比如--date=format:'%Y-%m-%d %H:%M:%S' 会格式化成:2016-01-13 11:32:13,其他的格式化占位符如下:
      1. %a:Abbreviated weekday name
      2. %A:Full weekday name
      3. %b:Abbreviated month name
      4. %B:Full month name
      5. %c:Date and time representation appropriate for locale
      6. %d:Day of month as decimal number (01 – 31)
      7. %H: Hour in 24-hour format (00 – 23)
      8. %I:Hour in 12-hour format (01 – 12)
      9. %j:Day of year as decimal number (001 – 366)
      10. %m:Month as decimal number (01 – 12)
      11. %M:Minute as decimal number (00 – 59)
      12. %p:Current locale's A.M./P.M. indicator for 12-hour clock
      13. %S:Second as decimal number (00 – 59)
      14. %U:Week of year as decimal number, with Sunday as first day of week (00 – 53)
      15. %w:Weekday as decimal number (0 – 6; Sunday is 0)
      16. %W:Week of year as decimal number, with Monday as first day of week (00 – 53)
      17. %x:Date representation for current locale
      18. %X:Time representation for current locale
      19. %y:Year without century, as decimal number (00 – 99)
      20. %Y:Year with century, as decimal number
      21. %z, %Z:Either the time-zone name or time zone abbreviation, depending on registry settings; no characters if time zone is unknown
      22. %%:Percent sign
 
三、筛选参数:
  1. 按数量
    1. -n:显示前n条log
  2. 按日期
    1. --after=
      1. 比如git log --after="2014-7-1”,显示2014年7月1号之后的commit(包含7月1号)
      2. 后边的日期还可以用相对时间表示,比如"1 week ago"和”yesterday",比如git log --after="yesterday"
      3. 这里的格式可以是什么?
    2. --before=
      1. 同上
      2. 另外这两条命令可以同时使用表示时间段,比如git log --after="2014-7-1" --before="2014-7-4"
      3. 另外--since --until和 --after --before是一个意思,都可以用
  3. 按作者
    1. --author=
      1. 比如git log --author=“John",显示John贡献的commit
      2. 注意:作者名不需要精确匹配,只需要包含就行了
      3. 而且:可以使用正则表达式,比如git log --author="John\|Mary”,搜索Marry和John贡献的commit
      4. 而且:这个--author不仅包含名还包含email, 所以你可以用这个搜索email
  4. 按commit描述
    1. --grep=
      1. 比如:git log --grep="JRA-224"
      2. 而且:可以传入-i用来忽略大小写
      3. 注意:如果想同时使用--grep和--author,必须在附加一个--all-match参数
  5. 按文件
    1. - -(空格)或[没有]
      1. 有时你可能只对某个文件的修改感兴趣, 你只想查看跟某个文件相关的历史信息, 你只需要插入你感兴趣文件的路径[对,是路径,所以经常是不太好用]就可以了
      2. 比如:git log -- foo.py bar.py ,只返回和foo.py或bar.py相关的commit
      3. 这里的--是告诉Git后面的参数是文件路径而不是branch的名字. 如果后面的文件路径不会和某个branch产生混淆, 你可以省略- -,比如git log foo.py 
      4. 另外,后边的路径还支持正则,比如:git log  *install.md 是,指定项目路径下的所有以install.md结尾的文件的提交历史
      5. 另外,文件名应该放到参数的最后位置,通常在前面加上--并用空格隔开表示是文件
      6. 另外,git log file/ 查看file文件夹下所有文件的提交记录
  6. 按分支
    1. - -
      1. --branchName branchName为任意一个分支名字,查看某个分支上的提交记录
      2. 需要放到参数中的最后位置处
      3. 如果分支名与文件名相同,系统会提示错 误,可通过--选项来指定给定的参数是分支名还是文件名
        1. 比如:在当前分支中有一个名为v1的文件,同时还存在一个名为v1的分支
        2. git log v1 -- 此时的v1代表的是分支名字(--后边是空的)
        3. git log -- v1 此时的v1代表的是名为v1的文件
        4. git log v1 -- v1 代表v1分支下的v1文件
  7. 按内容
    1. -S""、-G""
      1. 有时你想搜索和新增或删除某行代码相关的commit. 可以使用这条命令
      2. 假设你想知道Hello, World!这句话是什么时候加入到项目里去的,可以用:git log -S"Hello,World!"
      3. 另外:如果你想使用正则表达式去匹配而不是字符串, 那么你可以使用-G代替-S.
      4. 这是一个非常有用的debug工具, 使用他你可以定位所有跟某行代码相关的commit. 甚至可以查看某行是什么时候被copy的, 什么时候移到另外一个文件中去的
      5. 注:-S后没有"=",与查询内容之间也没有空格符
  8. 按范围
    1. git log ..
      1. 这个命令可以查看某个范围的commit
      2. 这个命令非常有用当你使用branch做为range参数的时候. 能很方便的显示2个branch之间的不同
      3. 比如:git log master..feature,master..feature这个range包含了在feature有而在master没有的所有commit,同样,如果是feature..master包含所有master有但是feature没有的commit
      4. 另外,如果是三个点,表示或的意思:git log master...test 查询master或test分支中的提交记录
  9. 过滤掉merge commit
    1. --no-merges
      1. 默认情况下git log会输出merge commit.  你可以通过--no-merges标记来过滤掉merge commit,git log --no-merges
      2. 另外,如果你只对merge commit感兴趣可以使用—merges,git log --merges
  10. 按标签tag
    1. git log v1.0
      1. 直接这样是查询标签之前的commit
      2. 加两个点git log v1.0.. 查询从v1.0以后的提交历史记录(不包含v1.0)
  11. 按commit
    1. git log commit :查询commit之前的记录,包含commit
    2. git log commit1 commit2:查询commit1与commit2之间的记录,包括commit1和commit2
    3. git log commit1..commit2:同上,但是不包括commit1
      1. 其中,commit可以是提交哈希值的简写模式,也可以使用HEAD代替
        1. HEAD代表最后一次提交,HEAD^为最后一个提交的父提交,等同于HEAD~1
        2. HEAD~2代表倒数第二次提交

 

1. git log 查看提交历史记录
2. git log --oneline 或者 git log --pretty=oneline 以精简模式显示
3. git log --graph 以图形模式显示
4. git log --stat 显示文件更改列表
5. git log --author= 'name' 显示某个作者的日志
6. git log -p filepath 查看某个文件的详细修改
7. git log -L start,end:filepath 查看某个文件某几行范围内的修改记录
8. git log --stat commitId 或者 git show --stat commitId 查看某一次提交的文件修改列表


推荐阅读
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 在Oracle11g以前版本中的的DataGuard物理备用数据库,可以以只读的方式打开数据库,但此时MediaRecovery利用日志进行数据同步的过 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 本文介绍了sqlserver云存储和本地存储的区别,云存储是将数据存储在网络上,方便查看和调用;本地存储是将数据存储在电脑磁盘上,只能在存储的电脑上查看。同时提供了几种启动sqlserver的方法。此外,还介绍了如何导出数据库的步骤和工具。 ... [详细]
author-avatar
郑子宜4262
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有