注意:用DBEXpress给SQLServer2000备份、恢复的操作。(50分)

  • 主题发起人 主题发起人 nzfsoft
  • 开始时间 开始时间
LiChaoHui:感谢你的关注!
 
你先发到我的信箱吧,马上要放假了,等到上班的时候我仔细的研究一下
谢谢
li_violetcn@yahoo.com.cn
 
等你8号试一下吧。
 
LiChaoHui:你上班了吧。
 
明天上班,我正在安装SQL Server2000
 
有试过在win98下重复安装、卸载Win2000个人版 吗?
好像重复两次后就会出现安装后安装程序自动配置服务器时出现错误。
不知道如何解决。
 
我一般都是在一个干净的分区上安装Win2000
没有像你说的那样安装,
你说的自动配置服务器,好像个人版没有啊,服务器版才有的

我也遇到麻烦了,我在Win2000 Professional下安装了SQL Server个人版
无法在D6下通过dbexpress连接到SQL Server,用别的方式是可以的
如BDE, ADO, SQLDirect, ODBC, 我用了你的方法,似乎不行,
老是出现连接错误 Failure to Connect: SQL Error: Error mapping failed
我在想用不用装D7呢?
我用了另一个版本的dbexpress for sql server 是CoreLab的,
倒是可以正常的连接数据库
 
不用装D7.就可以连接。我确定。要不我把我的连接程序给你发过来?
你的邮箱呢?
 
Li兄,你的QQ号是多少?我们讨论一下吧。
 
呵呵,D7已经装完了,我的QQ: 18671795
装了D7还是连不上,我没辙了
 
我不会什么DBExepress,
用TQUERY倒行~~~~~~
先建一个TDatabase对象(临时的),
再关闭原先打开过的TDataBase(这是你程序中用的)
目的是不让什么地方忘了关闭连接(占线了),
再建一个TQUERY对象
其SQL为
use master
Backup database 你的数据库名称 (//这个看SQL SERVER帮助啦)

OK?搞定备份,
再打开你原先的TDatabase啦,
还要你必要的数据表啦
如果谁把它做成组件,MAIL我一份~~~~
我很懒,
谢谢~~~~~~~~~~~~~~~
 
做成组件倒是不用,只是D7的dbexpress for sqlserver得升级才好使
 
object Form1: TForm1
Left = 192
Top = 107
Width = 544
Height = 375
Caption = 'Form1'
Color = clBtnFace
Font.Charset = GB2312_CHARSET
Font.Color = clWindowText
Font.Height = -12
Font.Name = '宋体'
Font.Style = []
OldCreateOrder = False
OnCreate = FormCreate
PixelsPerInch = 96
TextHeight = 12
object Button1: TButton
Left = 112
Top = 16
Width = 75
Height = 25
Caption = 'Button1'
TabOrder = 0
OnClick = Button1Click
end
object DBGrid1: TDBGrid
Left = 200
Top = 16
Width = 320
Height = 120
DataSource = DataSource1
TabOrder = 1
TitleFont.Charset = GB2312_CHARSET
TitleFont.Color = clWindowText
TitleFont.Height = -12
TitleFont.Name = '宋体'
TitleFont.Style = []
Columns = <
item
Expanded = False
FieldName = 'a'
Width = 55
Visible = True
end
item
Expanded = False
FieldName = 'b'
Width = 55
Visible = True
end
item
Expanded = False
FieldName = 'c'
Width = 79
Visible = True
end
item
Expanded = False
FieldName = 'd'
Width = 58
Visible = True
end>
end
object SQLCn: TSQLConnection
ConnectionName = 'MSSQLConnection'
DriverName = 'MSSQL'
GetDriverFunc = 'getSQLDriverMSSQL'
LibraryName = 'dbexpmss.dll'
LoginPrompt = False
Params.Strings = (
'DriverName=MSSQL'
'HostName=lzh'
'DataBase=test2'
'User_Name=sa'
'Password='
'BlobSize=-1'
'LocaleCode=0000'
'MSSQL TransIsolation=ReadCommited'
'OS Authentication=False')
VendorLib = 'oledb'
Left = 16
Top = 16
end
object C: TSQLClientDataSet
Active = True
CommandText = 'select * from tt1'
Aggregates = <>
Options = [poAllowCommandText]
ObjectView = True
Params = <>
DBConnection = SQLCn
Left = 48
Top = 16
end
object TmpCn: TSQLConnection
ConnectionName = 'MSSQLConnection'
DriverName = 'MSSQL'
GetDriverFunc = 'getSQLDriverMSSQL'
LibraryName = 'dbexpmss.dll'
LoginPrompt = False
Params.Strings = (
'DriverName=MSSQL'
'HostName=lzh'
'DataBase=master'
'User_Name=sa'
'Password='
'BlobSize=-1'
'LocaleCode=0000'
'MSSQL TransIsolation=ReadCommited'
'OS Authentication=False')
VendorLib = 'oledb'
Left = 16
Top = 64
end
object DataSource1: TDataSource
DataSet = C
Left = 80
Top = 16
end
object d: TOpenDialog
Left = 40
Top = 136
end
end
 
unit Unit1;

interface

uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, DBXpress, FMTBcd, StdCtrls, DB, SqlExpr, Provider, Grids,
DBGrids, DBClient, DBLocal, DBLocalS;

type
TForm1 = class(TForm)
SQLCn: TSQLConnection;
Button1: TButton;
C: TSQLClientDataSet;
TmpCn: TSQLConnection;
DataSource1: TDataSource;
DBGrid1: TDBGrid;
d: TOpenDialog;
procedure Button1Click(Sender: TObject);
procedure FormCreate(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;

var
Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var SQL,FileName,s:string;
R:integer;
begin

s:='';
d.InitialDir :='C:/';
d.Filter :='*.mdb|*.mdb';
d.Title :='OKOKOKOKO';
d.Execute ;
FileName:=d.FileName;//获取的文件名字与路径
C.Close ;
SQLcn.Close;
TmpCn.Close ;
//tmpcn.ExecuteDirect( 'ALTER DataBase IcSaler SET SINGLE_USER ');//这句时死机

SQL:='restore database test2 from disk='+''''+FileName+'''';
R:=TmpCn.ExecuteDirect(SQL);
Showmessage('R='+Inttostr(R));
tmpCN.Open ;
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
SQLCn.Connected := True;
end;

end.
 
与我原来的相比,是不是把死机的那句去掉就行了?
 
转:我把你的会死机的那句,注释掉了,
注意,开发环境的设计窗体也不允许连接要恢复的数据库
 
我知道了。主要是设计IDE中我对数据库有连接。所以我恢复就出问题。
我在设计阶段把他们都关了。就行了。

(奇怪ADO就可以。NND,搞不懂。如果Dbexpress的连接不断,ADO依然可以恢复。)
 
总之,要恢复的数据库上不能有任何连接,
你的那句把数据库设置为单用户模式,是没有必要了
恢复语句会自动进行此操作的

如果是Sybase数据库,恢复完成后,还需要设置数据库为在线
 
结单啦。。。
 
后退
顶部