以文本方式查看主題

-  曙海教育集團論壇  (http://m.scb-ycwb.com/bbs/index.asp)
--  Delphi程序設計  (http://m.scb-ycwb.com/bbs/list.asp?boardid=76)
----  幾個delphi書中沒提過的數據庫問題與我的疑惑和心得(一起討論)  (http://m.scb-ycwb.com/bbs/dispbbs.asp?boardid=76&id=2570)

--  作者:wangxinxin
--  發布時間:2010-12-14 11:16:27
--  幾個delphi書中沒提過的數據庫問題與我的疑惑和心得(一起討論)

1,ADOConnection和ADOTable在delphi中的使用

ADOConnection和ADOTable在delphi中像許多書中教的那樣設置好連接上數據庫(我用的SQLServer),運行沒有問題。然后我修改,目的是可以修改連接數據庫而不用在delphi中修改ADOConnection的ConnectionString屬性,還不出現連接對話框。

修改步驟:將LoginPrompt設置為false,將ConnectionString屬性清空,添加連接代碼

conStr:=\'Provider=SQLOLEDB.1;Password=1982072019;User ID=sa;Initial Catalog=StorageManagement;Data Source=10.16.99.175\';
  try
    loginForm.tempADOConnection.ConnectionString :=conStr;
    loginForm.tempADOConnection.Connected := true;
  except
    messagedlg(\'數據庫連接有誤!!請檢查DataConfig.XML\',mtConfirmation,[mbOk],0);
    Application.Terminate;
  end;

這樣程序運行起來,連接數據庫是沒有問題的。但出現的問題是在dlephi中ADOTable控件是不能連接表的,因為ConnectionString屬性沒有值。報錯為“無效的授權說明”。如何既能在delphi中使用ADOConnection和ADOTable控件,又可以不出現那個討厭的連接對話框。

2,在delphi中使用sql語句。

因為sql語句中給字符串賦值需要用雙引號,而delphi中用單引號括起字符串,我使用遇到了一些問題。我試驗的結果是delphi中用兩個單引號代替sql語句中的雙引號。不知道對不對?

具體如何使用,我還是不太清楚。

3,在delphi 7.0中使用ADOQuery的返回結果,書中介紹使用Params[\'xxxx\'].AsString;

我使用后報錯,但有一個光盤的程序這樣使用沒有報錯。我使用的是Parameters[\'xxxx\'],也使用不了.AsString

4,原代碼:
====================================================================
if canInsert then
  begin
    with allDataModule.AQ_OtherMaterielOut do
    begin
      Close;
      SQL.Clear;
      SQL.Text:=\'insert otherMaterielOut(materielID,amount) values (:insertID,:insertAmount,)\';
      Parameters[0].Value:=myMateriel;
      Parameters[1].Value:=myAmount; 
      ExecSQL;
    end;
    with allDataModule.AQ_OtherMaterielStock do
    begin
      Close;
      SQL.Clear;
      SQL.Text:=\'update otherMaterielStock set amount=amount-:updateAmount where materielID=:updateID\';
      Parameters[0].Value:=myAmount;
      Parameters[1].Value:=myMateriel;
      ExecSQL;
    end;
    materielOutForm.Close;
  end;

在這段代碼之后
with allDataModule.AQ_OtherMaterielOut do
    begin
      Close;
      SQL.Clear;
      SQL.Text:=\'update otherMaterielStock set amount=amount-:updateAmount where materielID=:updateID\';
      Parameters[0].Value:=myAmount;
      Parameters[1].Value:=myMateriel;
      ExecSQL;
    end;

不能使用allDataModule自動顯示可以使用的控件列表功能,但我強加上后面的代碼仍然可以使用。怎么回事?



主站蜘蛛池模板: 久久影院最新消息| 国产成人污污网站在线观看 | 国产精品网站在线观看免费传媒 | 超碰aⅴ人人做人人爽欧美| 日本免费www| 午夜无码国产理论在线| baoyu122.永久免费视频| 欧美精品黑人巨大在线播放| 国产精品久久久久久影视| 久久精品亚洲日本波多野结衣| 舞蹈班的三个小女孩唐嫣| 女人张开腿让男人捅| 亚洲欧洲精品成人久久曰影片 | 一级黄色片免费| 特级一级毛片免费看| 国产精品久久国产精品99盘| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 亚洲V欧美V国产V在线观看| 韩国电影吃奶喷奶水的电影| 成人永久免费福利视频网站| 伊人久久大香线蕉综合5g| 俄罗斯乱理伦片在线观看| 日本一区二区三区在线观看视频 | 久久久久久人妻无码| 精品400部自拍视频在线播放| 国产香蕉精品视频在| 久久精品免费大片国产大片| 精品国产柚木在线观看| 国产精品视频第一区二区三区| 久久精品老司机| 精品亚洲成a人无码成a在线观看| 国产自无码视频在线观看| 久久五月天综合| 狠狠躁夜夜躁人人爽天天不| 国产永久免费高清在线观看视频| 中文字幕aⅴ人妻一区二区| 欧美黑人粗暴多交高潮水最多| 国产国产人免费视频成69堂| а天堂中文最新一区二区三区| 欧美怡红院免费全部视频| 国产一级做a爰片久久毛片99|