易图难 细图大 汇盛人生
爱在进行时
随笔- 44  文章- 1  评论- 25 
博客园  首页  新随笔  联系  管理  订阅 订阅
2004年11月4日
终端服务器超出了最大允许连接数的解决办法
 终端服务器超出了最大允许连接数的解决办法
 
终端服务器超出了最大允许连接数的解决办法
1、首先你可以telnet到此主机上(不管你用哪种方法),当然如果能直接操作机器更好,不过直接操作就不必用命令行了,用控制台更直观,这里不是我们讲述的问题,略过。
2、Telnet上去后,先看登陆的用户:
输入命令:query user
系统返回:
USERNAME SESSIONNAME ID STATE IDLE TIME LOGON TIME
administrator console   0 运行中 .  2004-10-09 15:37
user1 UserMachine1   1 运行中 .  2004-10-09 15:37
user2                          12 已断开 无 2004-10-09 15:37
此时可以看出的可能根我们的不一样,根据具体情况而定。
看到吗? ID 0 的用户是本地登陆的,ID 1 和 ID 12是3389登陆的用户,前者在运行中,后者已经断开了,但是断开了仍然占用系统资源和通道,我们要把它踢掉。如下进行操作即可。
输入命令:logoff 12
C:\>query user //再看看
USERNAME SESSIONNAME ID STATE IDLE TIME LOGON TIME
administrator console 0 运行中 . 2004-10-09 15:37
user1 UserMachine1   1 运行中 .  2004-10-09 15:37
3、如果服务器关闭了telnet功能(这是默认的),还可以通过SqlServer的xp_cmdshell扩展存储过程,使用格式:master.dbo.xp_cmdshell '命令内容',其余可参考第二步。此方式要求有访问xp_cmdshell的权限。
posted @ 2008-08-05 11:59 xyicheng 阅读(22) | 评论 (0) | 编辑
Delphi中的容器类(转)
     摘要: Delphi中的容器类作者 陈省从Delphi 5开始VCL中增加了一个新的Contnrs单元,单元中定义了8个新的类,全部都是基于标准的TList 类。 TList 类TList 类实际上就是一个可以存储指针的容器类,提供了一系列的方法和属性来添加,删除,重排,定位,存取和排序容器中的类,它是基于数组的机制来实现的容器,比较类似于C++中的Vector和Java中的ArrayList,TList... 阅读全文
posted @ 2008-05-24 15:13 xyicheng 阅读(133) | 评论 (0) | 编辑
Delphi动态数组介绍(转)

    从 Delphi4起,开始了内建各种类型的动态数组支持。但是,对我们来说动态数组支持似乎做的不够彻底,因为Delphi竟然连删除、插入、移动连续元素的函数都没有提供,让人使用起来总觉得不够爽!!! J 。作为一名程序员,我们当然要有自己解决问题的能力,下面就让我们简单介绍一下Delphi 下的动态数组。

在Delphi中,数组类型有静态数组(a : array[0..1024] of integer)、动态数组(var a : array of integer)、指针数组(即指向静态数组的指针)和开放数组(仅用于参数传递)。静态数组、指针数组有速度快的好处,动态数组有大小可变的优势,权衡之下就有了折衷的办法,那就是定义的动态数组在必要时转换为指针。

动态数组声明之后,只有下面几个函数可供操作:

1. 设置数组大小,可以任意缩减或增加数组大小

Procedure SetLength(var S ; NewLength : integer);

2. 取出连续元素,复制给另一个数组变量

Function Copy(s;Index,Count : integer) : array ;

3. 取得数组大小及上下限

Function Length(s):integer;

Function High(x):integer;

Function Low(x):integer;

