使用C++ Builder修改某系统的总结

来源:岁月联盟 编辑:exp 时间:2011-12-09

 

1.ComboBox的使用:

  1)项的清除:mComShift->Items->Clear();

  2)事件经常用的有:OnDropDown(就是选择下拉框的时候触发的)和OnChange(就是下拉框选择后触发的)

  3)下拉框的数据加载:可以在OnDropDown事件里面加载数据,也可以在FormCreate的时候加载数据。一般建议前面一种方法,

     因为当在其他窗体里面改变了相关的数据的时候,如果是FormCreate的时候加载数据,那么该下拉框的数据不会随之而变化。

  4)下拉框绑定数据的时候有两张方法,下面以下拉框名字为mComShift说明:

     其一:mComShift->Items->AddObject(ADOQuery_Local1->FieldByName("schedulename")->AsString,

            (TObject *)ADOQuery_Local1->FieldByName("scheduleid")->AsInteger);

     其二:  mComShift->Items->AddObject(ADOQuery_Local1->FieldByName("schedulename")->AsString,

            new TValue(ADOQuery_Local1->FieldByName("scheduleid")->AsString));

     如果使用第二种方法需要用到如下类转换:

     class TValue:public TObject

     {

       public:

             TValue(const AnsiString& value):mValue(value){}

             AnsiString mValue;

     };

  5)获取下拉框的选择的数据:  AnsiString scheduleid = ((TValue*)mComShift->Items->Objects[mComShift->ItemIndex])->mValue;

  6)下拉框初始化的默认值:mComShift->ItemIndex=0;//选择第一个数据

2.提示消息:ShowMessage("message");

3.数据类型转换:

  1)int-AnsiString:int i=1;AnsiString  j=IntToStr(i);

  2)AnsiString-int:         i=j.ToInt();

 

4.C++Builder 6的环境使用:

  1)F9为调试启动,F8为一行一行地调试,Run-Program Reset为终止该次的调试。

  2)Object Inspector为各个控件的的属性视图,Object TreeView可以清晰地展示该窗体的全部控件

 

5.要注意类的初始化的参数,如:CTShift  *shift = new CTShift(ShiftID,Shiftname, "", StartTime, EndTime, 0);注意参数的

顺序要正确

6.Oracle

  1)查询某张表的前几天数据:select scheduleid,schedulename from wf_schedule where rownum<=10

  2)“违反唯一约束”的错误,即表有一个或多个主键的时候,当表有数据,再插入跟主键一样的数据的时候就出现这个情况.

  3)删除掉某张表的字段:alter TABLE  wf_shift DROP COLUMN  SelectFlag;

 

7.当程序运行出现异常的时候(特别),不妨重新Build All Projects(一次或多次),或者重新打开程序.

8.日志打印的:

  1)该文件为:tlog.h和tlog.cpp

  2)g_logFile.open();TLog g_logFile("WorkForce","1.0",1);g_logFile.print("log" );g_logFile.close();

 

9.ListBox的使用:

  1)动态加载数据:ListBox_NoSelectShift->Items->AddObject(shiftname, new TValue(query->FieldByName("shiftid")->AsString));

  2)判断选择项并且取出其中的Name和Id

      for(int i=0;i<ListBox_NoSelectShift->Count;i++)

     {

      if(ListBox_NoSelectShift->Selected[i])

      {

         AnsiString id = ((TValue*)ListBox_NoSelectShift->Items->Objects[ListBox_NoSelectShift->ItemIndex])->mValue;

         AnsiString name = ListBox_NoSelectShift->Items->Strings[i];

         ListBox_SelectShift->Items->AddObject(name, new TValue(id));

         ListBox_NoSelectShift->Items->Delete(i);

      }

     }

10.执行SQL语句(无非有两种),在该系统里面适用,直接调用的实例:

  1)非查询的:  

    AnsiString mySql="";

    DM->ExecSql(mySql);

  2)  查询的:

    AnsiString strSql="";

    TADOQuery *query = DM->ADOQuery_Comm;

   query->SQL->Clear();query->SQL->Add(strSql);

   query->Open();      query->First();

   while (!query->Eof)

   {

    int ActiveID = query->FieldByName("activeid")->AsInteger;

    //读取表的字段 www.2cto.com

    query->Next();

   }

          query->Close();

11.m_pVctLstShift.push_back(NewLstShift);//push_back是加载数据

 

摘自 loveheronly的专栏