linux从指定ID批量替换sql文件中记录的方法

当数据库中的某个字段(例如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(/zs/d/+/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(/zs/d/+",使用变量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'

方法2:

Linux下批量替换多个文件中的字符串的简单方法。用sed命令可以批量替换多个文件中的字符串。

用sed命令可以批量替换多个文件中的 字符串。

sed -i "s/原字符串/新字符串/g" `grep 原字符串 -rl 所在目录`

例如:我要把mahuinan替换 为huinanma,执行命令:

sed -i "s/mahuinan/huinanma/g" 'grep mahuinan -rl /www'

这是目前linux最简单的批量替换字符串命令了!

具体格式如下:

sed -i "s/oldString/newString/g" `grep oldString -rl /path`

实例代码:sed -i "s/大小多少/日月水火/g" `grep 大小多少 -rl /usr/aa`

sed -i "s/大小多少/日月水火/g" `grep 大小多少 -rl ./`

方法3:

在日程的开发过程中,可能大家会遇到将某个变量名修改 为另一个变量名的情况,如果这个变量是一个局部变量的话,vi足以胜任,但是如果是某个全局变量的话,并且在很多文件中进行了使用,这个时候使用vi就是 一个不明智的选择。这里给出一个简单的shell命令,可以一次性将所有文件中的指定字符串进行修改:

grep "abc" * -R | awk -F: '{print $1}' | sort | uniq | xargs sed -i 's/abc/abcde/g'

补充说明:

sed -i "s/oldString/newString/g" `grep oldString -rl /path`

对多个文件的处理可能不支持,需要用 xargs, 搞定。

变种如下:

grep oldString -rl /path | xargs sed -i "s/oldString/newString/g"

注意:

在 `grep oldString -rl /path` 中 ` 为1前边的翻引号`,而不是enter 前的 '

(0)

相关推荐

  • 如何批量替换电脑文件后缀名

    电脑是现在最常用的工具之一,有些新用户不知道如何批量替换电脑文件后缀名,接下来小编就给大家介绍一下具体的操作步骤.具体如下:1. 首先第一步根据下图箭头所指,将所有文件复制到同一文件夹中.2. 第二步 ...

  • 怎么批量删除txt文件中的空行?

    怎么批量删除txt文件中的空行?下面,给大家分享一个简介的方法: @echo off set n=1 :3 if exist d:new_%n%.txt (set /a n+=1&goto 3 ...

  • 如何快速批量替换excel表格中的不规则字段?

    相信很多小伙伴在日常办公中都会用到excel,其中的不规则字段我们应该如何替换呢?方法很简单,下面小编就来为大家介绍.具体如下:1. 首先,在excel中打开我们要进行操作的表格,然后将其中需要替换数 ...

  • 使用sudo提示用户不在sudoers文件中的解决方法

    CentOS使用sudo提示用户不在sudoers文件中的解决方法 操作方法 01 切换到root用户 [linux@localhost ~]$ su root 密码: [root@localhost ...

  • eclipse怎么批量替换Java文件某一个单词?

    替换eclipse中 Java文件中某一个单词为另一个单词(为了方便快速对文件的修改). 1.举一个例子,把下面有红色下划线的system改为System, 2.按着ctrl+F键,会出来下面的框 3 ...

  • 批量替换wps文字中的图片

    在Wps文字文件中插入了40张图片,想替换其中的20张图片。 常见方法都是逐张替换,少量的图片容易实现,大量替换工作量之大可想而知。有没有更简单的方法呢?当然有,那就是把wps文字转成网页格式,利用生 ...

  • 批量删除Powerpoint文件中生成的动画效果的方法

    Powerpoint是微软OFFICE系列办公应用软件的重要组成部份之一,也是大家在日常的办公中经常用到的一款软件。由于其集成了一些动画的功能,比较适合课件等的制作,因此受到广泛的欢迎。不过,对于Po ...

  • 如何批量删除Powerpoint文件中生成的动画效果

    Powerpoint是微软OFFICE系列办公应用软件的重要组成部份之一,也是大家在日常的办公中经常用到的一款软件。由于其集成了一些动画的功能,比较适合课件等的制作,因此受到广泛的欢迎。不过,对于Po ...

  • pixiv怎么批量保存图片?pixiv中保存图片的方法介绍

    pixiv怎么批量保存图片?Pixiv安卓版是一个主要由日本艺术家所组成的虚拟社群,聚集了众多国家的优秀艺术家,通过pixiv app他们在Pixiv相互交流,分享优秀高清插画.本文为大家介绍的是使用 ...