动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.Oracle数据库备份技巧.
.留言簿(带Oracle数据库分页的显.
.Oracle触发器详细介绍.
.10g DBMS_Scheduler本地特权提升.
.归档模式下用户管理的完全恢复.
.为ORACLE 8i for SOLARIS配置并管.
.oracle数据库优化.
.oracle8i for unixware安装说明.
.Oracle归档模式的命令及参数.
.Oracle数据库 FAQs and Tips.
.轻松六步使你的Oracle存储过程迅.
.将oracle的查询结果输出为文件.
.案例学习Oracle错误:ORA-27123.
.建立虚拟记忆体.
.ORACLE SQL性能优化系列(五).
.如何查看数据文件是否自动扩展?.
.linux的基本操作(下).
.Oracle中imp导入相同的两个用户的.
.关于oracle中blob字段的录入问题.
.当数据积累到一定时间后执行会越.

如何用保存数据库连接参数代码及祥解

发表日期:2008-2-9 |



  在设计数据库应用程序的时候,经常需要将一些信息从程序中独立出来,以保证程序的可移植性。其中最重要的信息就是数据库的连接参数。
  在Delphi中,获得正确的数据库连接参数的方法十分简单,你只需要建立一个数据模块,在其中添加一个ADO Connection,双击之,然后在弹出的窗口中选“Use Connection String”,单击“Build”按钮,在“数据链接属性”窗口中选择适当的驱动引擎,并设定相应的连接参数就可以了。点击“确认”后,系统将自动生成连接串,显示在Object Inspector的Connection String中。
  以Microsoft SQL Server 为例,连接串就类似于:
  
  Provider=SQLOLEDB.1;PassWord=map;Persist Security Info=True;User ID=map;Initial Catalog=SuperWorkFlow;Data Source=GTSERVER
  
  连接串中各项参数由分号(;)分隔,具体含义如下:
  
  Provider —— 驱动类型
  Data Source —— 服务器名称
  Initial Catalog —— 数据库名称
  User ID —— 用户名
  Password —— 口令
  Persist Security Info —— 是否使用持续安全验证
  
  现在我们所要做的第一件工作是将各项参数写入一个INI文件中。
  Windows INI文件,可解释为Windows初始化文件。它是一种专门用来保存应用程序初始化信息和运行环境信息的文本文件。例如Windows 3.1中两个闻名的INI文件win.ini和system.ini就在Windows启动时定义了Windows环境中鼠标响应速度、使用的外壳(shell)程序等设置,Windows系统附带的许多应用程序也都有自己的INI文件。Windows软件初始化参数的获取与保存是通过读取扩展名为INI的文本文件实现的,即程序运行前先从制定的INI文件中搜索到所需的参数,并反映到程序的运行环境中,当程序退出时又将当前的环境参数保存到制定的INI文件中。
  INI文件是文本文件,由若干section组成,在每个带括号的标题下面,是若干个Keyword和一个等号,每个Keyword会控制应用程序某个功能的工作方式,等号右边的Value制定Keyword的操作方式,其一般形式如下:
  
  [section1]
  keyword1=value1
  keyword2=value2
  [section2]
  keyword1=value1
  keyword2=value2
  
  其中SectionName和KeywordName分别是段名和要害字明,Value为要害字对应的设定值,假如等号右边无任何内容(value为空),表示Windows应用程序已为该Keyword指定了缺省值,假如在整个文件中找不到某个Keyword,同样表示为它们指定了缺省值,各Section所出现的顺序是无关紧要的,在每一个Section里,各个Keyword的顺序同样也无关紧要,Keyword的值的类型多为String或Integer,应分两种情况读写。
  INI文件的书写有严格的要求:
  1、Section的名称必须加以“[”和“]”,且“[”必须在屏幕的第一列。
  2、Keyword名称也必须从屏幕的第一列开始书写,且后面必须紧跟“=”
  3、可以对文件加以注释,每行注释须以“;”开头。
  依照上述规则,我们编写下面的INI文件存储数据库的连接信息:
  
  [dbParam]
  Data Source=GTSERVER
  Initial Catalog=SuperWorkFlow
  User ID=map
  Password=map
  
  下面要做的工作就是编写代码,在程序执行的时候从INI文件中读取数据库连接参数,为此,我编写了下面的代码:
  
  //RWini.pas
  {
  模块名称:配置文件读写
  编写人:blue
  编写日期:2003-4-26
  模块功能:从系统配置文件中读取系统运行所需的各项参数
       将系统运行所需的各项参数写入系统配置文件
       生成数据库连接字符串
  }
  unit RWini;
  interface
  uses INIFiles;
  const strINIname = 'db.ini';//INI文件的文件名,大家根据具体情况修改
  var
   iniParam : TINIFile;
   strLocal : String;
   procedure readParam(out server:String;out database:string;out user:string;out password:string);
   procedure writeParam(server:string;database:string;user:string;password:string);
   function getConnStr:string;
  implementation
  
   procedure readParam(out server:String;out database:string;out user:string;out password:string);
   begin
    //从配置文件中读取数据库连接参数
    server := iniParam.ReadString('dbParam','Data Source','');
    database := iniParam.ReadString('dbParam','Initial Catalog','');
    user := iniParam.ReadString('dbParam','User ID','');
    password := iniParam.ReadString('dbParam','Password','');
   end;
  
   procedure writeParam(server:string;database:string;user:string;password:string);
   begin
    //将数据库连接参数写入配置文件
    iniParam.WriteString('dbParam','Data Source',server);
    iniParam.WriteString('dbParam','Initial Catalog',database);
    iniParam.WriteString('dbParam','User ID',user);
    iniParam.WriteString('dbParam','Password',password);
   end;
  
   function getConnStr:String;
   var
    server,database,user,password : String;
   begin
    //生成数据库连接串
    readParam(server,database,user,password);
    result := 'Provider=SQLOLEDB.1;Password=' + password + ';Persist Security Info=True;User ID=' + user + ';Initial Catalog=' + database + ';Data Source=' + server;
   end;
  
  initialization
   getDir(0,strLocal);
   iniParam := TINIFile.Create(strLocal + '\' + strINIname);
  
  finalization
   iniParam.Free;
  end.
  
  在程序数据模块的Create事件中添加下面的代码:
  
  procedure TDM.DataModuleCreate(Sender: TObject);
  var
   confForm : TConf;
  begin
   conn.ConnectionString := RWini.getConnStr;
   try
    conn.Open;
   except
    on Err : EOLEException do
    begin
     confForm := TConf.Create(self);
     confForm.ShowModal;
    end;
   end;
  end;
  
  这样,在程序执行过程中,将自动从INI文件中读取数据库连接参数,连接数据库,假如连接出现错误,将显示参数配置窗口,让用户配置数据库连接参数。
配置窗口的代码如下:
  
  //上面的代码省略
  uses RWini;
  
  {$R *.dfm}
  
  procedure TConf.FormShow(Sender: TObject);
  var
   sServer,sDatabase,sUser,sPassword : String;
  begin
   readParam(sServer,sDatabase,sUser,sPassword);
   self.edtServer.Text := sServer;
   self.edtDatabase.Text := sDatabase;
   self.edtUser.Text := sUser;
   self.edtPassword.Text := sPassword;
   self.ActiveControl := self.BTnOK;
  end;
  
  procedure TConf.btnCancelClick(Sender: TObject);
  begin
   close;
  end;
  
  procedure TConf.btnOKClick(Sender: TObject);
  var
   sServer,sDatabase,sUser,sPassword : String;
  begin
   sServer := self.edtServer.Text;
   sDatabase := self.edtDatabase.Text;
   sUser := self.edtUser.Text;
   sPassword := self.edtPassword.Text;
   writeParam(sServer,sDatabase,sUser,sPassword);
   close;
  end;
上一篇:oracle中用创建表时Storage中参数的含义 人气:495
下一篇:oracle中使用ANYDATA列对数据串行化方法 人气:469
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-14 25175学生成绩管理系统 v2.88
2008-10-14 冰雪CMS v2.0 bulid 081013
2008-10-14 Modoer多功能点评系统 v1.1 Beta
2008-10-14 乐风CMS乐风影视版 v2008.10.13
2008-10-14 FeitecCMS 40T免费资源网整站源码
2008-10-14 Asoft签到管理系统 v3.0 Pack2
2008-10-14 金博人才招聘求职网黄金版 v4.2
2008-10-14 游戏推广无限制版本
2008-10-14 AmEav WebSite 业网站管理系统 英
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成