值得注意的是,不加const或var修饰的动态数组会被作为形参传递,而动态数组用const修饰并不意味着你不能修改数组里的元素(不信你可以字自己在程序中试试。还有一点是High函数调用了Length 函数,所以我们在获取数组上限时最好直接用 Length(s) 函数。

动态数组在内存空间中占用4个字节.   动态数组在内存中的分配表如下:

偏移量                                     内容

-8                                   32-bit 引用计数

-4                                   32-bit 数组长度

0..数组长度 * (元素尺寸) - 1 数组元素    元素尺寸=Sizeof(元素类型)

根据上面的分配情况,可以得到如下结果:

如果我们想要清空一个动态数组只需要把“数组长度”和“引用计数”清空即可。”引用上面的一句话就是:“权衡之下就有了折衷的办法,那就是定义的动态数组在必要时转换为指针。”下面是清空动态数组的函数:

procedure DynArraySetZero(var A);

var

 P: PLongint; //占用4个字节,正好符合 32 位内存排列

begin

 P := PLongint(A); // 指向 A 的地址

 Dec(P); //P 地址偏移量是 sizeof(A),指向了数组长度

 P^ := 0; // 长度清空

 Dec(P); // 指向引用计数

 P^ := 0; //计数清空。

end;

上面的函数就这么简单,而且效率也非常高。

下面让我们再来看看怎样删除动态数组中的元素,函数体如下:

{************************************

 A 变量类型 , elSize = SizeOf(A)

index 开始删除的位置索引 ,Count 删除的数量

****************************************}

procedure DynArrayDelete(var A; elSize: Longint; index, Count: Integer);

var

 len, MaxDelete: Integer;

 P : PLongint; //4 个字节的长整形指针

begin

 P := PLongint(A);// 取的 A 的地址

 if P = nil then

    Exit;

 {

下面这句完全等同于 Dec(P) ; len := P^ 因为 Dec(P) = Pchar(P) – 4 同样是移动4 字节的偏移量,只不过后者按字节来移动    }

len := PLongint(PChar(P) - 4)^; // 变量的长度 ,偏移量 -4

 if index >= len then //要删除的位置超出范围,退出

    Exit;

 MaxDelete := len - index; // 最多删除的数量

 Count := Min(Count, MaxDelete); // 取得一个较小值

 if Count = 0 then // 不要求删除

    Exit; 

Dec(len, Count);// 移动到要删除的位置

 MoveMemory(PChar(P)+index*elSize , PChar(P)+(index + Count)*elSize , (len-index)*elSize); //移动内存

 Dec(P); //移出 “数组长度”位置

 Dec(P); //移出“引用计数” 位置

 //重新再分配调整内存,len 新的长度. Sizeof(Longint) * 2 = 2*Dec(P)

 ReallocMem(P, len * elSize + Sizeof(Longint) * 2);

 Inc(P); // 指向数组长度

 P^ := len; // new length

 Inc(P); // 指向数组元素,开始的位置

 PLongint(A) := P;

end;

 

对上面的例子,我们需要注意的是 elSize 参数 ,它必须是 SizeOf(DyArray_Name),表示元素所占用的字节数。

    相信看了上面的例子后,对于动态数组的拷贝,移动想必也可以自己实现了吧 J

后续:

    其实,Delphi 对许多类型的内存分配都很相似,比如 string 类型,其实它和动态数组是很相似的,我们完全可以把它拿来当成动态数组。实质上 string 是 Pchar 的简易版本。不管怎么说,了解一些内存的分配对我们这些开发人员来说还是有一些好处的。

posted @ 2008-05-24 14:35 xyicheng 阅读(396) | 评论 (0) | 编辑
为sql server 表数据生成创建的储存过程(生成insert 脚本) (转)

为sql server 表数据生成创建的储存过程(生成insert 脚本)

使用SQL Server 2000自带的“生成SQL脚本”工具,可以生成创建表、视图、存储过程等的SQL脚本。那么,能否将表中的数据也生成为SQL脚本,在查询分析器中执行这些脚本后自动将数据导入到SQL Server中呢?答案是肯定的。

CREATE PROCEDURE   dbo.OutputData     
 @tablename   sysname      
 AS      
 declare   @column   varchar(1000)     
 declare   @columndata   varchar(1000)     
 declare   @sql   varchar(4000)     
 declare   @xtype   tinyint      
 declare   @name   sysname      
 declare   @objectId   int      
 declare   @objectname   sysname      
 declare   @ident   int      

 set   nocount   on      
 set   @objectId=object_id(@tablename)     
 if  @objectId   is   null   --   判断对象是否存在     
 
   begin      
      print  @tablename + '对象不存在'     
      return      
    end     

 set @objectname=rtrim(object_name(@objectId))     
 if @objectname is null or charindex(@objectname,@tablename)=0
    begin      
      print  @tablename + '对象不在当前数据库中'      
      return      
    end        

 if  OBJECTPROPERTY(@objectId,'IsTable')   <   >   1   --   判断对象是否是表     
    begin      
      print  @tablename + '对象不是表'     
      return      
    end        

 select   @ident=status&0x80   from   syscolumns   where   id=@objectid   and   status&0x80=0x80         

 if @ident is   not   null      
    print   'SET   IDENTITY_INSERT   '+ @TableName + '   ON'    

 --定义游标,循环取数据并生成Insert语句
 declare  syscolumns_cursor cursor for   
    select   c.name,c.xtype   from   syscolumns   c     
      where   c.id=@objectid     
      order   by   c.colid    

 --打开游标
 open   syscolumns_cursor     
 set  @column=''     
 set  @columndata=''     
 fetch   next   from   syscolumns_cursor   into   @name,@xtype     
 while   @@fetch_status   <> -1     
    begin      
    if   @@fetch_status   <> -2     
      begin      
      if   @xtype   not   in(189,34,35,99,98)   --timestamp不需处理,image,text,ntext,sql_variant 暂时不处理     
        begin      
        set   @column=@column + 
          case   when   len(@column)=0   then ''  
                 else   ','
                 end + @name     
        set   @columndata = @columndata + 
          case   when   len(@columndata)=0   then   ''   
                 else   ','','','
                 end  + 
          case   when  @xtype   in(167,175) then   '''''''''+'+@name+'+'''''''''                --varchar,char     
                 when   @xtype   in(231,239)   then   '''N''''''+'+@name+'+'''''''''             --nvarchar,nchar     
                 when   @xtype=61   then   '''''''''+convert(char(23),'+@name+',121)+'''''''''   --datetime     
                 when   @xtype=58   then   '''''''''+convert(char(16),'+@name+',120)+'''''''''   --smalldatetime     
                  when   @xtype=36   then   '''''''''+convert(char(36),'+@name+')+'''''''''       --uniqueidentifier     
                 else   @name   
                 end      
        end      
      end      
    fetch   next   from   syscolumns_cursor   into   @name,@xtype     
    end      
 close   syscolumns_cursor     
 deallocate   syscolumns_cursor         

 set  @sql='set   nocount   on   select   ''insert   '+@tablename+'('+@column+')   values(''as   ''--'','+@columndata+','')''   from   '+@tablename        

 print   '--'+@sql     
 exec(@sql)         

 if   @ident   is   not   null      
 print  'SET   IDENTITY_INSERT   '+@TableName+'   OFF'    

调用时 exec   OutputData   'myuser' 其中myUser中当前数据库中存在的表

posted @ 2008-05-15 16:05 xyicheng 阅读(75) | 评论 (0) | 编辑
Delphi7 函数
函数由一句或多句代码组成,可以实现某个特定的功能。使用函数可以使代码更加易读、易懂,加快编程速度及减少重复代码。过程与函数类似,过程与函数最重要的区别在于,过程没有返回值,而函数能有返回值。

  在Delphi 7.0中,已为我们定义好了非常多的函数,大致分类有6种:数据类型转换函数、字符串、数组操作函数、文件、磁盘操作函数、内存、指针操作函数、数学运算函数、日期函数。

  在Delphi中调用函数,一般情况下可以直接使用函数即可,但由于有一些函数未包含在Uses中列出的单元中(默认单元有Windows,Messages,SysUtils,Variants,Classes,Graphics, Controls,Forms,Dialogs;),所以需要我们手动添加单元。比如,MidStr函数就未包含在这些单元中,MidStr所属单元在StrUtils中,因此我们将StrUtils添加Uses中即可。

  在本手册中,凡是未包含在默认列出的单元中的函数,都标明了其所属的单元,使用时应当注意。

  一、数据类型转换函数

  在我们编写程序当中,根据不同情况,会使用到多种数据类型。当要对不同的类型进行操作时,必须要将不同的类型转换成同样的类型。因此熟练地掌握数据类型的转换是非常重要的。

  1.FloatToStr

  功能说明:该函数用于将“浮点型”转换成“字符型”。

  参考实例:

  Edit1.Text := FloatToStr(1.981);

  2.IntToStr

  功能说明:该函数用于将“整数型”转换成“字符型”。

  参考实例:

  S := IntToStr(10);(注:S为String类型变量。)

  3.IntToHex

  功能说明:该函数用于将“十进制”转换成“十进制”。该函数有二个参数。第一个参数为要转换的十进制数据,第二个参数是指定使用多少位来显示十六进制数据。

  参考实例:

  Edit1.Text := IntToHex('100', 2);

  执行结果,Edit1.Text等于64。

  注意:Delphi没有提供专门的“十六进制”转换为“十进制”的函数。使用StrToInt函数可以实现这个功能。具体代码是:I := StrToInt('S\' + '64'); 这时I等于100。加上一个'S\'即可将“十六进制”转换为“十进制”。

  4.StrToInt

  功能说明:该函数用于将“字符型”转换成“整数型”。

  参考实例:

  I := StrToInt('100');

  注意:不能转换如 StrToInt('ab')或StrToInt('好')这样的类型,因为他们并不存在数字型。

  5.StrToFloat

  功能说明:该函数用于将“字符型”转换成“浮点型”。

  参考实例:

  N := StrToFloat(Edit1.Text);

  注意:Edit1.Text中的内容为1.981(凡在Edit控件中显示的文本均为字符串)。N为Double类型,用于保存转换后的浮点型数据。

  二、字符串、数组操作函数

  对字符串及数组的操作,是每个程序员必须要掌握的。熟练的使用这些函数,在编程时能更加得心应手。

  1.Copy

  功能说明:该函数用于从字符串中复制指定范围中的字符。该函数有3个参数。第一个参数是数据源(即被复制的字符串),第二个参数是从字符串某一处开始复制,第三个参数是要复制字符串的长度(即个数)。最后函数返回一个新的字符串(即是我们指定要复制的字符串内容)。

  参考实例:

  var

    S: String;

    MyStr: String; // 保存新的字符串

  begin

    S := 'I Love China!';

  //下面将获取I Love China中的“Love”字符串。

  MyStr := Copy(S, 3, 4);

  end;

  执行结果,MyStr等于“Love”,“Love”字符串在“I Love China!”中第3个位置开始,所以第二个参数为3,“Love”一共有4个字符,所以第三个参数为4。

  2.Concat

  功能说明:连接两个或多个字符串为一个字符串。

  参考实例:

  var

    S1, S2: String;

  begin

    S1 := Concat('A', 'B'); // 连接两个字符串,S1变量等于AB。

    S2 := Concat('Borland', ' Delphi', ' 7.0'); // 连接三个字符,S2变量等于Borland Delphi 7.0。

  end;

  3.Delete

  功能说明:删除字符串中指定的字符串。该函数有三个参数。第一个参数为要进行处理的字符串,第二个参数为从何处开始删除,第三个参数为删除的字符个数。

  参考实例:

  var

    S: String;

  begin

    S := 'I Like Reading CPCW.';

    // 下面的代码将删除S变量中的“C”字符。

    Delete(S, 16, 1);

  end;

  此时S变量则是I Like Reading PCW.(“C”已经不存在了)。

  4.High

  功能说明:返回数组下标的最大值。

  参考实例:

  var

    arrText: array[0..9] of Char;

    i: Integer;

  begin

    i := High(arrText); // i的值则为9

  end;

  5.Insert

  功能说明:插入一个字符(串)。该函数有三个参数。第一个参数为要插入的字符(串),第二个参数为被插入字符串(源字符串),第三个参数为从何处插入。

  参考实例:

  var

    S: String;

  begin

    S := 'Wat is your name?';

    // 上面句子中的What单词查一个“h”字符,下面使用Insert函数将h添加进去。

    Insert('h', S, 2); // 将“h”从第2位处插入。

  end;

  6.LeftStr(所在单元:StrUtils)

  功能说明:返回字符串左边指定个数的新字符(串)。该函数有两个参数。第一个参数为完整的字符串,第二个参数为指定个数。

  参考实例:

  var

    S, A: String;

  begin

    S := 'MSN Messenger';

   A := LeftStr(S, 3); // 从最左边开始,获取左边的三个字符。因此A变量则等于MSN。

  end;

  7.Length

  功能说明:该函数用于统计指定字符串的长度(即个数)。

  参考实例:

  var

  nLen1, nLen2: Integer; // 用于保存字符串长度

  begin

    nLen1 := Length('CPCW');

  nLen2 := Length('电脑报');

  end;

  执行结果,nLen1等于4,nLen2等于6。由于一个汉字相当于两个字符的长度,所以3个汉字的长度为6。

  8.Low

  功能说明:返回数组下标的最小值。

  参考实例:

  var

    arrText: array[1..9] of Char;

    i: Integer;

  begin

    i:= High(arrText); // i的值则为1

  end;

  9.LowerCase

  功能说明:将字符(串)中的英文字符转换为小写。

  参考实例:

  var

    S, A: String;

  begin

    S := 'ABC';

    A := UpperCase(S); // 经过UpperCase函数转换后,A则等于abc。

  end;

  10.MidStr(所在单元:StrUtils)

  功能说明:返回指定范围内的字符串。该函数有三个参数。第一个参数为源字符串,第二个参数为起点,第三个参数为结束点。通过第二、第三个参数则可指定要复制字符串的范围。

  Copy函数与此函数类似。MidStr主要用于处理含有中文字符的字符串。

  参考实例:

  var

    S: String;

    H: String;

  begin

    S := MidStr('China', 1, 2); // S变量为Ch

    H := MidStr('电脑报', 1, 1); // H变量为“电”。如果使用Copy函数,则应是H := Copy('电脑报, 1, 2),否则返回的将不是“电”字。因此在使用操作含有中文的字符串时,最好使用MidStr。

  end;

  11.Pos

  功能说明:查找字符(串)所在位置。该函数有二个参数。第一个参数为要查找的字符(串),第二个参数为被查找字符(串)。

  参考实例:

  var

    nPos: Integer; // 用于保存查找的字符所在位置

  begin

    nPos := Pos('Like', 'I Like Reading!');

  end;

  此时nPos等于3。如果没有查找到,则nPos为0。

  注意:Pos函数在查找时是要区分字符大小的。如果要实现不区分大小,那么需要使用UpperCase或LowerCase函数将两个参数的字符(串)转换为“大写”或“小写”再进行查找。

  另外还有一个查找字符(串)的函数----AnsiPos,该函数的使用方法与Pos函数完全一样。当你查找的是汉字时,最好使用AnsiPos函数。

  12.RightStr(所在单元:StrUtils)

  功能说明:返回字符串右边指定个数的新字符(串)。该函数有两个参数。第一个参数为完整的字符串,第二个参数为指定个数。

  参考实例:

  var

    S, A: String;

  begin

    S := 'MSN Messenger';

    A := RightStr(S, 3); // 从最右边开始,获取右边的三个字符。因此A变量则等于ger。

  end;

  13.SetLength

  功能说明:设置字符串或动态数组长度。该函数有两个参数。第一个参数为要设置的字符串变量或动态数组变量,第二个参数为指定的长度,其取值范围在0到255之间。

  参考实例:

  var

    S: String;

    arrText: array of Char; // 定义一个动态数组

  begin

    SetLength(S, 10); // 当设置后,S变量只能赋值长度为10的字符串。

    SetLength(arrText, 10); // 只有使用SetLength为动态数组分配内存空间后才能使用动态数组。这句代码的作用相当于arrText: array[0..9] of Char

  end;

  14.StrPCopy

  功能说明:将字符串复制到字符数组中。该函数有两个参数。第一个参数为“目标数组”,第二个参数为“字符串”。

  参考实例:

  var

    arrChar: array[0..255] of Char; // 这里声明了长度为256的Char型数组

  begin

    StrPCopy(arrChar, 'Come on, baby!');

  end;

  15.Trim

  功能说明:删除字符串左右两边的空格(无论左右两边有多少个空格均被全部删除)。

  参考实例:

  var

    S: String;

  begin

    S := ' Delphi 7.0 ';

    S := Trim(S);

  end;

  16.TrimLeft

  功能说明:删除字符串左边的空格(无论左边有多少个空格均被全部删除)。

  参考实例:

    S := TrimLeft(' Delphi');

  17.TrimRight

  功能说明:删除字符串左边的空格(无论左边有多少个空格均被全部删除)。

  参考实例:

    S := TrimRight('Delphi ');

  18.UpperCase

  功能说明:将字符(串)中的英文字符转换为大写。

  参考实例:

  var

    S, A: String;

  begin

    S := 'abc';

    A := UpperCase(S); // 经过UpperCase函数转换后,A则等于ABC。

  end;

  三、文件、磁盘操作函数

  软件大多都要对文件、磁盘进行操作。熟悉掌握这些函数可以帮助你轻松实现创建、删除、保存文件等功能。

  1.Append

  功能说明:追加内容到文件中。文件必须要存在。

  参考实例:

  var

    S: String;

    F: TextFile;

  begin

    S := 'This is a book.';

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Append(F); // 以追加的方式打开文件

    Writeln(F, S); // 将S变量中的内容追加到文本尾后。

    CloseFile(F); // 关闭文件

  end;

  2.AssignFile

  功能说明:与指定的文件建立连接。

  参考实例:

  var

    F: TextFile; // 声明文本文件类型变量

  begin

    AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

  end;

  3.ChDir

  功能说明:改变当前目录(文件夹)。

  参考实例:

  var

    sDir: String;

  begin

    sDir := 'C:\Windows';

    ChDir(sDir); // 此时,系统的当前目录则为C:\Windows目录。

  end;

  4.CloseFile

  功能说明:关闭文件。当对文件的操作完成后,应该使用CloseFile函数关闭打开的文件。

  参考实例:

  var

    S: String;

    AllText: String;

    F: TextFile;

  begin

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Reset(F); // 打开文件

    while not EOF(F) do begin // 使用While循环,一直判断是否到了文件未尾

     Readln(F, S); // 读取一行文本

     AllText := AllText + S;

    end;

    CloseFile(F); // 关闭文件

  end;

  5.DeleteFile

  功能说明:删除指定的文件。该函数只有一个参数。此参数为欲删除文件的完整路径。如果删除成功,则返回True。若删除失败、或文件不存在则返回False。

  参考实例:

  var

    IsOK: Boolean; // 用于保存删除状态

  begin

    IsOK := DeleteFile('C:\My Documents\Index.html'); // 函数执着后,将结果返回给IsOK变量。如果IsOK变量为True,则表示文件删除成功。

    if IsOK then ShowMessage('文件删除成功!')

    else ShowMessage('文件删除失败!');

  end;

  6.DirectoryExists

  功能说明:检测指定的文件夹否存在。如果存在则返回True,反之则为False。

  参考实例:

  var

    IsExists: Boolean;

  begin

    IsExists := DirectoryExists ('C:\Windows');

    if IsExists then ShowMessage('Windows文件夹存在!')

    else ShowMessage('Windows文件夹不存在!');

  end;

  7.DiskFree

  功能说明:获取指定磁盘的剩余空间。该函数只有一个参数。该参数用于指定要获取剩余空间的磁盘号。当参数为0时,表示获取当前磁盘的剩余空间,1为A盘,2为B盘,以此类推。如果返回值为-1,表示指定的磁盘无效。

  参考实例:

  var

    FreeSize: Int64;

  begin

    FreeSize := DiskFree(3); // 获取C盘中的剩余空间。返回的值是以“字节”为单位的。

  end;

  8.DiskSize

  功能说明:获取指定磁盘的空间。该函数只有一个参数。该参数用于指定要获取磁盘空间的磁盘号。当参数为0时,表示获取当前磁盘的空间,1为A盘,2为B盘,以此类推。如果返回值为-1,表示指定的磁盘无效。

  参考实例:

  var

    DiskSize: Int64;

  begin

    DiskSize:= DiskSize(3); // 获取C盘的空间。返回的值是以“字节”为单位的。

  end;

  9.EOF

  功能说明:判断文件指针是否移动到了文件未尾。当EOF函数返回值为True时,则不可以使用Readln函数进行读取文件了。

  参考实例:

  var

    S: String;

    AllText: String;

    F: TextFile;

  begin

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Reset(F); // 打开文件

    while not EOF(F) do begin // 使用While循环,一直判断是否到了文件未尾

     Readln(F, S); // 读取一行文本

     AllText := AllText + S;

    end;

  end;

  10.Erase

  功能说明:删除文件。

  参考实例:

  var

    F: File;

  begin

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Reset(F); // 打开文件

    CloseFile(F); // 关闭文件

    Erase(F); // 删除文件。在删除文件之前必须先关闭文件。

  end;

  11.FileExists

  功能说明:检测指定的文件否存在。如果存在则返回True,反之则为False。

  参考实例:

  var

    IsExists: Boolean;

  begin

    IsExists := FileExists('C:\Test.txt');

    if IsExists then ShowMessage('该文件存在!')

    else ShowMessage('该文件不存在!');

  end;

  12.FileSize

  功能说明:获取文件大小。返回的结果是字节为单位。

  参考实例:

  var

    F: file of Byte;

    nSize: Longint;

  begin

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Reset(F); // 打开文件

    nSize := FileSize(F); // 获取文件大小。

    CloseFile(F); // 关闭文件

  end;

  13.ForceDirectories

  功能说明:创建新的子目录。路径中不存在的目录将一同创建。

  参考实例:

  ForceDirectories('C:\Flash\MyFolder'); // 如果Flash文件夹本身不存的话,那么将会先创建Flash文件夹,然后再创建MyFolder文件夹。

  14.MkDir

  功能说明:创建一个新的子目录(文件夹)。

  参考实例:

  MkDir('C:\MyFolder'); // 在C盘根目录中创建了一个名叫MyFolder的文件夹。

  需要注意的是,如果在本身不存在的目录中创建子目录将会失败。比如C盘根本不存在Flash文件夹,写成MkDir('C:\Flash\MyFolder');这样将不能成功创建MyFolder文件夹。

  15.Reset

  功能说明:以只读方式打开文件。

  参考实例:

  var

    F: TextFile; // 声明文本文件类型变量

  begin

    AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Reset(F); // 打开文件

  end;

  16.Rewrite

  功能说明:以可写方式打开文件。如果文件不存在,将会自动创建。使用该函数,将会覆盖文件中的所有内容。

  参考实例:

  var

    F: TextFile; // 声明文本文件类型变量

  begin

    AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Rewrite(F); // 打开文件。如果文件不存在,将会在C盘中创建MyFile.txt文件。如果文件存在,将会覆盖MyFile.txt中的所有内容。

  end;

  17.Readln

  功能说明:读取一行文本。

  参考实例:

  var

    S: String;

    F: TextFile;

  begin

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Reset(F); // 打开文件

    Readln(F, S); // 读取一行文本到S变量中

  end;

  18.Rename

  功能说明:更改文件名。

  参考实例:

  var

    F: File;

  begin

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    ReName(F, 'C:\NewFile.txt'); // 更名为NewFile.txt

  end;

  19.Writeln

  功能说明:写入一行文本。

  参考实例:

  var

    S: String;

    F: TextFile;

  begin

    S := 'This is a book.';

  AssignFile(F, 'C:\MyFile.txt'); // 将C:\MyFile.txt文件与F变量建立连接,后面可以使用F变量对文件进行操作。

    Rewrite(F); // 创建新文件

    Writeln(F, S); // 将S变量中的内容写入文本中。

  end;

  四、内存、指针操作函数

  在编程中,动态数组为我们处理数据带来了很大的方便。Windows API函数也为增强程序的功能提供了强有力的保障。当我们在使用这些动态数组及API函数时,常常需要动态分配内存空间,这样动态数组才能被我们使用,API函数才能正确的返回结果。因此,这些函数是必不可少的。

  1.AllocMem

  功能说明:分配内存空间并自动初始化为零。如果不需要初始化为零,可以使用GetMem代替AllocMem。

  参考实例:

  var

    Buffer: PChar;

  begin

    Buffer := AllocMem(256); // 分配大小为256个字节的内存空间

  end;

  2.Dispose

  功能说明:释放为指针分配的内存空间。

  参考实例:

  var

    P: Pinteger; // 声明一个Integer(整型)指针

  begin

    New(P);

    P^ := 100;

    Dispose(P) // 释放内存

  end;

  3.FreeMem

  功能说明:释放分配的内存空间。

  参考实例:

  var

    Buffer: Pchar;

  begin

    GetMem(Buffer, 256); // 分配大小为256个字节的内存空间。

    FreeMem(Buffer); // 释放内存空间

  end;

  4.GetMem

  功能说明:分配内存空间。

  参考实例:

  var

    Buffer: PChar;

  begin

    GetMem(Buffer, 256); // 分配大小为256个字节的内存空间。

  end;

  5.New

  功能说明:为指针分配内存空间。

  参考实例:

  var

    P: PInteger; // 声明一个Integer(整型)指针

  begin

    New(P); // 分配内存

    P^ := 100; // 赋值

  end;

  五、数学运算函数

  我们在编写跟数学紧密相关的程序时,数学运算函数将大有用处。比如图像处理软件,就会大量用到这些数学运算函数。

  默认情况下,Delphi新建的工程里,没有包含大多数的数学运行函数,因此需要在Uses中加入Math单元。

  1.Abs

  功能说明:求绝对值。

  参考实例:

  var

    r: Single;

    i: Integer;

  begin

    r := Abs(-2.8); // r等于 2.8

    i := Abs(-156); // I 等于 156

  end;

  2.Exp

  功能说明:Exp返回e的X次幂的值,其中e是一个自然对数基底。

  参考实例:

    e := Exp(1.0); // e为real型变量

  end;

  3.Floor

  功能说明:取得小于等于X的最大的整数。

  参考实例:

  Floor(-2.8) = -3

  Floor(2.8) = 2

  Floor(-1.0) = -1

  4.Int

  功能说明:返回参数中的整数部分。

  参考实例:

  var

    R: Real;

  begin

    R := Int(123.456); // R等于 123.0

    R := Int(-123.456); // R等于 -123.0

  end;

  5.Max(所在单元:Math)

  功能说明:比较两个数字,并返回最大的一个数字。

  参考实例:

  var

    k: Integer;

  begin

    k := Max(10, 20); // k将为20

  end;

  6.Min(所在单元:Math)

  功能说明:比较两个数字,并返回最小的一个数字。

  参考实例:

  var

    k: Integer;

  begin

    k := Min(10, 20); // k将为10

  end;

  7.PI

  功能说明:精确计算返回圆周率。

  参考实例:

  var

    x Extended;

  begin

    x := PI; // x等于3.1415926535897932385

  end;

  8.Round

  功能说明:对一个实数进行四舍五入。

  参考实例:

  var

    I, j: Integer;

  begin

    i := Round(1.25); // i等于1

    j := Round(1.62); // j等于2

  end;

  9.Sqr

  功能说明:取给定值的平方。

  参考实例:

  var

   i: Integer;

  begin

   i := Sqr(3); // i等于9

  end;

  六、日期函数

  对日期的处理,一般在有日期限制的共享、商业软件中经常使用到。如果你打算编写一款有日期限制的软件,熟悉使用下面的函数即可以实现。

  1.Date

  功能说明:返回当前的日期。

  参考实例:

  procedure TForm1.Button1Click(Sender: TObject);

  begin

    Label1.Caption := '今天是:' + DateToStr(Date);

  end;

  Label显示为:今天是2005年1月1日。

  2.DateToStr

  功能说明:将日期型转换为字符型。

  参考实例:

  var

    S: String;

  begin

    S := DateToStr(Date);

  end;

  3.DateTimeToStr

  功能说明:将DateTime型转换为字符型。

  参考实例:

  var

    S: String;

  begin

    S := DateTimeToStr(Now);

  end;

  4.DayOfTheMonth(所在单元:DateUtils)

  功能说明:获取指定日期的日。

  参考实例:

  Label1.Caption := IntToStr(DayOfTheMonth(Now));

  假设当前日期为2005年1月2日,那么Label将显示为2。

  5.DayOfTheWeek(所在单元:DateUtils)

  功能说明:根据指定日期,获取星期几。

  参考实例:

  Label1.Caption := IntToStr(DayOfTheMonth(Now));

  假设当前日期为2005年1月2日,那么Label将显示为7。根据返回的值来判断是周几。7表示星期天,1为星期一,依类类推。

  6.DayOfTheYear(所在单元:DateUtils)

  功能说明:根据指定日期,获取天数。

  参考实例:

  Label1.Caption := IntToStr(DayOfTheYear(Now));

  假设当前日期为2005年1月2日,那么Label将显示为2。表示是2005年的第2天。

  7.DayOf(所在单元:DateUtils)

  功能说明:根据指定的日期,返回日。

  参考实例:

  Label1.Caption := IntToStr(DayOf(Date));

  假设当前日期为2005年1月2日,那么Label将显示为2。

  8.IsLeapYear

  功能说明:根据指定的年,判断是否为闰年。可使用YearOf函数获取年。

  参考实例:

  procedure TForm1.Button1Click(Sender: TObject);

  begin

    if IsLeapYear(YearOf(Date)) then ShowMessage('是闰年')

    else ShowMessage('不是闰年');

  end;

  9.MonthOf(所在单元:DateUtils)

  功能说明:根据指定的日期,返回月份。

  参考实例:

  Label1.Caption := IntToStr(MonthOf(Date));

  假设当前日期为2005年1月2日,那么Label将显示为1。

  10.Now

  功能说明:返回当前日期及时间。

  参考实例:

  procedure TForm1.Button1Click(Sender: TObject);

  begin

    Label1.Caption := '现在是:' + DateTimeToStr(Now);

  end;

  11.YearOf(所在单元:DateUtils)

  功能说明:根据指定的日期,返回年。

  参考实例:

  Label1.Caption := IntToStr(YearOf(Date));

  假设当前日期为2005年1月2日,那么Label将显示为2005。

posted @ 2008-05-10 10:01 xyicheng 阅读(49) | 评论 (0) | 编辑
Delphi调用外部程序详解(转)
Delphi调用外部程序详解

WinExec主要运行EXE文件。如:WinExec(’Notepad.exe Readme.txt’, SW_SHOW); 
ShellExecute不仅可以运行EXE文件,也可以运行已经关联的文件。
首先必须引用shellapi.pas单元:uses ShellAPI; 

1.标准用法 
  ShellExecute函数原型及参数含义如下: 
  function ShellExecute(hWnd: HWND; Operation, FileName, Parameters,Directory: PChar; ShowCmd: Integer): HINST; stdcall; 
  ●hWnd:用于指定父窗口句柄。当函数调用过程出现错误时,它将作为Windows消息窗口的父窗口。例如,可以将其设置为应用程序主窗口句柄,即Application.Handle,也可以将其设置为桌面窗口句柄(用GetDesktopWindow函数获得)。 
  ●Operation:用于指定要进行的操作。其中“open”操作表示执行由FileName参数指定的程序,或打开由FileName参数指定的文件或文件夹;“print”操作表示打印由FileName参数指定的文件;“explore”操作表示浏览由FileName参数指定的文件夹。当参数设为nil时,表示执行默认操作“open”。 
  ●FileName:用于指定要打开的文件名、要执行的程序文件名或要浏览的文件夹名。 
  ●Parameters:若FileName参数是一个可执行程序,则此参数指定命令行参数,否则此参数应为nil或PChar(0)。 
  ●Directory:用于指定默认目录。 
  ●ShowCmd:若FileName参数是一个可执行程序,则此参数指定程序窗口的初始显示方式,否则此参数应设置为0。 
  若ShellExecute函数调用成功,则返回值为被执行程序的实例句柄。若返回值小于32,则表示出现错误。 
  上述仅仅是ShellExecute函数的标准用法,下面将介绍它的特殊用法。 

2.特殊用法 
  如果将FileName参数设置为“http:”协议格式,那么该函数将打开默认浏览器并链接到指定的URL地址。若用户机器中安装了多个浏览器,则该函数将根据Windows 9x/NT注册表中http协议处理程序(Protocols Handler)的设置确定启动哪个浏览器。 
  格式一:http://网站域名。 
  如:ShellExecute(handle, ‘open’, http:// ;  http://www.neu.edu.cn’/, nil, nil, SW_SHOWNORMAL); 
  格式二:http://网站域名/网页文件名。 
  如:ShellExecute(handle, ‘open’, http:// ;  www.neu.edu.cn/default.htm’,nil,nil,  SW_SHOWNORMAL); 
  如果将FileName参数设置为“mailto:”协议格式,那么该函数将启动默认邮件客户程序,如Microsoft Outlook(也包括Microsoft Outlook Express)或Netscape Messanger。若用户机器中安装了多个邮件客户程序,则该函数将根据Windows 9x/NT注册表中mailto协议处理程序的设置确定启动哪个邮件客户程序。 
  格式一:mailto: 
  如:ShellExecute(handle,‘open’, ‘mailto:’, nil, nil, SW_SHOWNORMAL);打开新邮件窗口。 
  格式二:mailto:用户账号@邮件服务器地址 
  如:ShellExecute(handle, ‘open’,‘ mailto:who@mail.neu.edu.cn’, nil, nil, SW_SHOWNORMAL);打开新邮件窗口,并自动填入收件人地址。若指定多个收件人地址,则收件人地址之间必须用分号或逗号分隔开(下同)。 
  格式三:mailto:用户账号@邮件服务器地址?subject=邮件主题&body=邮件正文 
  如:ShellExecute(handle, ‘open’, ‘ mailto:who@mail.neu.edu.cn?subject=Hello&Body=This is a test’, nil, nil, SW_SHOWNORMAL);打开新邮件窗口,并自动填入收件人地址、邮件主题和邮件正文。若邮件正文包括多行文本,则必须在每行文本之间加入换行转义字符%0a。 
例子(delphi): 
在一个应用程序调用c:Project1.exe; 
ShellExecute(handle, ’open’,’c:Project1.exe’,’字串内容’,nil, SW_SHOWNORMAL); 
在Project1.exe里可以调用: 
procedure TForm1.FormCreate(Sender: TObject); 
var i:integer; 
begin 
for i:=1 to paramcount do 
if ParamStr(i)〈〉’’ then showmessage(ParamStr(i)); 
end;

最后的那个参数,为窗口指定可视性方面的一个命令。 
请用下述任何一个常数 
SW_HIDE 隐藏窗口,活动状态给令一个窗口 
SW_MINIMIZE 最小化窗口,活动状态给令一个窗口 
SW_RESTORE 用原来的大小和位置显示一个窗口,同时令其进入活动状态 
SW_SHOW 用当前的大小和位置显示一个窗口,同时令其进入活动状态 
SW_SHOWMAXIMIZED 最大化窗口,并将其激活 
SW_SHOWMINIMIZED 最小化窗口,并将其激活 
SW_SHOWMINNOACTIVE 最小化一个窗口,同时不改变活动窗口 
SW_SHOWNA 用当前的大小和位置显示一个窗口,不改变活动窗口 
SW_SHOWNOACTIVATE 用最近的大小和位置显示一个窗口,同时不改变活动窗口 
SW_SHOWNORMAL 与SW_RESTORE相同 

posted @ 2008-05-06 08:45 xyicheng 阅读(282) | 评论 (2) | 编辑
使用Transact-SQL进行数据导入导出方法详解[转]
本文讨论了如何通过Transact-SQL以及系统函数OPENDATASOURCE和OPENROWSET在同构和异构数据库之间进行数据的导入导出,并给出了详细的例子以供参考。 
 
1. 在SQL Server数据库之间进行数据导入导出 
 
(1).使用SELECT INTO导出数据   
在SQL Server中使用最广泛的就是通过SELECT INTO语句导出数据,SELECT INTO语句同时具备两个功能:
根据SELECT后跟的字段以及INTO后面跟的表名建立空表(如果SELECT后是*, 空表的结构和FROM所指的表的结构相同);
将SELECT查出的数据插入到这个空表中。在使用SELECT INTO语句时,INTO后跟的表必须在数据库不存在,否则出错,下面是一个使用SELECT INTO的例子。  
假设有一个表table1,字段为f1(int)、f2(varchar(50))。 SELECT * INTO table2 FROM table1   这条SQL语的在建立table2表后,将table1的数据全部插入到table1中的,还可以将*改为f1或f2以便向适当的字段中插入数据。 
 SELECT INTO不仅可以在同一个数据中建立表,也可以在不同的SQL Server数据库中建立表。
  
USE db1 SELECT * INTO db2.dbo.table2 FROM table1

以上语句在数据库db2中建立了一个所有者是dbo的表table2,在向db2建表时当前登录的用户必须有在db2建表的权限才能建立table2。 使用SELECT INTO要注意的一点是SELECT INTO不可以和COMPUTE一起使用,因为COMPUTE返回的是一组记录集,这将会引起二意性(即不知道根据哪个表建立空表)。  


(2).使用INSERT INTO 和 UPDATE插入和更新数据  SELECT INTO只能将数据复制到一个空表中,而INSERT INTO可以将一个表或视图中的数据插入到另外一个表中。
INSERT INTO table1 SELECT * FROM table2 或 INSERT INTO db2.dbo.table1 SELECT * FROM table2

  但以上的INSERT INTO语句可能会产生一个主键冲突错误(如果table1中的某个字段是主键,恰巧table2中的这个字段有的值和table1的这个字段的值相同)。因此,上面的语句可以修改为 INSERT INTO table1 -- 假设字段f1为主键 SELECT * FROM table2 WHERE NOT EXISTS(SELECT table1.f1 FROM table1 WHERE table1.f1=table2.f1 )   以上语句的功能是将table2中f1在table1中不存在的记录插入到table1中。 

 要想更新table1可以使用UPDATE语句 UPDATE table1 SET table1.f1=table2.f1, table1.f2=table2.f2 FROM table2 WHERE table1.f1=table2.f1   将以上两条INSERT INTO和UPDATE语句组合起来在一起运行,就可以实现记录在table1中不存在时插入,存在时更新的功能,但要注意要将UPDATE放在INSERT INTO前面,否则UPDATE更新的记录数将是table1和table2记录数的总和。
 
2. 使用OPENDATASOURCE和OPENROWSET在不同类型的数据库之间导入导出数据  

在异构的数据库之间进行数据传输,可以使用SQL Server提供的两个系统函数OPENDATASOURCE和OPENROWSET。  
OPENDATASOURCE可以打开任何支持OLE DB的数据库,并且可以将OPENDATASOURCE做为SELECT、UPDATE、INSERT和DELETE后所跟的表名。
如
SELECT * FROM OPENDATASOURCE('SQLOLEDB', 'Data Source=192.168.18.252;User ID=sa;Password=test').pubs.dbo.authors

这条语句的功能是查询192.168.18.252这台机器中SQL Server数据库pubs中的authors表。
从这条语句可以看出,OPENDATASOURCE有两个参数,第一个参数是provider_name,表示用于访问数据源的 OLE DB 提供程序的 PROGID 的名称。provider_name 的数据类型为 char,没有默认值。第二个参数是连接字符串,根据OLE DB Provider不同而不同(如果不清楚自己所使用的OLE DB Provider的连接字符串,可以使用delphi、visual studio等开发工具中的ADO控件自动生成相应的连接字符串)。  

OPENROWSET函数和OPENDATASOURCE函数类似,只是它可以在打开数据库的同时对数据库中的表进行查询,如以下语句
OPENROWSET('MSDASQL.1', 'Driver=Microsoft Visual FoxPro Driver; SourceDB=c:\db; SourceType=DBF', 'SELECT * FROM [b.dbf]')
最后一个参数查询foxpro表b.dbf,读者可以通过where条件对b.dbf进行过滤。
如果将INSERT INTO、SELECT INTO和OPENDATASOURCE或OPENROWSET一起使用,就可以使SQL Server数据库和其它类型的数据库之间进行数据导入导出。
下面介绍如何使用这两个函数在SQL Server数据库和其它类型的数据库之间进行数据导入导出。 


 (1).SQL Server数据库和SQL Server数据库之间的数据导入导出。
  
导入数据
SELECT * INTO authors1 FROM OPENDATASOURCE( 'SQLOLEDB', 'Data Source=192.168.18.252;User ID=sa;Password=abc' ).pubs.dbo.authors   

导出数据
INSERT INTO OPENDATASOURCE( 'SQLOLEDB', 'Data Source=192.168.18.252;User ID=sa;Password=abc' ).test.dbo.authors select * from pubs.dbo.authors   


在这条语句中OPENDATASOURCE(...)可以理解为SQL Server的一个服务,.pubs.dbo.authors是这个服务管理的一个数据库的一个表authors。使用INSERT INTO时OPENDATASOURCE(...)后跟的表必须存在。  也可以将以上的OPENDATASOURCE换成
OPENROWSET INSERT INTO OPENROWSET('SQLOLEDB','192.168.18.252';'sa';'abc', 'select * from test.dbo.kk') SELECT * FROM pubs.dbo.authors
 使用OPENROWSET要注意一点,'192.168.18.252';'sa';'abc'中间是";",而不是","。OPENDATASOURCE和OPENROWSET都不接受参数变量。  

(2). SQL Server数据库和Access数据库之间的数据导入导出。
  导入数据
 
SELECT * INTO access FROM OPENDATASOURCE( 'Microsoft.Jet.OLEDB.4.0', 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\data.mdb;Persist Security Info=False')table1
 或者使用
OPENROWSET SELECT * FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0', 'c:\data.mdb';'admin';'','SELECT * FROM table1') 

  导出数据
INSERT INTO OPENDATASOURCE( 'Microsoft.Jet.OLEDB.4.0', 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\data.mdb;Persist Security Info=False')table1 SELECT * FROM access
 
  打开access数据库的OLE DB Provider叫Microsoft.Jet.OLEDB.4.0,需要注意的是操作非SQL Server数据库在OPENDATASOURCE(...)后面引用数据库中的表时使用"...”,而不是“.”。  


 (3). SQL Server数据库和文本文件之间的数据导入导出。  
       导入数据
SELECT * INTO text1 FROM OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')[data#txt] 
  导出数据
INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\')[data#txt] SELECT * FROM text1 

 或者使用
OPENROWSET INSERT INTO OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\', [data#txt]) SELECT * FROM text1 

 如果要插入部分字段,可使用
 
INSERT INTO OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Text;DATABASE=c:\', 'SELECT aa FROM [data#txt]') SELECT aa FROM text1 
  这条SQL语句的功能是将c盘根目录的data.txt文件导入到text1表中,在这里文件名中的“.”要使用“#”代替。在向文本导出时,不仅文本文件要存在,而且第一行必须和要导出表的字段一至。
 

(4). SQL Server数据库和dbase数据库之间的数据导入导出。  
导入数据
SELECT * INTO dbase FROM OPENROWSET('MICROSOFT.JET.OLEDB.4.0' , 'dBase III;HDR=NO;IMEX=2;DATABASE=C:\','SELECT * FROM [b.dbf]')   
导出数据
INSERT INTO OPENROWSET('MICROSOFT.JET.OLEDB.4.0' , 'dBase III;HDR=NO;IMEX=2;DATABASE=C:\','SELECT * FROM [b.dbf]') SELECT * FROM dbase   OPENROWSET(...)中的b.dbf使用[...]括起来,是为了当dbf文件名有空格等字符时不会出错,如果没有这些特殊字符,可以将[...]去掉  

(5). SQL Server数据库和foxpro数据库之间的数据导入导出。  
导入数据
SELECT * INTO foxpro FROM OPENROWSET('MSDASQL.1', 'Driver=Microsoft Visual FoxPro Driver; SourceDB=c:\; SourceType=DBF', 'SELECT * FROM [a.dbf]')   导出数据
INSERT INTO OPENROWSET('MSDASQL.1' , 'Driver=Microsoft Visual FoxPro Driver; SourceDB=c:\db; SourceType=DBF','SELECT * FROM a.dbf') SELECT * FROM foxpro   
在此处a.dbf不能使用[...]括起来,否则出错(这是由driver决定的)。

  (6). SQL Server数据库和excel文件之间的数据导入导出 
 导入数据
 SELECT * INTO excel FROM OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0', 'Excel 5.0;DATABASE=c:\book1.xls' )[Sheet1$]
 导出数据
INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0', 'Excel 5.0;DATABASE=c:\book1.xls' )[Sheet1$] SELECT * FROM excel

在book1.xls的Sheet1中必须有和excel表相对应的字段,否则会出错。  

以上讨论了几种常用的数据库和SQL Server数据库之间如何使用Transact-SQL进行数据导入导出。在SQL Server中还提供了将其它类型的数据库注册到SQL Server中的功能,这样就可以和使用SQL Server数据库表一样使用这些被注册数据库中的表了。
EXEC sp_addlinkedserver 'access', 'OLE DB Provider for Jet', 'Microsoft.Jet.OLEDB.4.0', 'c:\data.mdb'   
以上SQL使用存储过程sp_addlinkedserver注册了一个access数据库,我们可以在SQL Server中使用如下语句查询在data.mdb中的table1。
SELECT * FROM access...table1   
这样就可很方便地查询access数据库中的表了,如果要导入table1,可以使用
SELECT * INTO table2 FROM access...table1。
如果想删除注册的数据库连接,使用如下语句。
EXEC sp_dropserver 'access'   
使用Transact-SQL不仅可以向SQL Server数据库导入导出数据,而且还可以使任意两种类型数据库之间互相导入导出数据。以access和excel为例进行说明。

INSERT INTO OPENDATASOURCE('MICROSOFT.JET.OLEDB.4.0', 'Excel 5.0;DATABASE=c:\book1.xls' )[Sheet1$] SELECT * FROM OPENROWSET('Microsoft.Jet.OLEDB.4.0', 'c:\data.mdb';'admin';'','SELECT * FROM table1') 

 以上SQL语句将access数据库的table1表的数据插入到excel文件book1.xls中的Sheet1表单中。  
使用Transact-SQL进行数据的导入导出,可以很方便地将这些Transact-SQL语句放到客户端程序中(如delphi、c#等),从而可以很容易地编写自已的数据库导入导出工具。
posted @ 2008-04-13 10:38 xyicheng| 编辑
Delphi Excel and SqlServer
从Excel文件中,导入数据到SQL数据库中,很简单,直接用下面的语句:  
   
  /*===================================================================*/  
  --如果接受数据导入的表已经存在  
  insert   into   表   select   *   from    
  OPENROWSET('MICROSOFT.JET.OLEDB.4.0'  
  ,'Excel   5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$)  
   
  --如果导入数据并生成表  
  select   *   into   表   from    
  OPENROWSET('MICROSOFT.JET.OLEDB.4.0'  
  ,'Excel   5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$)  
   
   
  /*===================================================================*/  
  --如果从SQL数据库中,导出数据到Excel,如果Excel文件已经存在,而且已经按照要接收的数据创建好表头,就可以简单的用:  
  insert   into   OPENROWSET('MICROSOFT.JET.OLEDB.4.0'  
  ,'Excel   5.0;HDR=YES;DATABASE=c:\test.xls',sheet1$)  
  select   *   from   表  
   
   
  --如果Excel文件不存在,也可以用BCP来导成类Excel的文件,注意大小写:  
  --导出表的情况  
  EXEC   master..xp_cmdshell   'bcp   数据库名.dbo.表名   out   "c:\test.xls"   /c   -/S"服务器名"   /U"用户名"   -P"密码"'  
   
  --导出查询的情况  
  EXEC   master..xp_cmdshell   'bcp   "SELECT   au_fname,   au_lname   FROM   pubs..authors   ORDER   BY   au_lname"   queryout   "c:\test.xls"   /c   -/S"服务器名"   /U"用户名"   -P"密码"'  
   
  说明.  
   
  c:\test.xls     为导入/导出的Excel文件名.  
  sheet1$             为Excel文件的工作表名,一般要加上$才能正常使用.  
   
     
   
  下面是导出真正Excel文件的方法:  
   
   
  /*--数据导出EXCEL  
     
    导出表中的数据到Excel,包含字段名,文件为真正的Excel文件  
    ,如果文件不存在,将自动创建文件  
    ,如果表不存在,将自动创建表  
    基于通用性考虑,仅支持导出标准数据类型  
  ---*/  
   
  /*--调用示例  
   
    p_exporttb   @tbname='地区资料',@path='c:\',@fname='aa.xls'  
  --*/  
  if   exists   (select   *   from   dbo.sysobjects   where   id   =   object_id(N'[dbo].[p_exporttb]')   and   OBJECTPROPERTY(id,   N'IsProcedure')   =   1)  
  drop   procedure   [dbo].[p_exporttb]  
  GO  
   
  create   proc   p_exporttb  
  @tbname   sysname,         --要导出的表名,注意只能是表名/视图名  
  @path   nvarchar(1000),       --文件存放目录  
  @fname   nvarchar(250)=''     --文件名,默认为表名  
  as  
  declare   @err   int,@src   nvarchar(255),@desc   nvarchar(255),@out   int  
  declare   @obj   int,@constr   nvarchar(1000),@sql   varchar(8000),@fdlist   varchar(8000)  
   
  --参数检测  
  if   isnull(@fname,'')=''   set   @fname=@tbname+'.xls'  
   
  --检查文件是否已经存在  
  if   right(@path,1)<>'\'   set   @path=@path+'\'  
  create   table   #tb(a   bit,b   bit,c   bit)  
  set   @sql=@path+@fname  
  insert   into   #tb   exec   master..xp_fileexist   @sql  
   
  --数据库创建语句  
  set   @sql=@path+@fname  
  if   exists(select   1   from   #tb   where   a=1)  
    set   @constr='DRIVER={Microsoft   Excel   Driver   (*.xls)};DSN='''';READONLY=FALSE'  
                +';CREATE_DB="'+@sql+'";DBQ='+@sql  
  else  
    set   @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended   Properties="Excel   5.0;HDR=YES'  
          +';DATABASE='+@sql+'"'  
   
  --连接数据库  
  exec   @err=sp_oacreate   'adodb.connection',@obj   out  
  if   @err<>0   goto   lberr  
   
  exec   @err=sp_oamethod   @obj,'open',null,@constr  
  if   @err<>0   goto   lberr  
   
  --创建表的SQL  
  select   @sql='',@fdlist=''  
  select   @fdlist=@fdlist+','+a.name  
    ,@sql=@sql+',['+a.name+']   '  
      +case   when   b.name   in('char','nchar','varchar','nvarchar')   then  
            'text('+cast(case   when   a.length>255   then   255   else   a.length   end   as   varchar)+')'  
        when   b.name   in('tynyint','int','bigint','tinyint')   then   'int'  
        when   b.name   in('smalldatetime','datetime')   then   'datetime'  
        when   b.name   in('money','smallmoney')   then   'money'  
        else   b.name   end  
  FROM   syscolumns   a   left   join   systypes   b   on   a.xtype=b.xusertype  
  where   b.name   not   in('image','text','uniqueidentifier','sql_variant','ntext','varbinary','binary','timestamp')  
    and   object_id(@tbname)=id  
  select   @sql='create   table   ['+@tbname  
    +']('+substring(@sql,2,8000)+')'  
    ,@fdlist=substring(@fdlist,2,8000)  
   
  exec   @err=sp_oamethod   @obj,'execute',@out   out,@sql  
  if   @err<>0   goto   lberr  
   
  exec   @err=sp_oadestroy   @obj  
   
  --导入数据  
  set   @sql='openrowset(''MICROSOFT.JET.OLEDB.4.0'',''Excel   5.0;HDR=YES  
        ;DATABASE='+@path+@fname+''',['+@tbname+'$])'  
   
  exec('insert   into   '+@sql+'('+@fdlist+')   select   '+@fdlist+'   from   '+@tbname)  
   
  return  
   
  lberr:  
    exec   sp_oageterrorinfo   0,@src   out,@desc   out  
  lbexit:  
    select   cast(@err   as   varbinary(4))   as   错误号  
      ,@src   as   错误源,@desc   as   错误描述  
    select   @sql,@constr,@fdlist  
  go  
   
     
   
  *--数据导出EXCEL  
     
    导出查询中的数据到Excel,包含字段名,文件为真正的Excel文件  
    ,如果文件不存在,将自动创建文件  
    ,如果表不存在,将自动创建表  
    基于通用性考虑,仅支持导出标准数据类型  
  --*/  
   
  /*--调用示例  
   
    p_exporttb   @sqlstr='select   *   from   地区资料'  
      ,@path='c:\',@fname='aa.xls',@sheetname='地区资料'  
  --*/  
  if   exists   (select   *   from   dbo.sysobjects   where   id   =   object_id(N'[dbo].[p_exporttb]')   and   OBJECTPROPERTY(id,   N'IsProcedure')   =   1)  
  drop   procedure   [dbo].[p_exporttb]  
  GO  
   
  create   proc   p_exporttb  
  @sqlstr   sysname,         --查询语句,如果查询语句中使用了order   by   ,请加上top   100   percent,注意,如果导出表/视图,用上面的存储过程  
  @path   nvarchar(1000),       --文件存放目录  
  @fname   nvarchar(250),       --文件名  
  @sheetname   varchar(250)=''     --要创建的工作表名,默认为文件名  
  as    
  declare   @err   int,@src   nvarchar(255),@desc   nvarchar(255),@out   int  
  declare   @obj   int,@constr   nvarchar(1000),@sql   varchar(8000),@fdlist   varchar(8000)  
   
  --参数检测  
  if   isnull(@fname,'')=''   set   @fname='temp.xls'  
  if   isnull(@sheetname,'')=''   set   @sheetname=replace(@fname,'.','#')  
   
  --检查文件是否已经存在  
  if   right(@path,1)<>'\'   set   @path=@path+'\'  
  create   table   #tb(a   bit,b   bit,c   bit)  
  set   @sql=@path+@fname  
  insert   into   #tb   exec   master..xp_fileexist   @sql  
   
  --数据库创建语句  
  set   @sql=@path+@fname  
  if   exists(select   1   from   #tb   where   a=1)  
    set   @constr='DRIVER={Microsoft   Excel   Driver   (*.xls)};DSN='''';READONLY=FALSE'  
                +';CREATE_DB="'+@sql+'";DBQ='+@sql  
  else  
    set   @constr='Provider=Microsoft.Jet.OLEDB.4.0;Extended   Properties="Excel   5.0;HDR=YES'  
          +';DATABASE='+@sql+'"'  
   
  --连接数据库  
  exec   @err=sp_oacreate   'adodb.connection',@obj   out  
  if   @err<>0   goto   lberr  
   
  exec   @err=sp_oamethod   @obj,'open',null,@constr  
  if   @err<>0   goto   lberr  
   
  --创建表的SQL  
  declare   @tbname   sysname  
  set   @tbname='##tmp_'+convert(varchar(38),newid())  
  set   @sql='select   *   into   ['+@tbname+']   from('+@sqlstr+')   a'  
  exec(@sql)  
   
  select   @sql='',@fdlist=''  
  select   @fdlist=@fdlist+','+a.name  
    ,@sql=@sql+',['+a.name+']   '  
      +case   when   b.name   in('char','nchar','varchar','nvarchar')   then  
            'text('+cast(case   when   a.length>255   then   255   else   a.length   end   as   varchar)+')'  
        when   b.name   in('tynyint','int','bigint','tinyint')   then   'int'  
        when   b.name   in('smalldatetime','datetime')   then   'datetime'  
        when   b.name   in('money','smallmoney')   then   'money'  
        else   b.name   end  
  FROM   tempdb..syscolumns   a   left   join   tempdb..systypes   b   on   a.xtype=b.xuse