系統(tǒng)之家 - 系統(tǒng)光盤下載網(wǎng)站!

當(dāng)前位置:系統(tǒng)之家 > 系統(tǒng)教程 > Linux在指定ID快速修改sql文件中記錄

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

時間:2015-05-15 14:55:40 作者:小蘭 來源:系統(tǒng)之家 1. 掃描二維碼隨時看資訊 2. 請使用手機(jī)瀏覽器訪問: https://m.xitongzhijia.net/xtjc/20150515/48472.html 手機(jī)查看 評論

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

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

  解決方法:

  當(dāng)數(shù)據(jù)庫中的某個字段(例如ID)是整型,那么當(dāng)新插入數(shù)據(jù)的時候需要從目前已有的數(shù)據(jù)庫總最大的值加1開始排列。

  當(dāng)前生產(chǎn)數(shù)據(jù)庫的id最大值為150,那么上線時候需要從151開始編號,當(dāng)然可以使用sequence自增是一種方式。

  這里介紹的是手動修改sql,保存如下內(nèi)容到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打開文件

  命令模式下執(zhí)行如下命令就可以搞定

  :let n=151 | g/values(\zs\d\+/s//\=n/|let n+=1

  以下是詳細(xì)的解釋:

  這條命令各個組成元素:

  let 為變量賦值 (:help let )

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

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

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

  \d\+ 查找1個或多個數(shù)字 (:help /\d )

  s 在選中的區(qū)域中進(jìn)行替換 (:help :s )

  \= 指明后面是一個表達(dá)式 (:help :s\= )

  所以,這條命令的執(zhí)行過程為:

  給變量n賦值為0;

  查找模式"values(\zs\d\+",使用變量n的值替換匹配的模式字符串;

  給變量n加1;

  回第二步;

  補(bǔ)充一下知識點(diǎn):

  方法1:

  這兩天在構(gòu)建一個應(yīng)用的使用用到了maven,由于project很大,足足有700多個 pom.xml文件,更郁悶的是在很多pom.xml文件里都單獨(dú)指定了資源庫的url,我需要把這些資源庫的url統(tǒng)一指定到nexus本地中央庫.

  手 工一個個改文件配置有點(diǎn)不太實(shí)際,所以google了一下,找到批量替換文件內(nèi)容的好方法,命令結(jié)構(gòu)如下:

  find -name '要查找的文件名' | xargs perl -pi -e 's|被替換的字符串|替換后的字符串|g'下面這個例子就是將當(dāng)前目錄及所有子目錄下的所有pom.xml文件中的”https://repo1.maven.org/maven2“ 替換為”https://localhost:8081/nexus/content/groups/public“.

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

  perl -pi -e 在Perl 命令中加上-e 選項(xiàng),后跟一行代碼,那它就會像運(yùn)行一個普通的Perl 腳本那樣運(yùn)行該代碼.

  從命令行中使用Perl 能夠幫助實(shí)現(xiàn)一些強(qiáng)大的、實(shí)時的轉(zhuǎn)換。認(rèn)真研究正則表達(dá)式,并正確地使用,將會為您省去大量的手工編輯工作。

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

標(biāo)簽 sql文件

發(fā)表評論

0

沒有更多評論了

評論就這些咯,讓大家也知道你的獨(dú)特見解

立即評論

以上留言僅代表用戶個人觀點(diǎn),不代表系統(tǒng)之家立場

其他版本軟件

熱門教程

人氣教程排行

Linux系統(tǒng)推薦

官方交流群 軟件收錄