linux 文件id修改,Linux如何在指定ID快速修改sql文件中记录

Linux系统中sql.sql文件有着大量的数据记录,有时也包含着ID记录,有时我们需要替换这些ID记录,今天华军小编给大家展示的是Linux如何在指定ID快速修改sql文件中记录,精心挑选的内容希望大家多多支持、多多分享,喜欢就赶紧get哦!

7553c7df13a21b3373d5e7eeec759950.png

解决方法:

当数据库中的某个字段(例如ID)是整型,那么当新插入数据的时候需要从目前已有的数据库总最大的值加1开始排列。

当前生产数据库的id最大值为150,那么上线时候需要从151开始编号,当然可以使用sequence自增是一种方式。

这里介绍的是手动修改sql,保存如下内容到online.sql中

insert into ct values(1, 'sss', 2, 4);

insert into ct values(1, 'sss', 2, 4);

insert into ct values(1, 'sss', 2, 4);

insert into ct values(1, 'sss', 2, 4);

insert into ct values(1, 'sss', 2, 4);

insert into ct values(1, 'sss', 2, 4);

insert into ct values(1, 'sss', 2, 4);

使用vim打开文件

命令模式下执行如下命令就可以搞定

:let n=151 | g/values(zsd+/s//=n/|let n+=1

以下是详细的解释:

这条命令各个组成元素:

let 为变量赋值 (:help let )

| 用来分隔不同的命令 (:help :bar )

g 在匹配后面模式的行中执行指定的ex命令 (:help :g )

zs 指明匹配由此开始 (:help /zs )

d+ 查找1个或多个数字 (:help /d )

s 在选中的区域中进行替换 (:help :s )

= 指明后面是一个表达式 (:help :s= )

所以,这条命令的执行过程为:

给变量n赋值为0;

查找模式"values(zsd+",使用变量n的值替换匹配的模式字符串;

给变量n加1;

回第二步;

补充一下知识点:

方法1:

这两天在构建一个应用的使用用到了maven,由于project很大,足足有700多个 pom.xml文件,更郁闷的是在很多pom.xml文件里都单独指定了资源库的url,我需要把这些资源库的url统一指定到nexus本地中央库.

手 工一个个改文件配置有点不太实际,所以google了一下,找到批量替换文件内容的好方法,命令结构如下:

find -name '要查找的文件名' | xargs perl -pi -e 's|被替换的字符串|替换后的字符串|g'下面这个例子就是将当前目录及所有子目录下的所有pom.xml文件中的”http://repo1.maven.org/maven2“ 替换为”http://localhost:8081/nexus/content/groups/public“.

find -name 'pom.xml' | xargs perl -pi -e 's|http://repo1.maven.org/maven2|http://localhost:8081/nexus/content /groups/public|g'这里用到了Perl语言,

perl -pi -e 在Perl 命令中加上-e 选项,后跟一行代码,那它就会像运行一个普通的Perl 脚本那样运行该代码.

从命令行中使用Perl 能够帮助实现一些强大的、实时的转换。认真研究正则表达式,并正确地使用,将会为您省去大量的手工编辑工作。

find -name 'pom.xml' | xargs perl -pi -e 's|http://repo1.maven.org/maven2|http://localhost:8081/nexus/content/groups/public|g'

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值