main.cpp

来自「AbsDataBase5.16 最新版」· C++ 代码 · 共 79 行

CPP
79
字号
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop

#include "Main.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma link "ABSMain"
#pragma resource "*.dfm"
TForm1 *Form1;

const AnsiString DataBaseFileName = "..\\..\\Data\\Demos.abs";

//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
void __fastcall TForm1::FormCreate(TObject *Sender)
{
  TABSQuery *q;

  dbDemos->DatabaseFileName = ExtractFilePath(Application->ExeName) + DataBaseFileName;
  dbDemos->Open();

  q = new TABSQuery(NULL);
  try {
    q->DatabaseName = dbDemos->DatabaseName;
    q->SQL->Clear();
    q->SQL->Append("drop table friends;");
    q->SQL->Append("create table friends (id AutoInc, name varchar(20));");
    q->SQL->Append("insert into friends (name) values ('Kim');");
    q->SQL->Append("insert into friends (name) values ('Scott');");
    q->ExecSQL();
  } __finally {
    delete q;
  }

  ABSTable1->Open();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::FormClose(TObject *Sender, TCloseAction &Action)
{
  ABSTable1->Close();
  ABSTable1->DeleteTable();
}
//---------------------------------------------------------------------------
void __fastcall TForm1::btTransactionWithTableClick(TObject *Sender)
{
  dbDemos->StartTransaction();
  try {
    ABSTable1->Insert();
    ABSTable1->FieldByName("name")->AsString = "Kelly";
    ABSTable1->Post();
    dbDemos->Commit(cbFlush->Checked);
  } catch (Exception &e){
    dbDemos->Rollback();
  }
}
//---------------------------------------------------------------------------
void __fastcall TForm1::btTransactionWithQueryClick(TObject *Sender)
{
  ABSQuery1->SQL->Text = "START TRANSACTION; INSERT INTO friends (name) values ('Junior');";
  if (cbFlush->Checked) {
    ABSQuery1->SQL->Text = ABSQuery1->SQL->Text + "COMMIT;";
  } else {
    ABSQuery1->SQL->Text = ABSQuery1->SQL->Text + "COMMIT NOFLUSH;";
  }
  try {
    ABSQuery1->ExecSQL();
  } catch (Exception &e) {
    ABSQuery1->SQL->Text = "ROLLBACK";
    ABSQuery1->ExecSQL();
  }
  ABSTable1->Refresh();
}
//---------------------------------------------------------------------------

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?