2012年10月31日 星期三

SQL实现模糊搜索,即SQL LIKE 通配符的用法


 与任意单字符匹配

%    与包含一个或多个字符的字符串匹配

[ ] 与特定范围(例如,[a-f])或特定集(例如,[abcdef])中的任意单字符匹配。

[^] 与特定范围(例如,[^a-f])或特定集(例如,[^abcdef])之外的任意单字符匹配。
使用like比较字,加上SQL里的通配符,请参考以下:
a.. LIKE 'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden)。
b.. LIKE '%inger' 将搜索以字母 inger 结尾的所有字符串(如 Ringer、
Stringer)。
c.. LIKE '%en%' 将搜索在任何位置包含字母 en 的所有字符串(如 Bennet、
Green、McBadden)。
d.. LIKE '_heryl' 将搜索以字母 heryl 结尾的所有六个字母的名称(如 Cheryl、
Sheryl)。
e.. LIKE '[CK]ars[eo]n' 将搜索下列字符串:Carsen、Karsen、Carson 和 Karson
(如 Carson)。
f.. LIKE '[M-Z]inger' 将搜索以字符串 inger 结尾、以从 M 到 Z 的任何单个字
母开头的所有名称(如 Ringer)。
g.. LIKE 'M[^c]%' 将搜索以字母 M 开头,并且第二个字母不是 c 的所有名称(如
MacFeather)。



例子:
WHERE FirstName LIKE '_im' 可以找到所有三个字母的、以 im 结尾的名字(例如,Jim、Tim)。 

WHERE LastName LIKE '%stein' 可以找到姓以 stein 结尾的所有员工。 

WHERE LastName LIKE '%stein%' 可以找到姓中任意位置包括 stein 的所有员工。 

WHERE FirstName LIKE '[JT]im' 可以找到三个字母的、以 im 结尾并以 J 或 T 开始的名字(即仅有 Jim 和 Tim) 

WHERE LastName LIKE 'm[^c]%' 可以找到以 m 开始的、后面的(第二个)字母不为 c 的所有姓。

C#正则表达式语法规则


