⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qmdoc.cpp

📁 邮 电 公 司 erp源码
💻 CPP
📖 第 1 页 / 共 4 页
字号:
    case 1:
        b_RqrCode="";
        b_RqrName="";
        b_RqrDesc="";
      break;
     }
}
//---------------------------------------------------------------------------
void TsdRqr::BatchLetValue()
{
    m_RqrCode=m_Query->FieldValues["RqrCode"];
    m_RqrName=m_Query->FieldValues["RqrName"];
    m_RqrDesc=m_Query->FieldValues["RqrDesc"];
    BackupValue();
}
//---------------------------------------------------------------------------
void TsdRqr::Update()
{
    if(CurStatus==0||CurStatus==1)
        throw Exception("当前不是编辑状态,不能进行存盘操作!");
    if(m_RqrCode.IsEmpty()==true)
        throw Exception("单号不能为空!");
    m_StoredProc->Close();
    if(CurStatus==2||CurStatus==4)
      {
        m_StoredProc->ProcedureName="sdRqr_Insert";
        m_StoredProc->Parameters->Clear();
        m_StoredProc->Parameters->CreateParameter("@RqrCode",ftString,pdInput,18,m_RqrCode);
        m_StoredProc->Parameters->CreateParameter("@RqrName",ftString,pdInput,20,m_RqrName);
        m_StoredProc->Parameters->CreateParameter("@RqrDesc",ftString,pdInput,40,m_RqrDesc);

        m_StoredProc->ExecProc();


   }
  else
    {
        m_StoredProc->ProcedureName="sdRqr_Update";
        m_StoredProc->Parameters->Clear();

        m_StoredProc->Parameters->CreateParameter("@W_RqrCode",ftString,pdInput,18,b_RqrCode);
        m_StoredProc->Parameters->CreateParameter("@RqrCode",ftString,pdInput,18,m_RqrCode);
        m_StoredProc->Parameters->CreateParameter("@RqrName",ftString,pdInput,20,m_RqrName);
        m_StoredProc->Parameters->CreateParameter("@RqrDesc",ftString,pdInput,40,m_RqrDesc);

       m_StoredProc->ExecProc();


   }
    m_StoredProc->Close();
  TsdRqr *p=new TsdRqr();
  if(CurStatus==2)
    {
     SetActionID(1);
     p->Assign(this);
     AddRecord((void *)p,p->RqrCode);
     }
  else
    {
     SetActionID(1);
     p->Assign(this);
     ChangeRecord((void *)p,p->RqrCode,this->b_RqrCode);
    }
}
//---------------------------------------------------------------------------
void TsdRqr::Delete()
{
    if(CurStatus!=1)
        throw Exception("当前状态不能进行删除操作!");
    if(m_RqrCode.IsEmpty()==true)
        throw Exception("当前没有记录可以删除!");
    m_StoredProc->Close();
    m_StoredProc->ProcedureName="sdRqr_Delete";
    m_StoredProc->Parameters->Clear();
        m_StoredProc->Parameters->CreateParameter("@W_RqrCode",ftString,pdInput,18,b_RqrCode);
    m_StoredProc->ExecProc();
    m_StoredProc->Close();
    DeleteRecord(this->b_RqrCode);
}
//---------------------------------------------------------------------------
void TsdRqr::Assign(TsdRqr *p)
{
    this->SetActionID(p->CurStatus);
    this->m_RqrCode=p->m_RqrCode;
    this->m_RqrName=p->m_RqrName;
    this->m_RqrDesc=p->m_RqrDesc;
    this->BackupValue();
}
//---------------------------------------------------------------------------
void TsdRqr::AssignValue()
{
    TsdRqr *p=(TsdRqr *)Records(CurRecNo);
    Assign(p);
}
//---------------------------------------------------------------------------
int TsdRqr::Query()
{
    AnsiString m_SqlStr;
    m_SqlStr=QueryString;
    if(FilterString.IsEmpty()==false)
        m_SqlStr=m_SqlStr+" where  "+FilterString;
    if(OrderString.IsEmpty()==false)
        m_SqlStr=m_SqlStr+" Order by "+OrderString;
    m_Query->Close();
    m_Query->SQL->Clear();
    m_Query->SQL->Add(m_SqlStr);
    m_Query->Open();
    ClearRecord();
    if(m_Query->RecordCount>0)
    {
        m_Query->First();
        while(!m_Query->Eof)
        {
            BatchLetValue();
            TsdRqr *p=new TsdRqr();
            SetActionID(1);
            p->Assign(this);
            AddRecord((void *)p,p->RqrCode);
            m_Query->Next();
        }
        MoveFirst();
    }
    m_Query->Close();
    return Count;
}
//---------------------------------------------------------------------------
bool TsdRqr::Find(AnsiString WhereStr)
{
    AnsiString m_SqlStr;
    if(WhereStr.IsEmpty()==true)
        throw Exception("查找表达式不能为空");
    m_SqlStr="select * from sdRqr where  "+WhereStr;
    m_Query->Close();
    m_Query->SQL->Clear();
    m_Query->SQL->Add(m_SqlStr);
    m_Query->Open();
    if(m_Query->RecordCount!=1)
    {
        m_Query->Close();
        return false;
    }
    else
    {
        BatchLetValue();
        m_Query->Close();
        return true;
    }
}
//完成
//类体
//**************************************
//     TsdTrd            技术要求
//**************************************
//--------------------------------------------------------------
void __fastcall TsdTrd:: SetTrdCode(AnsiString value)
{
       if(value.IsEmpty())
         throw Exception("技术要求代码不能为空");
       if(value.Length()>18)
         throw Exception("技术要求代码不能大于18");
       if(value!=m_TrdCode)
       {
            m_Query->Close();
            m_Query->SQL->Clear();
            m_Query->SQL->Add("select TrdCode from sdTrd where TrdCode='"+value+"'");
            m_Query->Open();
            if(m_Query->RecordCount>0)
            {
                 m_Query->Close();
                 throw Exception("技术要求代码"+value+"已存在");
            }
            m_Query->Close();
       }
       m_TrdCode=value;
}
void __fastcall TsdTrd:: SetTrdName(AnsiString value)
{
       if(value.Length()>20)
         throw Exception("技术要求名称不能大于20");
       if(value != m_TrdName)
       {
            m_Query->Close();
            m_Query->SQL->Clear();
            m_Query->SQL->Add("select TrdName from sdTrd where TrdName='"+value+"'");
            m_Query->Open();
            if(m_Query->RecordCount>0)
            {
                 m_Query->Close();
                 throw Exception("技术要求名称 "+value+" 已存在");
            }
            m_Query->Close();
       }
       m_TrdName=value;
}
void __fastcall TsdTrd:: SetTrdDesc(AnsiString value)
{
       if(value.Length()>40)
         throw Exception("技术要求描述不能大于40");
       m_TrdDesc=value;
}
//---------------------------------------------------------------------------
AnsiString TsdTrd::GetFieldValue(euTrd sdFieldName)
{
    switch(sdFieldName)
    {
      case fiTrdCode:
           return TrdCode;
      case fiTrdName:
           return TrdName;
      case fiTrdDesc:
           return TrdDesc;
      default:
           throw Exception("当前未定义返可取值");
     }
}
//---------------------------------------------------------------------------
void TsdTrd::SetFieldValue(euTrd sdFieldName, AnsiString value)
{
    value=Trim(value);
    switch(sdFieldName)
     {
    case fiTrdCode:
         TrdCode=value;
          break;
    case fiTrdName:
         TrdName=value;
          break;
    case fiTrdDesc:
         TrdDesc=value;
          break;
    default:
         throw Exception("当前字段未定义可赋值");
    }
}
//---------------------------------------------------------------------------
TsdTrd::TsdTrd(TDataComm *DC)
                :TsdStandard(DC)
{
    try
    {
        QueryString="SELECT * FROM sdTrd";
        FilterString="";
        OrderString="TrdCode";
        EmptyValue(0);
        EmptyValue(1);
    }
    catch(Exception &e)
    {
        ShowMessage(e.Message);
    }
}
TsdTrd::TsdTrd()
                :TsdStandard()
{
    try
    {
        QueryString="SELECT * FROM sdTrd";
        FilterString="";
        OrderString="TrdCode";
        EmptyValue(0);
        EmptyValue(1);
    }
    catch(Exception &e)
    {
        ShowMessage(e.Message);
    }
}
//---------------------------------------------------------------------------
TsdTrd::~TsdTrd()
{
  try{
     }
  catch(...)
    {
     throw Exception("析构函数出错");
    }
}
//---------------------------------------------------------------------------
void TsdTrd::BackupValue()
{
      b_TrdCode=m_TrdCode;
      b_TrdName=m_TrdName;
      b_TrdDesc=m_TrdDesc;
}
//---------------------------------------------------------------------------
void TsdTrd::RestoreValue()
{
      m_TrdCode=b_TrdCode;
      m_TrdName=b_TrdName;
      m_TrdDesc=b_TrdDesc;
}
//---------------------------------------------------------------------------
void TsdTrd::EmptyValue(int Index)
{
   switch(Index)
   {
    case 0:
        m_TrdCode="";
        m_TrdName="";
        m_TrdDesc="";
    break;
    case 1:
        b_TrdCode="";
        b_TrdName="";
        b_TrdDesc="";
      break;
     }
}
//---------------------------------------------------------------------------
void TsdTrd::BatchLetValue()
{
    m_TrdCode=m_Query->FieldValues["TrdCode"];
    m_TrdName=m_Query->FieldValues["TrdName"];
    m_TrdDesc=m_Query->FieldValues["TrdDesc"];
    BackupValue();
}
//---------------------------------------------------------------------------
void TsdTrd::Update()
{
    if(CurStatus==0||CurStatus==1)
        throw Exception("当前不是编辑状态,不能进行存盘操作!");
    if(m_TrdCode.IsEmpty()==true)
        throw Exception("单号不能为空!");
    m_StoredProc->Close();
    if(CurStatus==2||CurStatus==4)
      {
        m_StoredProc->ProcedureName="sdTrd_Insert";
        m_StoredProc->Parameters->Clear();
        m_StoredProc->Parameters->CreateParameter("@TrdCode",ftString,pdInput,18,m_TrdCode);
        m_StoredProc->Parameters->CreateParameter("@TrdName",ftString,pdInput,20,m_TrdName);
        m_StoredProc->Parameters->CreateParameter("@TrdDesc",ftString,pdInput,40,m_TrdDesc);

        m_StoredProc->ExecProc();


   }
  else
    {
        m_StoredProc->ProcedureName="sdTrd_Update";
        m_StoredProc->Parameters->Clear();

        m_StoredProc->Parameters->CreateParameter("@W_TrdCode",ftString,pdInput,18,b_TrdCode);
        m_StoredProc->Parameters->CreateParameter("@TrdCode",ftString,pdInput,18,m_TrdCode);
        m_StoredProc->Parameters->CreateParameter("@TrdName",ftString,pdInput,20,m_TrdName);
        m_StoredProc->Parameters->CreateParameter("@TrdDesc",ftString,pdInput,40,m_TrdDesc);

       m_StoredProc->ExecProc();


   }
    m_StoredProc->Close();
  TsdTrd *p=new TsdTrd();
  if(CurStatus==2)
    {
     SetActionID(1);
     p->Assign(this);
     AddRecord((void *)p,p->TrdCode);
     }
  else
    {
     SetActionID(1);
     p->Assign(this);
     ChangeRecord((void *)p,p->TrdCode,this->b_TrdCode);
    }
}
//---------------------------------------------------------------------------
void TsdTrd::Delete()
{
    if(CurStatus!=1)
        throw Exception("当前状态不能进行删除操作!");
    if(m_TrdCode.IsEmpty()==true)
        throw Exception("当前没有记录可以删除!");
    m_StoredProc->Close();
    m_StoredProc->ProcedureName="sdTrd_Delete";
    m_StoredProc->Parameters->Clear();
        m_StoredProc->Parameters->CreateParameter("@W_TrdCode",ftString,pdInput,18,b_TrdCode);
    m_StoredProc->ExecProc();
    m_StoredProc->Close();
    DeleteRecord(this->b_TrdCode);
}
//---------------------------------------------------------------------------
void TsdTrd::Assign(TsdTrd *p)
{
    this->SetActionID(p->CurStatus);
    this->m_TrdCode=p->m_TrdCode;
    this->m_TrdName=p->m_TrdName;
    this->m_TrdDesc=p->m_TrdDesc;
    this->BackupValue();
}
//---------------------------------------------------------------------------
void TsdTrd::AssignValue()
{
    TsdTrd *p=(TsdTrd *)Records(CurRecNo);
    Assign(p);
}
//---------------------------------------------------------------------------
int TsdTrd::Query()
{
    AnsiString m_SqlStr;
    m_SqlStr=QueryString;
    if(FilterString.IsEmpty()==false)
        m_SqlStr=m_SqlStr+" where  "+FilterString;
    if(OrderString.IsEmpty()==false)
        m_SqlStr=m_SqlStr+" Order by "+OrderString;
    m_Query->Close();
    m_Query->SQL->Clear();
    m_Query->SQL->Add(m_SqlStr);
    m_Query->Open();
    ClearRecord();
    if(m_Query->RecordCount>0)
    {
        m_Query->First();
        while(!m_Query->Eof)
        {
            BatchLetValue();
            TsdTrd *p=new TsdTrd();
            SetActionID(1);
            p->Assign(this);
            AddRecord((void *)p,p->TrdCode);
            m_Query->Next();
        }
        MoveFirst();
    }
    m_Query->Close();
    return Count;
}
//---------------------------------------------------------------------------
bool TsdTrd::Find(AnsiString WhereStr)
{
    AnsiString m_SqlStr;
    if(WhereStr.IsEmpty()==true)
        throw Exception("查找表达式不能为空");
    m_SqlStr="select * from sdTrd where  "+WhereStr;
    m_Query->Close();
    m_Query->SQL->Clear();
    m_Query->SQL->Add(m_SqlStr);
    m_Query->Open();
    if(m_Query->RecordCount!=1)
    {
        m_Query->Close();
        return false;
    }
    else
    {
        BatchLetValue();
        m_Query->Close();
        return true;
    }
}
//完成

⌨️ 快捷键说明

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