當(dāng)數(shù)據(jù)庫(kù)中的某個(gè)字段(例如ID)是整型,那么當(dāng)新插入數(shù)據(jù)的時(shí)候需要從目前已有的數(shù)據(jù)庫(kù)總最大的值加1開(kāi)始排列。
當(dāng)前生產(chǎn)數(shù)據(jù)庫(kù)的id最大值為150,那么上線時(shí)候需要從151開(kāi)始編號(hào),當(dāng)然可以使用sequence自增是一種方式。
這里介紹的是手動(dòng)修改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打開(kāi)文件
命令模式下執(zhí)行如下命令就可以搞定
:let n=151 | g/values(zsd+/s//=n/|let n+=1
以下是詳細(xì)的解釋:
這條命令各個(gè)組成元素:
let 為變量賦值 (:help let )
| 用來(lái)分隔不同的命令 (:help :bar )
g 在匹配后面模式的行中執(zhí)行指定的ex命令 (:help :g )
zs 指明匹配由此開(kāi)始 (:help /zs )
d+ 查找1個(gè)或多個(gè)數(shù)字 (:help /d )
s 在選中的區(qū)域中進(jìn)行替換 (:help :s )
= 指明后面是一個(gè)表達(dá)式 (:help :s= )
所以,這條命令的執(zhí)行過(guò)程為:
給變量n賦值為0;
查找模式"values(zsd+",使用變量n的值替換匹配的模式字符串;
給變量n加1;
回第二步;
補(bǔ)充一下知識(shí)點(diǎn):
方法1:
這兩天在構(gòu)建一個(gè)應(yīng)用的使用用到了maven,由于project很大,足足有700多個(gè) pom.xml文件,更郁悶的是在很多pom.xml文件里都單獨(dú)指定了資源庫(kù)的url,我需要把這些資源庫(kù)的url統(tǒng)一指定到nexus本地中央庫(kù).
手 工一個(gè)個(gè)改文件配置有點(diǎn)不太實(shí)際,所以google了一下,找到批量替換文件內(nèi)容的好方法,命令結(jié)構(gòu)如下:
find -name '要查找的文件名' | xargs perl -pi -e 's|被替換的字符串|替換后的字符串|g'下面這個(gè)例子就是將當(dāng)前目錄及所有子目錄下的所有pom.xml文件中的”“ 替換為”:8081/nexus/content/groups/public“.
find -name 'pom.xml' | xargs perl -pi -e 's||http://localhost:8081/nexus/content /groups/public|g'這里用到了Perl語(yǔ)言,
perl -pi -e 在Perl 命令中加上-e 選項(xiàng),后跟一行代碼,那它就會(huì)像運(yùn)行一個(gè)普通的Perl 腳本那樣運(yùn)行該代碼.
從命令行中使用Perl 能夠幫助實(shí)現(xiàn)一些強(qiáng)大的、實(shí)時(shí)的轉(zhuǎn)換。認(rèn)真研究正則表達(dá)式,并正確地使用,將會(huì)為您省去大量的手工編輯工作。
find -name 'pom.xml' | xargs perl -pi -e 's||http://localhost:8081/nexus/content/groups/public|g'
方法2:
Linux下批量替換多個(gè)文件中的字符串的簡(jiǎn)單方法。用sed命令可以批量替換多個(gè)文件中的字符串。
用sed命令可以批量替換多個(gè)文件中的 字符串。
sed -i "s/原字符串/新字符串/g" `grep 原字符串 -rl 所在目錄`
例如:我要把mahuinan替換 為huinanma,執(zhí)行命令:
sed -i "s/mahuinan/huinanma/g" 'grep mahuinan -rl /www'
這是目前l(fā)inux最簡(jiǎn)單的批量替換字符串命令了!
具體格式如下:
sed -i "s/oldString/newString/g" `grep oldString -rl /path`
實(shí)例代碼:sed -i "s/大小多少/日月水火/g" `grep 大小多少 -rl /usr/aa`
sed -i "s/大小多少/日月水火/g" `grep 大小多少 -rl ./`
方法3:
在日程的開(kāi)發(fā)過(guò)程中,可能大家會(huì)遇到將某個(gè)變量名修改 為另一個(gè)變量名的情況,如果這個(gè)變量是一個(gè)局部變量的話,vi足以勝任,但是如果是某個(gè)全局變量的話,并且在很多文件中進(jìn)行了使用,這個(gè)時(shí)候使用vi就是 一個(gè)不明智的選擇。這里給出一個(gè)簡(jiǎn)單的shell命令,可以一次性將所有文件中的指定字符串進(jìn)行修改:
grep "abc" * -R | awk -F: '{print $1}' | sort | uniq | xargs sed -i 's/abc/abcde/g'
補(bǔ)充說(shuō)明:
sed -i "s/oldString/newString/g" `grep oldString -rl /path`
對(duì)多個(gè)文件的處理可能不支持,需要用 xargs, 搞定。
變種如下:
grep oldString -rl /path | xargs sed -i "s/oldString/newString/g"
注意:
在 `grep oldString -rl /path` 中 ` 為1前邊的翻引號(hào)`,而不是enter 前的 '