一个文件里存放的一些Sql 语句如何在程序中调用? qry1.SQL.LoadFromFile('your.sql');qry1.ExecSQL; 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 QUERY1.SQL.LoadFromFile('C:\LZJ.TXT'); query1.SQL.LoadFromFile('directory\filename.sql');query1.ExecSQL; 可以看一下文件的读写方面的帖子阿要用到一下的函数:Delphi中的INI文件编程 2000-07-04· -·-INI文件在系统配置及应用程序参数保存与设置方面,具有很重要的作用,所以可视化的编程一族,如VB、VC、VFP、Delphi等都提供了读写INI文件的方法,其中Delphi中操作INI文件,最为简洁,这是因为Delphi3提供了一个TInifile类,使我们可以非常灵活的处理INI文件。 一、有必要了解INI文件的结构:;注释[小节名]关键字=值...INI文件允许有多个小节,每个小节又允许有多个关键字,“=”后面是该关键字的值。 值的类型有三种:字符串、整型数值和布尔值。其中字符串存贮在INI文件中时没有引号,布尔真值用1表示,布尔假值用0表示。 注释以分号“;”开头。 二、定义1、在Interface的Uses节增加IniFiles; 2、在Var变量定义部分增加一行: myinifile:Tinifile;然后,就可以对变量myinifile进行创建、打开、读取、写入等操作了。 三、打开INI文件myinifile:=Tinifile.create('program.ini');上面这一行语句将会为变量myinifile与具体的文件program.ini建立联系,然后,就可以通过变量myinifile,来读写program.ini文件中的关键字的值了。 值得注意的是,如果括号中的文件名没有指明路径的话,那么这个Program.ini文件会存储在Windows目录中,把Program.ini文件存储在应用程序当前目录中的方法是:为其指定完整的路径及文件名。下面的两条语句可以完成这个功能: Filename:=ExtractFilePath(Paramstr(0))+'program.ini';myinifile:=Tinifile.Create(filename);四、读取关键字的值针对INI文件支持的字符串、整型数值、布尔值三种数据类型,TINIfiles类提供了三种不同的对象方法来读取INI文件中关键字的值。 假设已定义变量vs、vi、vb分别为string、integer、boolean类型。 vs:=myinifile.Readstring('小节名','关键字',缺省值);vi:=myinifile.Readinteger('小节名','关键字',缺省值);vb:=myinifile.Readbool('小节名','关键字',缺省值);其中缺省值为该INI文件不存在该关键字时返回的缺省值。 五、写入INI文件同样的,TInifile类也提供了三种不同的对象方法,向INI文件写入字符串、整型数及布尔类型的关键字。 myinifile.writestring('小节名','关键字',变量或字符串值);myinifile.writeinteger('小节名','关键字',变量或整型数值);myinifile.writebool('小节名','关键字',变量或True或False);当这个INI文件不存在时,上面的语句还会自动创建该INI文件。 六、删除关键字除了可用写入方法增加一个关键字,Tinifile类还提供了一个删除关键字的对象方法: myinifile.DeleteKey('小节名','关键字');七、小节操作增加一个小节可用写入的方法来完成,删除一个小节可用下面的对象方法: myinifile.EraseSection('小节名');另外Tinifile类还提供了三种对象方法来对小节进行操作: myinifile.readsection('小节名',TStrings变量);可将指定小节中的所有关键字名读取至一个字符串列表变量中; myinifile.readsections(TStrings变量);可将INI文件中所有小节名读取至一个字符串列表变量中去。 myinifile.readsectionvalues('小节名',TStrings变量);可将INI文件中指定小节的所有行(包括关键字、=、值)读取至一个字符串列表变量中去。 八、释放在适当的位置用下面的语句释放myinifile:myinifile.distory;九、一个实例下面用一个简单的例子(如图),演示了建立、读取、存贮INI文件的方法。myini.ini文件中包含有“程序参数”小节,和用户名称(字符串)、是否正式用户(布尔值)和已运行时间(整型值)三个关键字。程序在窗体建立读取这些数据,并在窗体释放时写myini.ini文件。 附源程序清单 unitUnit1;interfaceusesWindows,Messages,SysUtils,Classes,Graphics,Controls,Forms,Dialogs,inifiles,StdCtrls,ExtCtrls;typeTForm1=class(TForm)Edit1:TEdit;CheckBox1:TCheckBox;Edit2:TEdit;Label1:TLabel;Label2:TLabel;Timer1:TTimer;Label3:TLabel;procedureFormCreate(Sender:TObject);procedureFormDestroy(Sender:TObject);procedureTimer1Timer(Sender:TObject);private{Privatedeclarations}public{Publicdeclarations}end;varForm1:TForm1;implementationvarmyinifile:TInifile;{$R*.DFM}procedureTForm1.FormCreate(Sender:TObject);varfilename:string;beginfilename:=ExtractFilePath(paramstr(0))+'myini.ini';myinifile:=TInifile.Create(filename);edit1.Text:=myinifile.readstring('程序参数','用户名称','缺省的用户名称');edit2.text:=inttostr(myinifile.readinteger('程序参数','已运行时间',0));checkbox1.Checked:=myinifile.readbool('程序参数','是否正式用户',False);end;procedureTForm1.FormDestroy(Sender:TObject);beginmyinifile.writestring('程序参数','用户名称',edit1.Text);myinifile.writeinteger('程序参数','已运行时间',strtoint(edit2.text));myinifile.writebool('程序参数','是否正式用户',checkbox1.Checked);myinifile.Destroy;end;procedureTForm1.Timer1Timer(Sender:TObject);beginedit2.Text:=inttostr(strtoint(edit2.text)+1);end;end.Copy()Pos() 如果是SQL SERVER,可以这样用:ShellExecute('isql',PChar('-S'+数据库服务器名+' -U'+用户名+' -P'+口令+' -d'+数据库名+' <"'+SQL语句文件名+'"',SW_HIDE);也就是调用SQL SERVER 的isql命令提示行工具。 楼上这位您好!我想的正是用Sql server 2000连结数据库,请问,我想将新建一个数据库的语句写在一个文件里,并在一个程序中调用,则如何实现呢? 把文件分割成一个一个的事物块,然后有一个Query控件,QUERY1.close;QUERY1.sql.clear;QUERY1.SQL.LoadFromFile('文件名');QUERY1.execsql;反复执行即可 如何才能让DBRID控件显示相应的信息, HTMLHELP 中图片不能显示? !!!!高手快来,请教字模问题???? 我问你。 有关操作符"and"的使用,请高手指点! 多了一个三角,散分!另问问大家学java的经验(我在java和delphi版都散了)! 请问怎么用代码联接数据库 小妹?^_^?捉虫:模糊查询的问题? 请问如何dbgrid控件的单击事件中得到单击行的行号 120分,Delphi猛料包及winapi全家福下载!!!快…… 谁有Delphi的电子书呀? 窗口连接的问题
query1.ExecSQL;
要用到一下的函数:
Delphi中的INI文件编程
2000-07-04· -·-INI文件在系统配置及应用程序参数保存与设置方面,具有很重要的作用,
所以可视化的编程一族,如VB、VC、VFP、Delphi等都提供了读写INI文件
的方法,其中Delphi中操作INI文件,最为简洁,这是因为Delphi3提供了
一个TInifile类,使我们可以非常灵活的处理INI文件。
一、有必要了解INI文件的结构:;注释
[小节名]
关键字=值
...INI文件允许有多个小节,每个小节又允许有多个关键字,“=”后面是
该关键字的值。
值的类型有三种:字符串、整型数值和布尔值。其中字符串存贮在INI文
件中时没有引号,布尔真值用1表示,布尔假值用0表示。 注释以分号“;”开头。 二、定义
1、在Interface的Uses节增加IniFiles;
2、在Var变量定义部分增加一行:
myinifile:Tinifile;然后,就可以对变量myinifile进行创建、打开、读取、写入等操作了。
三、打开INI文件myinifile:=Tinifile.create('program.ini');上面这一行语句将会为变量myinifile与具体的文件program.ini建立联
系,然后,就可以通过变量myinifile,来读写program.ini文件中的关
键字的值了。
值得注意的是,如果括号中的文件名没有指明路径的话,那么这个
Program.ini文件会存储在Windows目录中,把Program.ini文件存储在应
用程序当前目录中的方法是:为其指定完整的路径及文件名。下面的两
条语句可以完成这个功能:
Filename:=ExtractFilePath(Paramstr
(0))+'program.ini';
myinifile:=Tinifile.Create(filename);四、读取关键字的值
针对INI文件支持的字符串、整型数值、布尔值三种数据类型,
TINIfiles类提供了三种不同的对象方法来读取INI文件中关键字的值。
假设已定义变量vs、vi、vb分别为string、integer、boolean类型。
vs:=myinifile.Readstring
('小节名','关键字',缺省值);
vi:=myinifile.Readinteger
('小节名','关键字',缺省值);
vb:=myinifile.Readbool
('小节名','关键字',缺省值);其中缺省值为该INI文件不存在该关键字时返回的缺省值。
五、写入INI文件
同样的,TInifile类也提供了三种不同的对象方法,向INI文件写
入字符串、整型数及布尔类型的关键字。 myinifile.writestring('小节名','关键字',变量或字符串值);
myinifile.writeinteger('小节名','关键字',变量或整型数值);
myinifile.writebool('小节名','关键字',变量或True或False);当这个INI文件不存在时,上面的语句还会自动创建该INI文件。
六、删除关键字
除了可用写入方法增加一个关键字,Tinifile类还提供了一个删
除关键字的对象方法: myinifile.DeleteKey('小节名','关键字');七、小节操作
增加一个小节可用写入的方法来完成,删除一个小节可用下面的
对象方法: myinifile.EraseSection('小节名');另外Tinifile类还提供了三种对象方法来对小节进行操作:
myinifile.readsection('小节名',TStrings变量);可将指定小节中的
所有关键字名读取至一个字符串列表变量中; myinifile.readsections(TStrings变量);可将INI文件中所有小节名读
取至一个字符串列表变量中去。 myinifile.readsectionvalues('小节名',TStrings变量);可将INI文件
中指定小节的所有行(包括关键字、=、值)读取至一个字符串列表变
量中去。 八、释放在适当的位置用下面的语句释放myinifile:
myinifile.distory;九、一个实例
下面用一个简单的例子(如图),演示了建立、读取、存贮INI文件的方
法。myini.ini文件中包含有“程序参数”小节,和用户名称(字符串
)、是否正式用户(布尔值)和已运行时间(整型值)三个关键字。
程序在窗体建立读取这些数据,并在窗体释放时写myini.ini文件。
附源程序清单
unitUnit1;
interface
uses
Windows,Messages,SysUtils,Classes,Graphics,
Controls,Forms,Dialogs,inifiles,StdCtrls,ExtCtrls;
type
TForm1=class(TForm)
Edit1:TEdit;
CheckBox1:TCheckBox;
Edit2:TEdit;
Label1:TLabel;
Label2:TLabel;
Timer1:TTimer;
Label3:TLabel;
procedureFormCreate(Sender:TObject);
procedureFormDestroy(Sender:TObject);
procedureTimer1Timer(Sender:TObject);
private
{Privatedeclarations}
public
{Publicdeclarations}
end;
var
Form1:TForm1;implementation
var
myinifile:TInifile;
{$R*.DFM}procedureTForm1.FormCreate(Sender:TObject);
var
filename:string;
begin
filename:=ExtractFilePath(paramstr(0))+'myini.ini';
myinifile:=TInifile.Create(filename);
edit1.Text:=myinifile.readstring
('程序参数','用户名称','缺省的用户名称');
edit2.text:=inttostr(myinifile.readinteger
('程序参数','已运行时间',0));
checkbox1.Checked:=myinifile.readbool
('程序参数','是否正式用户',False);
end;procedureTForm1.FormDestroy(Sender:TObject);
begin
myinifile.writestring('程序参数','用户名称',edit1.Text);
myinifile.writeinteger('程序参数','已运行时间',
strtoint(edit2.text));
myinifile.writebool('程序参数','是否正式用户',
checkbox1.Checked);
myinifile.Destroy;
end;procedureTForm1.Timer1Timer(Sender:TObject);
begin
edit2.Text:=inttostr(strtoint(edit2.text)+1);
end;end.Copy()
Pos()
ShellExecute('isql',PChar('-S'+数据库服务器名+' -U'+用户名+' -P'+口令+' -d'+数据库名+' <"'+SQL语句文件名+'"',SW_HIDE);
也就是调用SQL SERVER 的isql命令提示行工具。
请问,我想将新建一个数据库的语句写在一个文件里,并在
一个程序中调用,则如何实现呢?
QUERY1.close;
QUERY1.sql.clear;
QUERY1.SQL.LoadFromFile('文件名');
QUERY1.execsql;
反复执行即可