歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux管理 >> Linux維護 >> Linux如何在指定ID快速修改sql文件中記錄

Linux如何在指定ID快速修改sql文件中記錄

日期:2017/3/2 10:28:01   编辑:Linux維護

Linux系統中sql.sql文件有著大量的數據記錄,有時也包含著ID記錄,有時我們需要替換這些ID記錄,該怎麼快速的進行替換呢?今天小編就告訴大家這個問題的解決方法。

解決方法:

當數據庫中的某個字段(例如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 前的 '

以上就是如何在Linux系統中快速替換sql.sql文件中的ID記錄的方法了,不清楚的用戶不妨按照這上面的步驟進行替換吧。

Copyright © Linux教程網 All Rights Reserved