正则表达式通常包含字母文本(Literal text)和元字符(metacharacter)
字母文本指的是普通文本如"abcde"可匹配字符串中任何包含"abcde"的字符串。
元字符则更加灵活运用通用的表达式匹配所有符合此表达式规律的字符串。
一、匹配单个字符
[ ]——从中选择一个字符匹配
中间支持的类型:单词字符([ae])、非单词字符([!?,;@#$*])、字母范围([A-Z])、数字范围([0])
eg.  正则表达式  可匹配字符串 
[ae]ffect      affect,effect
(此例中"[ae]"为元字符,"ffect"为字母文本)
注意:1.要在字符类中匹配连字符,那么把连字符号作为第一个字符列出即可。
            2.可以在单个正则表达式中包含多个字符类。
             eg.   [01][0-9]:[0-5][0-9][ap]m 可以用来匹配如12:59pm格式的所有时间
^——排除某些字符(在[ ]中表此意,还可表示字符串的开头)
eg.  正则表达式  可匹配字符串  不可匹配字符串 
m[^a]t  met,mit,m&t……  mat

 
二、匹配特殊字符
可以使用的特殊字符:
\t ——匹配制表符
\r ——匹配硬回车符
\f ——匹配换页符
\n——匹配换行符
描述表示字符类的元字符:
 ——匹配任何除了\n以外的字符(或者在单行模式中的任何字符)
\w ——匹配任何单词字符(任何字母或数字)
\W ——匹配任何非单词字符(除了字母和数字以外的任何字符)
\s  ——匹配任何空白字符(包括空格、换行、制表符等)
\S ——匹配任何非空白字符(除了空格、换行、制表符等的任何字符)
\d ——匹配任何数字字符(0~9的数字) 
\D——匹配任何非数字字符(除了0~9以外的任何字符)
表示字符串中字符位置:
^ ——匹配字符串的开头(或者多行模式下行的开头)。
$ ——匹配字符串的结尾,或者是字符串结尾“\n”之前的最后一个字符,或者是多行模式中的行结尾。
\A——匹配字符串的开头(忽略多行模式)
\Z——匹配字符串的结尾或字符串结尾“\n”之前的最后一个字符(忽略多行模式)。
\z——匹配字符串的结尾。
\G——匹配当前搜索开始的位置。
\b——匹配单词的边界。
\B——匹配单词的非边界。
注意:
1.句点字符(.)特别有用。可以用它来表示任何一个字符。
eg.  正则表达式  可匹配字符串 
01.17.84  01/17/84 , 01-17-84 , 01 17 84 , 01.17.84
      

 2.可以使用\b匹配单词的边界
eg. 正则表达式  可匹配字符串  不可匹配字符串 
\blet\b  let  letter,hamlet


3.\A和\z在确保字符串所包含的是某个表达式,而不是其他内容时很用。
eg.要判断Text控件是否包含单词"sophia",而不含任何额外的字符、换行符或者空白。
\Asophia\z
4.句点字符( . )具有特殊的含义,若要表示字母字符本身的含义,在前面加一个反斜杠:\.
三、匹配而选一的字符序列
|——匹配二选一
eg.  正则表达式  可匹配字符串 
col(o|ou)r  color,colour
      

注意: \b(bill|ted)和\bbill|ted是不同的。
               后者还可以匹配"malted"因为\b元字符只应用于"bill"。
四、用量词匹配
        ——匹配0次或多次
       ——匹配1次或多次
       ——匹配0次或1次
{n}     ——恰好匹配n次
{n,}    ——至少匹配n次
{n,m}——至少匹配n次,但不多于m次
eg.  正则表达式  可匹配字符串 
brothers?  brother,brothers
   

eg.  正则表达式  可匹配字符串 
\bp\d{3,5}\b  以p开头,且后跟3~5个数字结尾
   

注意:也可以把量词与()一起使用,以便把该量词应用到整个字母序列。
eg.  正则表达式  可匹配字符串 
(The)?school is beautiful.  school is beautiful,The school is beautiful.
   

五、识别正则表达式和贪婪
有些量词是贪婪的(greedy).他们会尽可能多的匹配字符。
如量词* 匹配0个或多个字符。假设要匹配字符串中任何HTML标签。你可能会用如下正则表达式:
<.*>
现有字符串A <i>quantifier</i> can be <big> greedy</big>
结果<.*>把 <i>quantifier</i> can be <big> greedy</big>都匹配上了。
要解决该问题,需要与量词一起使用一个特殊的非贪婪字符“?”,因此表达式变化如下:
<.*?>
这样就可以正确匹配<i>、</i>、<big>、</big>。
?能强制量词尽可能少地匹配字符,?还可以用在以下几个量词中:
*?       ——非贪婪的量词*
+?      ——非贪婪的量词+
??      ——非贪婪的量词?
{n}?    ——非贪婪的量词{n}
{n,}?   ——非贪婪的量词{n,}
{n,m}?——非贪婪的量词{n,m}
六、捕获和反向引用
捕获组(capture group)就像是正则表达式中的变量。捕获组可以捕获正则表达式中的字符模式,并且由正则表达式后面的编号或名称来引用改模式。
( )    ——用来捕获其中的字符串
\数字——用编号来引用
eg. 

正则表达式  可匹配字符串 
(\w)(\w)\2\1  abba


注意:1.反向引用用来匹配html标签非常有效如<(\w+)></\1>可以匹配<table></table>等类似格式的标签。
             2.默认情况下,只要使用圆括号,就会捕获圆括号内所包含的字符,可以使用n选项来禁用这个默认行为(在第7条里会详细介绍),或者添加?:到圆括号中。eg. (?:sophia)   或 (?n:sophia)此时不会捕获sophia。
(?<捕获组名称>)\k<捕获组名称>——用名称来引用
eg. 

正则表达式  可匹配字符串 
(?<sophia>\w)abc\k<sophia>  xabcx


注意:在替换模式中使用捕获组的格式略有不同,要用$1、$2等来按数值引用捕获,用${sophia}等名称来按名称引用捕获组
七、设置正则表达式的选项
eg.
string str = "<h4>sophia</h4>"
RegEx objRegEx = new RegEx("<h(d)>(.*?)</h1>");
Response.Write(objRegEx.Replace(str,"<font size = $1>$2</font>"));
 
 ——所执行的匹配是不区分大小写的(.net中的属性为IgnoreCase)
m——指定多行模式(.net中的属性为Multiline)
n ——只捕获显示命名或编号的组(.net中的属性为ExplicitCapture)
c ——编译正则表达式,这样会产生较快的执行速度,但启动会变慢(.net中的属性为Compiled)
s ——指定单行模式(.net中的属性为SingleLine)
x ——消除非转义空白字符和注释(.net中的属性为IgnorePatternWhitespace)
r ——搜索从右到左进行(.net中的属性为RightToLeft)
- ——表示禁用。
eg. (?im-r:sophia)  允许不区分大小写匹配sophia,使用多行模式,但禁用了从右到左的匹配。
注意:1.m会影响如何解析起始元字符(^)和结束元字符($)。在默认情况^和$只匹配整个字符串的开头,即使字符串包含多行文本。如果启用了m,那么它们就可以匹配每行文本的开头和结尾。
          2.s会影响如何解析句点元字符(.)。通常一个句点能匹配除了换行符以外的所有字符。但在单行模式下,句点也能匹配一个换行符。

ASP.NET取得網卡MAC地址


详细代码请参考下面,代码多有参考网络,为我所用(客户端)。
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

//引入相应的空间信息
using System.Text.RegularExpressions;
using System.Diagnostics;



public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {
        //此处输入Ip地址,你可以做成接受文本框的值进行查询
        Response.Write(GetCustomerMac("192.168.168.242"));
    }

  
    //这里是关键函数了
    public string GetCustomerMac(string IP) 
    { 
       string dirResults=""; 
       ProcessStartInfo psi  = new ProcessStartInfo(); 
       Process proc = new Process(); 
       psi.FileName = "nbtstat"; 
       psi.RedirectStandardInput = false; 
       psi.RedirectStandardOutput = true; 
       psi.Arguments = "-a " + IP; 
       psi.UseShellExecute = false; 
       proc = Process.Start(psi); 
       dirResults = proc.StandardOutput.ReadToEnd(); 
       proc.WaitForExit();
        
       //匹配mac地址
       Match m = Regex.Match(dirResults, "\\w+\\-\\w+\\-\\w+\\-\\w+\\-\\w+\\-\\w\\w");

       //若匹配成功则返回mac,否则返回找不到主机信息
       if (m.ToString() != "")
       {
           return m.ToString();
       }
       else
       {
           return "找不到主机信息";
       }       

     }
}
讲到如何取得网卡mac地址,就不得不讲到dos命令:NBTSTAT,下面简单介绍下(客户端):
1. 具体功能
  该命令用于显示本地计算机和远程计算机的基于 TCP/IP(NetBT) 协议的 NetBIOS 统计资料、 NetBIOS 名称表和 NetBIOS 名称缓存。 NBTSTAT 可以刷新 NetBIOS 名称缓存和注册的 Windows Internet 名称服务 (WINS) 名称。使用不带参数的 NBTSTAT 显示帮助。
2. 语法详解
nbtstat [-a remotename] [-A IPaddress] [-c] [-n] [-r] [-R] [-RR] [-s] [-S] [Interval]
3. 参数说明
-a remotename 显示远程计算机的 NetBIOS 名称表, 其中, remote name 是远程计算机的 NetBIOS 计算机名称。 NetBIOS 名称表是运行在该计算机上的应用程序使用的 NetBIOS 名称列表。 
-A IPaddress 显示远程计算机的 NetBIOS 名称表, 其名称由远程计算机的 IP 地址指定 ( 以小数点分隔 ) 。 
-c 显示 NetBIOS 名称缓存内容、 NetBIOS 名称表及其解析的各个地址。 
-n 显示本地计算机的 NetBIOS 名称表。 Registered 中的状态表明该名称是通过广播或 WINS ******注册的。 
-r 显示 NetBIOS 名称解析统计资料。 在配置为使用 WINS 的 Windows 计算机上,该参数将返回已通过广播和 WINS 解析和注册的名称号码。 
-R 清除 NetBIOS 名称缓存的内容并从 Lmhosts 文件中重新加载带有 #PRE 标记的项目。 
-RR 重新释放并刷新通过 WINS 注册的本地计算机的 NetBIOS 名称。 
-s 显示 NetBIOS 客户和******会话,并试图将目标 IP 地址转化为名称。 
-S 显示 NetBIOS 客户和******会话,只通过 IP 地址列出远程计算机。
  Interval 重新显示选择的统计资料,可以中断每个显示之间的 Interval 中指定的秒数。 按Ctrl+C 停止重新显示统计信息。如果省略该参数, NBTSTAT 将只显示一次当前的配置信息。
我们试下它的功能:在DOS窗口下,输入:
nbtstat -a 192.168.168.242
       这里的192.168.168.242是我的本机IP,测试中发现呆会的程序并不能取得非本地的mac地址,也就是说只能取得******的网卡mac地址,而不能取得客户端的网卡mac地址,记得以前用一些黑客软件的时候可以办到获取对方的网卡mac地址的,有空研究下。结果如下图:
看到网卡的MAC地址了吧!也就是:
MAC Address = 00-18-F3-A7-E1-56
所以在asp.net中我们也是根据这个原理,先取得指定Ip的所有信息后,再用正则取得我们要的mac地址。

法二 (载自 http://topic.csdn.net/t/20020619/14/815413.html)(******端)
using   System.Management;   ...   
    ManagementClass   mc   =   new   ManagementClass("Win32_NetworkAdapterConfiguration");   
    ManagementObjectCollection   moc   =   mc.GetInstances();     
  foreach(ManagementObject   mo   in   moc)     
  {     
  if((bool)mo["IPEnabled"]   ==   true)   
                    {   
        Console.WriteLine("MAC   address\t{0}",   mo["MacAddress"].ToString());     
                          mo.Dispose();     
  }     
  }
如果系统提示找不到名字空间Management,   
  1.   在Solution   Explorer中鼠标右键单击References,选择Add   Reference...     
  2.   此时会弹出Add   Reference对话框,选中.NET选项卡。   
  3.   选中System.Management,点select   
  4.   点击"OK"。