??xml version="1.0" encoding="utf-8" standalone="yes"?> 1. 获取帮助 2. 导入一个完整数据库 3. 导入一个或一l指定用h属的全部表、烦(ch)引和其他对象 4. 一个用h属的数据导入另一个用?/font> 5. 导入一个表 正则表达式(regular expressionQ描qC(jin)一U字W串匚w的模式,可以用来Q(1Q检查一个串中是否含有符合某个规则的子串Qƈ且可以得到这个子ԌQ?Q根据匹配规则对字符串进行灵zȝ替换操作?br /> 字母、数字、汉字、下划线、以?qing)后边章节中没有?gu)定义的标点符P都是"普通字W?。表辑ּ中的普通字W,在匹配一个字W串的时候,匚w与之相同的一个字W?br /> 一些不便书写的字符Q采用在前面?"\" 的方法。这些字W其实我们都已经熟知?jin)?/p> 表达?/p> 可匹?/p> \r, \n 代表回R和换行符 \t 制表W?/p> \\ 代表 "\" 本n q有其他一些在后边章节中有Ҏ(gu)用处的标点符P在前面加 "\" 后,׃表该W号本n。比如:(x)^, $ 都有Ҏ(gu)意义Q如果要惛_配字W串?"^" ?"$" 字符Q则表达式就需要写?"\^" ?"\$"?/p> 表达?/p> 可匹?/p> \^ 匚w ^ W号本n \$ 匚w $ W号本n \. 匚w数点(.Q本w?/p> q些转义字符的匹配方法与 "普通字W? 是类似的。也是匹配与之相同的一个字W?br /> 正则表达式中的一些表C方法,可以匚w '多种字符' 其中的Q意一个字W。比如,表达?"\d" 可以匚wL一个数字。虽然可以匹配其中Q意字W,但是只能是一个,不是多个。这好比玩扑克牌时候,大小王可以代替Q意一张牌Q但是只能代替一张牌?/p> 表达?/p> 可匹?/p> \d L一个数字,0~9 中的L一?/p> \w L一个字母或数字或下划线Q也是 A~Z,a~z,0~9,_ 中Q意一?/p> \s 包括I格、制表符、换늬{空白字W的其中L一?/p> . 数点可以匹配除?jin)换行符Q\nQ以外的L一个字W?/p> 举例1Q表辑ּ "\d\d"Q在匚w "abc123" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?12"Q匹配到的位|是Q开始于3Q结束于5?br /> 使用Ҏ(gu)?[ ] 包含一pd字符Q能够匹配其中Q意一个字W。用 [^ ] 包含一pd字符Q则能够匚w其中字符之外的Q意一个字W。同L(fng)道理Q虽然可以匹配其中Q意一个,但是只能是一个,不是多个?/p> 表达?/p> 可匹?/p> [ab5@] 匚w "a" ?"b" ?"5" ?"@" [^abc] 匚w "a","b","c" 之外的Q意一个字W?/p> [f-k] 匚w "f"~"k" 之间的Q意一个字?/p> [^A-F0-3] 匚w "A"~"F","0"~"3" 之外的Q意一个字W?/p> 举例1Q表辑ּ "[bcd][bcd]" 匚w "abc123" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?bc"Q匹配到的位|是Q开始于1Q结束于3?br /> 前面章节中讲到的表达式,无论是只能匹配一U字W的表达式,q是可以匚w多种字符其中L一个的表达式,都只能匹配一ơ。如果用表辑ּ再加上修饰匹配次数的Ҏ(gu)W号Q那么不用重复书写表辑ּ可以重复匹配?br /> 表达?/p> 作用 {n} 表达式重复nơ,比如Q?a >"\w{2}" 相当?"\w\w"Q?a >"a{5}" 相当?"aaaaa" {m,n} 表达式至重复mơ,最多重复nơ,比如Q?a >"ba{1,3}"可以匚w "ba"?baa"?baaa" {m,} 表达式至重复mơ,比如Q?a >"\w\d{2,}"可以匚w "a12","_456","M12344"... ? 匚w表达?ơ或?ơ,相当?{0,1}Q比如:(x)"a[cd]?"可以匚w "a","ac","ad" + 表达式至出?ơ,相当?{1,}Q比如:(x)"a+b"可以匚w "ab","aab","aaab"... * 表达式不出现或出CQ意次Q相当于 {0,}Q比如:(x)"\^*b"可以匚w "b","^^^b"... 举例1Q表辑ּ "\d+\.?\d*" 在匹?"It costs $12.5" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?12.5"Q匹配到的位|是Q开始于10Q结束于14?br /> 一些符号在表达式中代表抽象的特D意义:(x) 表达?/p> 作用 ^ 与字W串开始的地方匚wQ不匚wM字符 $ 与字W串l束的地方匹配,不匹配Q何字W?/p> \b 匚w一个单词边界,也就是单词和I格之间的位|,不匹配Q何字W?/p> q一步的文字说明仍然比较抽象Q因此,举例帮助大家理解?br /> 一些符号可以媄(jing)响表辑ּ内部的子表达式之间的关系Q?/p> 表达?/p> 作用 | 左右两边表达式之?"? 关系Q匹配左Ҏ(gu)者右?/p> ( ) (1). 在被修饰匚wơ数的时候,括号中的表达式可以作为整体被修饰 举例5Q表辑ּ "Tom|Jack" 在匹配字W串 "I'm Tom, he is Jack" ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)"Tom"Q匹配到的位|是Q开始于4Q结束于7。匹配下一个时Q匹配结果是Q成功;匚w到的内容是:(x)"Jack"Q匹配到的位|时Q开始于15Q结束于19?br /> 在用修饰匹配次数的Ҏ(gu)W号Ӟ有几U表C方法可以同一个表辑ּ能够匚w不同的次敎ͼ比如Q?{m,n}", "{m,}", "?", "*", "+"Q具体匹配的ơ数随被匚w的字W串而定。这U重复匹配不定次数的表达式在匚wq程中,L可能多的匹配。比如,针对文本 "dxxxdxxxd"QD例如下:(x) 表达?/p> 匚wl果 "\w+" 匹配第一?"d" 之后的所有字W?"xxxdxxxd" "\w+" 匹配第一?"d" 和最后一?"d" 之间的所有字W?"xxxdxxx"。虽?"\w+" 也能够匹配上最后一?"d"Q但是ؓ(f)?jin)整个表达式匹配成功?\w+" 可以 "让出" 它本来能够匹配的最后一?"d" 由此可见Q?\w+" 在匹配的时候,L可能多的匹配符合它规则的字W。虽然第二个举例中,它没有匹配最后一?"d"Q但那也是ؓ(f)?jin)让整个表达式能够匹配成功。同理,?"*" ?"{m,n}" 的表辑ּ都是可能地多匹配,?"?" 的表辑ּ在可匚w可不匚w的时候,也是可能的 "要匹?。这 U匹配原则就叫作 "贪婪" 模式 ?/p> 非贪婪模式:(x) 表达?/p> 匚wl果 "\w+?" 尽可能的匚wW一?"d" 之后的字W,l果是:(x)"\w+?" 只匹配了(jin)一?"x" Z(jin)让整个表辑ּ匚w成功Q?\w+?" 不得不匹?"xxx" 才可以让后边?"d" 匚wQ从而整个表达式匹配成功。因此,l果是:(x)"\w+?" 匚w "xxx" 更多的情况,举例如下Q?br /> 表达式在匚wӞ表达式引擎会(x)小括号 "( )" 包含的表辑ּ所匚w到的字符串记录下来。在获取匚wl果的时候,括号包含的表达式所匚w到的字符串可以单独获取。这一点,在前面的举例中,已经多次展示?jin)。在实际应用场合中,当用某种边界来查找,而所要获取的内容又不包含边界Ӟ必须使用括h指定所要的范围。比如前面的 "<td>(.*?)</td>"?br /> 举例如下Q?br /> 前面的章节中Q我讲到?jin)几个代表抽象意义的?gu)W号Q?^"Q?$"Q?\b"。它们都有一个共同点Q那是Q它们本w不匚wM字符Q只是对 "字符串的两头" 或?"字符之间的缝? 附加?jin)一个条件。理解到q个概念以后Q本节将l箋介绍另外一U对 "两头" 或?"~隙" 附加条g的,更加灉|的表C方法?/p> 正向预搜索:(x)"(?=xxxxx)"Q?(?!xxxxx)" 格式Q?(?!xxxxx)"Q所在缝隙的右侧Q必M能匹?xxxxx q部分表辑ּ?br /> 反向预搜索:(x)"(?<=xxxxx)"Q?(?<!xxxxx)" q有一些在各个正则表达式引擎之间比较通用的规则,在前面的讲解q程中没有提到?/p> 3.1 表达式中Q可以?"\xXX" ?"\uXXXX" 表示一个字W("X" 表示一个十六进制数Q?/p> 形式 字符范围 \xXX ~号?0 ~ 255 范围的字W,比如Q?a >I格可以使用 "\x20" 表示 \uXXXX M字符可以使用 "\u" 再加上其~号?位十六进制数表示Q比如:(x)"\u4E2D" 3.2 在表辑ּ "\s"Q?\d"Q?\w"Q?\b" 表示Ҏ(gu)意义的同Ӟ对应的大写字母表C相反的意义 表达?/p> 可匹?/p> \S \D \W \B 3.3 在表辑ּ中有Ҏ(gu)意义Q需要添?"\" 才能匚w该字W本w的字符汇?/p> 字符 说明 ^ 匚w输入字符串的开始位|。要匚w "^" 字符本nQ请使用 "\^" $ 匚w输入字符串的l尾位置。要匚w "$" 字符本nQ请使用 "\$" ( ) 标记一个子表达式的开始和l束位置。要匚w括P请?"\(" ?"\)" [ ] 用来自定义能够匹?'多种字符' 的表辑ּ。要匚w中括P请?"\[" ?"\]" { } 修饰匚wơ数的符受要匚w大括P请?"\{" ?"\}" . 匚w除了(jin)换行W(\nQ以外的L一个字W。要匚w数Ҏ(gu)w,请?"\." ? 修饰匚wơ数?0 ơ或 1 ơ。要匚w "?" 字符本nQ请使用 "\?" + 修饰匚wơ数?1 ơ。要匚w "+" 字符本nQ请使用 "\+" * 修饰匚wơ数?0 ơ或Lơ。要匚w "*" 字符本nQ请使用 "\*" | 左右两边表达式之?"? 关系。匹?"|" 本nQ请使用 "\|" 3.4 括号 "( )" 内的子表辑ּQ如果希望匹配结果不q行记录供以后用,可以使用 "(?:xxxxx)" 格式 举例1Q表辑ּ "(?:(\w)\1)+" 匚w "a bbccdd efg" ?/font>Q结果是 "bbccdd"。括?"(?:)" 范围的匹配结果不q行记录Q因?"(\w)" 使用 "\1" 来引用?/p> 3.5 常用的表辑ּ属性设|简介:(x)IgnorecaseQSinglelineQMultilineQGlobal 表达式属?/p> 说明 Ignorecase 默认情况下,表达式中的字母是要区分大写的。配|ؓ(f) Ignorecase 可匚w时不区分大小写。有的表辑ּ引擎Q把 "大小? 概念延?UNICODE 范围的大写?/p> Singleline 默认情况下,数?"." 匚w除了(jin)换行W(\nQ以外的字符。配|ؓ(f) Singleline 可ɞ数点可匚w包括换行W在内的所有字W?/p> Multiline 默认情况下,表达?"^" ?"$" 只匹配字W串的开??和结??位置。如Q?br /> Global 主要在将表达式用来替换时起作用,配置?Global 表示替换所有的匚w?/p> 4.1 如果惌?jin)解高的正则引擎还支持那些复杂的正则语法,可参?a >本站 DEELX 正则引擎的说明文?/font>?/p> 4.2 如果要要求表辑ּ所匚w的内Ҏ(gu)整个字符Ԍ而不是从字符串中找一部分Q那么可以在表达式的首尾使用 "^" ?"$"Q比如:(x)"^\d+$" 要求整个字符串只有数字?/p> 4.3 如果要求匚w的内Ҏ(gu)一个完整的单词Q而不?x)是单词的一部分Q那么在表达式首?"\b"Q比如:(x)使用 "\b(if|while|else|void|int…?font color="#5050ff">)\b 4.4 表达式不要匹配空字符丌Ӏ否则会(x)一直得到匹配成功,而结果什么都没有匚w到。比如:(x)准备写一个匹?"123"?123."?123.5"?.5" q几UŞ式的表达式时Q整数、小数点、小数数字都可以省略Q但是不要将表达式写成:(x)"\d*\.?\d*"Q因为如果什么都没有Q这个表辑ּ也可以匹配成功?a >更好的写法是Q?\d+\.?\d*|\.\d+"?/p> 4.5 能匹配空字符串的子匹配不要@环无限次。如果括号内的子表达式中的每一部分都可以匹?0 ơ,而这个括h体又可以匚w无限ơ,那么情况可能比上一条所说的更严重,匚wq程中可能死循环。虽然现在有些正则表辑ּ引擎已经通过办法避免?jin)这U情况出现死循环?jin),比?.NET 的正则表辑ּQ但是我们仍然应该尽量避免出现这U情c(din)如果我们在写表辑ּ旉C(jin)d@环,也可以从q一点入手,查找一下是否是本条所说的原因?/p> 4.6 合理选择贪婪模式与非贪婪模式Q参?a >话题讨论?/p> 4.7 ?"|" 的左右两边,Ҏ(gu)个字W最好只有一边可以匹配,q样Q不?x)因?"|" 两边的表辑ּ因ؓ(f)交换位置而有所不同?/p> Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1459667
备䆾数据
1、获取帮助:(x)
exp help=y
2. 导出一个完整数据库
exp user/pwd@instance file=path full=y
CZQexp system/system@xc file = c:/hehe fill =y
3 、导Z个或一l指定用h属的全部表、烦(ch)引和其他对象
exp system/manager file=seapark log=seapark owner=seapark exp system/manager file=seapark log=seapark owner=(seapark,amy,amyc,harold)
CZQexp system/system@xc file=c:/hehe owner=uep
4、导Z个或多个指定?br />
exp system/manager file=tank log=tank tables=(seapark.tank,amy.artist)
CZQexp system/system@xc file=c:/heh tables=(ueppm.ne_table)
恢复数据
imp help=y
imp system/manager file=bible_db log=dible_db full=y ignore=y
imp system/manager file=seapark log=seapark fromuser=seapark
imp system/manager file=seapark log=seapark fromuser=(seapark,amy,amyc,harold) imp system/manager file=tank log=tank fromuser=seapark touser=seapark_copy
imp system/manager file=tank log=tank fromuser=(seapark,amy) touser=(seapark1, amy1)
imp system/manager file=tank log=tank fromuser=seapark TABLES=(a,b)
]]>package com.xcblcx.test;
import java.util.ArrayList;
public class ThreadNotifyTest {
private ArrayList list = new ArrayList();
/**
* @param args
*/
public static void main(String[] args) {
ThreadNotifyTest test = new ThreadNotifyTest();
Queue queue = test.new Queue();
try{
Thread.sleep(1000);
for(int i=0;i<5;i++) {
queue.addStr(new Integer(i).toString());
Thread.sleep(1000);
}
}catch(Exception e) {
e.printStackTrace();
}
}
class ThreadTest extends Thread {
Queue queue = new Queue();
public ThreadTest() {
//this.queue = queue;
}
public void run() {
while(true) {
try{
System.out.println("Thread start
.");
String testStr = this.queue.getNext();
System.out.println(testStr);
}catch(Exception e ){
e.printStackTrace();
}
}
}
}
class Queue {
private ThreadTest threadTest = null;
public Queue(){
//this.threadTest = new ThreadTest(this);
this.threadTest = new ThreadTest();
this.threadTest.start();
}
public void addStr(String str) {
synchronized(list) {
list.add(str);
list.notify();
}
}
public String getNext() throws InterruptedException {
synchronized(list) {
while(list.size() <= 0) {
System.out.println("wait start");
list.wait();
System.out.println("wait end");
}
return (String)list.remove(0);
}
}
}
}
q行l果为:(x)
java.lang.StackOverflowError
Exception in thread "main"
请问Z么?
]]>
p么个问题Q搞?jin)我两天Q郁P发泄一下,重新开始blog生(dng)Q庆(jin)?
]]>
(g)验匮乏啊Q?
]]> java正则表达式入门文?
引言
正则表达式学?fn)v来其实是很简单的Q不多的几个较ؓ(f)抽象的概念也很容易理解。之所以很多h感觉正则表达式比较复杂,一斚w是因为大多数的文档没有做到由入深地讲解Q概念上没有注意先后序Q给读者的理解带来困难Q另一斚wQ各U引擎自带的文档一般都要介l它Ҏ(gu)的功能,然而这部分Ҏ(gu)的功能ƈ不是我们首先要理解的?br />
文章中的每一个D例,都可以点击进入到试面q行试。闲话少_(d)开始?/p>
1. 正则表达式规?/h4>
1.1 普通字W?/h5>
举例1Q表辑ּ "c"Q在匚w字符?"abcde" ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)"c"Q匹配到的位|是Q开始于2Q结束于3。(注:(x)下标?开始还是从1开始,因当前编E语a的不同而可能不同)(j)
举例2Q表辑ּ "bcd"Q在匚w字符?"abcde" ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)"bcd"Q匹配到的位|是Q开始于1Q结束于4?/p>1.2 单的转义字符
举例1Q表辑ּ "\$d"Q在匚w字符?"abc$de" ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)"$d"Q匹配到的位|是Q开始于3Q结束于5?/p>1.3 能够?'多种字符' 匚w的表辑ּ
举例2Q表辑ּ "a.\d"Q在匚w "aaa100" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?aa1"Q匹配到的位|是Q开始于1Q结束于4?/p>1.4 自定义能够匹?'多种字符' 的表辑ּ
举例2Q表辑ּ "[^abc]" 匚w "abc123" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?1"Q匹配到的位|是Q开始于3Q结束于4?/p>1.5 修饰匚wơ数的特D符?/h5>
使用Ҏ(gu)是:(x)"ơ数修饰"攑֜"被修饰的表达?后边。比如:(x)"[bcd][bcd]" 可以写成 "[bcd]{2}"?/p>
举例2Q表辑ּ "go{2,8}gle" 在匹?"Ads by goooooogle" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?goooooogle"Q匹配到的位|是Q开始于7Q结束于17?/p>1.6 其他一些代表抽象意义的Ҏ(gu)W号
举例1Q表辑ּ "^aaa" 在匹?"xxx aaa xxx" ?/font>Q匹配结果是Q失败。因?"^" 要求与字W串开始的地方匚wQ因此,只有?"aaa" 位于字符串的开头的时候,"^aaa" 才能匚wQ?a >比如Q?aaa xxx xxx"?br />
举例2Q表辑ּ "aaa$" 在匹?"xxx aaa xxx" ?/font>Q匹配结果是Q失败。因?"$" 要求与字W串l束的地方匹配,因此Q只有当 "aaa" 位于字符串的l尾的时候,"aaa$" 才能匚wQ?a >比如Q?xxx xxx aaa"?br />
举例3Q表辑ּ ".\b." 在匹?"@@@abc" ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)"@a"Q匹配到的位|是Q开始于2Q结束于4?br /> q一步说明:(x)"\b" ?"^" ?"$" cMQ本w不匚wM字符Q但是它要求它在匚wl果中所处位|的左右两边Q其中一Ҏ(gu) "\w" 范围Q另一Ҏ(gu) ?\w" 的范围?br />
举例4Q表辑ּ "\bend\b" 在匹?"weekend,endfor,end" ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)"end"Q匹配到的位|是Q开始于15Q结束于18?/p>
(2). 取匹配结果的时候,括号中的表达式匹配到的内容可以被单独得到
举例6Q表辑ּ "(go\s*)+" 在匹?"Let's go go go!" ?/font>Q匹配结果是Q成功;匚w到内Ҏ(gu)Q?go go go"Q匹配到的位|是Q开始于6Q结束于14?br />
举例7Q表辑ּ "K?font color="#5050ff">(\d+\.?\d*)" 在匹?"Q?0.9,K?0.5" ?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu)Q?K?0.5"Q匹配到的位|是Q开始于6Q结束于10。单独获取括可围匹配到的内Ҏ(gu)Q?20.5"?/p>2. 正则表达式中的一些高U规?/h4>
2.1 匚wơ数中的贪婪与非贪婪
在修饰匹配次数的Ҏ(gu)W号后再加上一?"?" P则可以匚wơ数不定的表辑ּ可能少的匹配,使可匚w可不匚w的表辑ּQ尽可能?"不匹?。这U匹配原则叫?"非贪? 模式Q也叫作 "勉强" 模式。如果少匚w׃(x)D整个表达式匹配失败的时候,与贪婪模式类|非贪婪模式会(x)最限度的再匹配一些,以整个表达式匹配成功。D例如下,针对文本 "dxxxdxxxd" 举例Q?/p>
举例1Q表辑ּ "<td>(.*)</td>" 与字W串 "<td><p>aa</p></td> <td><p>bb</p></td>" 匚w?/font>Q匹配的l果是:(x)成功Q匹配到的内Ҏ(gu) "<td><p>aa</p></td> <td><p>bb</p></td>" 整个字符Ԍ 表达式中?"</td>" 与字符串中最后一?"</td>" 匚w?
举例2Q相比之下,表达?"<td>(.*?)</td>" 匚w举例1中同L(fng)字符串时Q将只得?"<td><p>aa</p></td>"Q?再次匚w下一个时Q可以得到第二个 "<td><p>bb</p></td>"?/p>2.2 反向引用 \1, \2...
其实Q?括号包含的表达式所匚w到的字符? 不仅是在匚wl束后才可以使用Q在匚wq程中也可以使用。表辑ּ后边的部分,可以引用前面 "括号内的子匹配已l匹配到的字W串"。引用方法是 "\" 加上一个数字?\1" 引用W?Ҏ(gu)号内匚w到的字符Ԍ"\2" 引用W?Ҏ(gu)号内匚w到的字符东y(c)…以此类推,如果一Ҏ(gu)号内包含另一Ҏ(gu)P则外层的括号先排序号。换句话_(d)哪一对的左括?"(" 在前Q那q一对就先排序号?/p>
举例1Q表辑ּ "('|")(.*?)(\1)" 在匹?" 'Hello', "World" " ?/font>Q匹配结果是Q成功;匚w到的内容是:(x)" 'Hello' "。再ơ匹配下一个时Q可以匹配到 " "World" "?br />
举例2Q表辑ּ "(\w)\1{4,}" 在匹?"aa bbbb abcdefg ccccc 111121111 999999999" ?/font>Q匹配结果是Q成功;匚w到的内容?"ccccc"。再ơ匹配下一个时Q将得到 999999999。这个表辑ּ要求 "\w" 范围的字W至重?ơ,注意?"\w{5,}" 之间的区?/font>?br />
举例3Q表辑ּ "<(\w+)\s*(\w+(=('|").*?\4)?\s*)*>.*?</\1>" 在匹?"<td id='td1' style="bgcolor:white"></td>" ?/font>Q匹配结果是成功。如?"<td>" ?"</td>" 不配对,则会(x)匚wp|Q如果改成其他配对,也可以匹配成功?/p>2.3 预搜索,不匹配;反向预搜索,不匹?/h5>
格式Q?(?=xxxxx)"Q在被匹配的字符串中Q它Ҏ(gu)处的 "~隙" 或?"两头" 附加的条件是Q所在缝隙的右侧Q必能够匹配上 xxxxx q部分的表达式。因为它只是在此作ؓ(f)q个~隙上附加的条gQ所以它q不影响后边的表辑ּȝ正匹配这个缝隙之后的字符。这q?"\b"Q本w不匚wM字符?\b" 只是所在缝隙之前、之后的字符取来q行?jin)一下判断,不会(x)影响后边的表辑ּ来真正的匚w?br />
举例1Q表辑ּ "Windows (?=NT|XP)" 在匹?"Windows 98, Windows NT, Windows 2000" ?/font>Q将只匹?"Windows NT" 中的 "Windows "Q其他的 "Windows " 字样则不被匹配?br />
举例2Q表辑ּ "(\w)((?=\1\1\1)(\1))+" 在匹配字W串 "aaa ffffff 999999999" ?/font>Q将可以匚w6?f"的前4个,可以匚w9?9"的前7个。这个表辑ּ可以读解成:(x)重复4ơ以上的字母数字Q则匚w其剩下最?位之前的部分。当?dng)q个表达式可以不q样写,在此的目的是作ؓ(f)演示之用?/p>
举例3Q表辑ּ "((?!\bstop\b).)+" 在匹?"fdjka ljfdl stop fjdsla fdj" ?/font>Q将从头一直匹配到 "stop" 之前的位|,如果字符串中没有 "stop"Q则匚w整个字符丌Ӏ?br />
举例4Q表辑ּ "do(?!\w)" 在匹配字W串 "done, do, dog" ?/font>Q只能匹?"do"。在本条举例中,"do" 后边使用 "(?!\w)" 和?"\b" 效果是一L(fng)?/p>
q两U格式的概念和正向预搜烦(ch)是类似的Q反向预搜烦(ch)要求的条件是Q所在缝隙的 "左侧"Q两U格式分别要求必能够匹配和必须不能够匹配指定表辑ּQ而不是去判断右侧。与 "正向预搜? 一L(fng)是:(x)它们都是Ҏ(gu)在缝隙的一U附加条Ӟ本n都不匚wM字符?br />
举例5Q表辑ּ "(?<=\d{4})\d+(?=\d{4})" 在匹?"1234567890123456" Ӟ匹配除?jin)?个数字和?个数字之外的中间8个数字。由?JScript.RegExp 不支持反向预搜烦(ch)Q因此,本条举例不能够进行演C。很多其他的引擎可以支持反向预搜索,比如QJava 1.4 以上?java.util.regex 包,.NET 中System.Text.RegularExpressions 命名I间Q以?qing)本站推荐?a >最单易用的 DEELX 正则引擎?/p>3. 其他通用规则
①xxxxxxxxx②\n
③xxxxxxxxx?br />
配置?Multiline 可以?"^" 匚w ?外,q可以匹配换行符之后Q下一行开始前 ?的位|,?"$" 匚w ?外,q可以匹配换行符之前Q一行结??的位|?/p>4. 其他提示
]]>
T2 AS(SELECT DISTINCT B.C_MAIN_REF,B.C_UNIT_CODE,I_AUTH_LEVEL,B.C_CNTY_CODE,B.C_PRODUCT_ID FROM TRX_MATRIX_LIST A JOIN TRX_AUTH_LIST B ON A.C_MAIN_REF = B.C_MAIN_REF AND A.C_UNIT_CODE = B.C_UNIT_CODE AND A.C_CNTY_CODE = B.C_CNTY_CODE AND A.C_PRODUCT_ID = B.C_PRODUCT_ID AND A.I_OP_LEVEL = B.I_AUTH_LEVEL WHERE B.C_MAIN_REF NOT IN (SELECT DISTINCT C_MAIN_REF FROM TRX_AUTH_LIST WHERE C_USER_ID = 'usr1206')),
T3 AS(SELECT T2.C_MAIN_REF,T2.C_UNIT_CODE,T2.C_CNTY_CODE,T2.C_PRODUCT_ID FROM T2 JOIN T1 ON T1.C_UNIT_CODE = T2.C_UNIT_CODE AND T1.C_CNTY_CODE = T2.C_CNTY_CODE AND T1.C_PRODUCT_ID = T2.C_PRODUCT_ID AND T1.I_AUTH_LEVEL = T2.I_AUTH_LEVEL),
T4 AS(SELECT A. C_UNIT_CODE,A.C_TRX_STATUS,A.C_STATUS_NAME,A.C_PRODUCT_NAME,A.C_MAIN_REF,A.CUST_REF,A.COMP_NAME,A.SCB_REF,A.T_LOCKED_TIME,A.TXN_DATE,A.OTSTND_CCY,A.OTSTND_AMT,A.C_IS_TEMPLATE,A.C_GRP_CODE,A.C_FUNC_ID,A.C_CNTY_CODE,A.C_BK_GROUP_ID,A.C_MODULE,A.BANK_INIT,A.C_PRODUCT_ID,A.C_TRX_REF,A.I_EVENT_TIMES FROM TRX_INBOX A JOIN T3 ON T3.C_MAIN_REF = A.C_MAIN_REF AND T3.C_UNIT_CODE = A.C_UNIT_CODE AND T3.C_CNTY_CODE = A.C_CNTY_CODE AND T3.C_PRODUCT_ID = A.C_PRODUCT_ID WHERE (C_TRX_STATUS ='P'OR C_TRX_STATUS='T')AND (BANK_INIT <> 'T'OR BANK_INIT IS NULL)AND (C_IS_TEMPLATE <> 'Y'OR C_IS_TEMPLATE IS NULL) AND C_BK_GROUP_ID ='SCBBANK'),
T5 AS(SELECT DISTINCT A.C_UNIT_CODE,A.C_CNTY_CODE,B.C_PRODUCT_ID FROM TRX_OP_FUNC A JOIN TRX_FAP_RULE B ON A.C_FAP_ID = B.C_FAP_ID WHERE C_GRP_CODE = 'GRP1206' AND C_USER_ID = 'usr1206')
SELECT COUNT(*) AS RECCOUNT FROM T4 JOIN T5 ON T4.C_UNIT_CODE = T5.C_UNIT_CODE AND T4.C_CNTY_CODE = T5.C_CNTY_CODE AND T4.C_PRODUCT_ID = T5.C_PRODUCT_ID
UNION语句Q?br />SELECT C_MAIN_REF,I_AUTH_LEVEL,C_TRX_STATUS ,TXN_DATE,TXN_TIME FROM shgt_auth WHERE C_MAIN_REF='SGGHYLL10030' And C_UNIT_CODE='CINDYGP'
AND C_CNTY_CODE='CN' AND C_trx_status = 'A'
UNION
select B.C_MAIN_REF,B.I_AUTH_LEVEL,B.C_TRX_STATUS ,B.TXN_DATE,B.TXN_TIME from TRX_AUTH_LIST A,shgt_auth B
WHERE B.C_MAIN_REF='SGGHYLL10030' And B.C_UNIT_CODE='CINDYGP'
Ҏ(gu)定表不写日志Qalter table *** activate not logged initially
创徏表:(x)
DELETE FROM TABLE EXIMTRX.KEYTEST;
DROP TABLE EXIMTRX.KEYTEST;
CREATE TABLE EXIMTRX.KEYTEST
(
USER_ID INTEGER,
USER_NAME VARCHAR(10) NOT NULL,
USER_ADDR VARCHAR(10) NOT NULL,
USER_MAIL VARCHAR(10) NOT NULL,
USER_SEC VARCHAR(10) NOT NULL,
HASH VARCHAR(10),
PRIMARY KEY (USER_ID,USER_NAME,USER_ADDR,USER_MAIL,USER_SEC)
);
(g)索数据库表中的不重复记录 (按B列来查询Q去除B列中的重复数据)(j)
SELECT * FROM TEST WHERE id in (SELECT MIN(id) FROM TEST GROUP BY B)
1、查找表中多余的重复记录Q重复记录是Ҏ(gu)单个字段QpeopleIdQ来判断
select * from people
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
2、删除表中多余的重复记录Q重复记录是Ҏ(gu)单个字段QpeopleIdQ来判断Q只留有rowid最的记录
delete from people
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)
and rowid not in (select min(rowid) from people group by peopleId having count(peopleId )>1)
3、查找表中多余的重复记录Q多个字D)(j)
select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
4、删除表中多余的重复记录Q多个字D)(j)Q只留有rowid最的记录
delete from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
5、查找表中多余的重复记录Q多个字D)(j)Q不包含rowid最的记录
select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
复制?br />create table trx_inbox_back like trx_inbox
insert into trx_inbox_back select * from trx_inbox
创徏视图
drop view view_sql
create view view_sql as
select * from table where ....
create view viewTest(id,name,cnty,address) as
select a.id,a.col1,a.col2,b.col1 from tablea a ,tableb b where a.id<10000 and a.id=b.id;
select * from viewTest where id<5000
建立索引
create index idx_inbox_back on TRX_INBOX_BACK(C_CNTY_CODE,C_UNIT_CODE,C_PRODUCT_ID)
选取?00条记?br />select * from trx_inbox FETCH FIRST 100 ROWS ONLY
join 语句
SELECT DISTINCT A.CUST_REF,A.SCB_REF,A.COMP_NAME,A.C_PRODUCT_NAME,A.COUNTER_PARTY_NAME,A.C_STATUS_NAME,A.C_TRX_STATUS,A.C_UNIT_CODE FROM TRX_INBOX_back A JOIN TRX_OP_FUNC B ON A.C_CNTY_CODE = B.C_CNTY_CODE AND A.C_UNIT_CODE = B.C_UNIT_CODE AND A.C_PRODUCT_ID = B.C_PRODUCT_ID AND B.C_GRP_CODE = 'HKGROUP' AND B.C_USER_ID = 'hkuser' WHERE ( A.C_TRX_STATUS = 'P' OR A.C_TRX_STATUS = 'T') AND (A.BANK_INIT <> 'T' OR A.BANK_INIT IS NULL) AND (A.C_IS_TEMPLATE <> 'Y' OR A.C_IS_TEMPLATE IS NULL) AND A.C_BK_GROUP_ID ='SCBBANK' AND A.C_MAIN_REF LIKE '%xcblcx%' AND A.C_PRODUCT_ID = 'P05102100000'
count指定字段 Q去除指定字D重复行Q注Q指定字D中不能包括 INTEGER cd
select count( distinct user_id || user_sec) as counter from test
通配W的一些用法:(x)(关键字:(x)like % [] -)
select * from tablename where column1 like '[A-M]%'
q样可以选择出column字段中首字母在A-M之间的记?br />
select * from tablename where column1 like '[ABC]%'
q样可以选择出column字段中首字母是A或者B或者C的记?br />
select * from tablename where column1 like '[A-CG]%'
q样可以选择出column字段中首字母在A-C之间的或者是G的记?br />
select * from tablename where column1 like '[^C]%'
q样可以选择出column字段中首字母不是C的记?br />
脱字W(关键字:(x)like _Q?br /> 通过使用下滑U字W(_Q,可以匚wL单个字符
select * from tablename where column1 like 'M_crosoft'
匚wҎ(gu)字符Q([ ] _ - %Q?br /> 把他们都攑ֈ[]中就行了(jin)Q比如:(x)
select * from tablename where column1 like '%[%]%'
匚w发音Q关键字Q?/span>SOUNDEX DIFFERENCEQ?br /> 如果不知道一个名字确切的发音Q但是又多少知道一点,可以考虑使用SOUNDEX DIFFERENCE函数?br /> select * from tablename where DIFFERENCE(column1,'Laofei'>3)
DIFFERENCEq回0-4之间的数字,4是非常接q,0是差异非常大
要深入了(jin)解DIFFERENCE函数的工作原理,使用SOUNDEX函数q回DIFFERENCE函数所使用的音标码
select column1 as column,SOUNDEX(column1) 'sound like'
注意Q?br /> DIFFERENCE函数比较两个字符串的W一个字母和所有的辅音字母Q该函数忽略M元音字母Q包括YQ?除非元音字母是该字符串的W一个字母?br /> 使用q两个函数在where中执行效果ƈ不好Q所以尽量少使用?/span>
===client?==
Z(jin)一个out和in:(x)
BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
PrintWriter Clientout = new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())),true);
向server端输出:(x)clientOut.println("hello"); clientout.close();
{待服务器端q回代码片段Q?br />StringBuffer sbuf = new StringBuffer();
char[] buff = new char[10];
int iLen = in.read(buff);
while (iLen>0) {
sbuf.append(buff,0,iLen);
if (sbuf.toString().trim().equals("hello")){
System.out.println(sbuf.toString());
break;
}
iLen = in.read(buff);
}
===server?==
同样Z(jin)一个in和out?br />BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
PrintWriter Serverout = new PrintWriter(new BufferedWriter( new OutputStreamWriter(socket.getOutputStream())),true);
接收client端信息和原样q回信息:
StringBuffer sbuf = new StringBuffer();
char[] buff = new char[10];
int iLen = in.read(buff);
while(iLen>0){
sbuf.append(buff,0,iLen);
if (sbuf.toString().trim().equals("hello")){
System.out.println("Echoing: " + sbuf.toString());
serverout.println(sbuf.toString()); //此处为server端输出流,q回lclient?br /> break;
}
iLen = in.read(buff);
}
问题来了(jin):
1、如果按以上代码q行,server端可以收到client的信?但client端却收不到返回的信息。ؓ(f)什么?
2、后来我把client端的clientout.close()注释掉后Q一切正常,client端能收到server端返回的信息。这又ؓ(f)什么?
Nserver端和client端用的是一个out?Z么client端把out关掉后Qclientout.close())Qserver端就不能q回信息呢?
以我以前的理解,server端和client端徏的两个输出流应该是独立的。不?x)因为我把client端的out关掉后Qserver端out就不能q回?jin)?不?x)吧!呵呵Q?/font>
q有一个问题:(x)server端怎么判断client端数据已l发送完毕?
一开始,我用clientout.print("hello"),q行后,server端显C已l连接成功但一直侦听,没有收到信息Q认为client端还没有发送完成?br />后来Q我改用clientout.println("hello"),q行后,一切正常,服务器端也收C息(helloQ?br />从上看出server的地判定是一个回车符Q不知道q样认识对不对?大家指点Q?br />l过我试验,如果client端print后,用clientout.close()也可以server端接收到信息。但却不能返回信息。也是我发C面说q的问题来由?/font>
以上几个问题Q请大家和banq大哥多加指点Q?/font>
源代码如下:(x)
client端:(x)
package com.socket;
import java.net.*;
import java.io.*;
public class ConnClient {
public static void main(String[] args) throws IOException {
I(yng)netAddress addr = InetAddress.getByName(null);
System.out.println("addr = " + addr);
Socket socket = new Socket(addr, 8080);
//socket.setSoTimeout(5000);
try {
System.out.println("socket = " + socket);
BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
PrintWriter clientout = new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())),true);
String strSend = "hello";
clientout.println(strSend);
//clientout.println("\r\n");
//clientout.println();
//clientout.close();
StringBuffer sbuf = new StringBuffer();
char[] buff = new char[10];
int iLen = in.read(buff);
while (iLen>0) {
sbuf.append(buff,0,iLen);
if (sbuf.toString().trim().equals(strSend)){
System.out.println(sbuf.toString());
break;
}
iLen = in.read(buff);
}
}catch(Exception e){
e.printStackTrace();
} finally {
System.out.println("closing...");
socket.close();
}
}
}
server端代码:(x)
package com.socket;
import java.io.*;
import java.net.*;
public class ConnServer {
public static final int PORT = 8080;
public static void main(String[] args) throws IOException {
ServerSocket s = new ServerSocket(PORT);
System.out.println("Started: " + s);
try {
Socket socket = s.accept();
try {
System.out.println("Connection accepted: "+ socket);
BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
PrintWriter serverout = new PrintWriter(new BufferedWriter( new OutputStreamWriter(socket.getOutputStream())),true);
StringBuffer sbuf = new StringBuffer();
char[] buff = new char[10];
iLen = in.read(buff);
while(iLen>0){
sbuf.append(buff,0,iLen);
if(sbuf.toString().trim().equals("hello")){
System.out.println("Echoing: " + sbuf.toString());
serverout.println(sbuf.toString());
}
iLen = in.read(buff);
}
}catch(Exception e) { e.printStackTrace();}
finally {
System.out.println("closing...");
socket.close();
}
} finally {
s.close();
}
}
}