| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 | // FormatSQL.cpp: implementation of the CFormatSQL class.////////////////////////////////////////////////////////////////////////#include "stdafx.h"#include "cp_main.h"#include "FormatSQL.h"#ifdef _DEBUG#undef THIS_FILEstatic char THIS_FILE[]=__FILE__;#define new DEBUG_NEW#endif//////////////////////////////////////////////////////////////////////// Construction/Destruction//////////////////////////////////////////////////////////////////////CFormatSQL::CFormatSQL(){}CFormatSQL::~CFormatSQL(){}void CFormatSQL::Parse(CString cs){	//Replace all single ' with a double '	cs.Replace("'", "''");	//Replace all "|" with a space	cs.Replace("|", " ");	int nLength = cs.GetLength();	CString csCurrentWord;	bool bInQuotes = false;	eSpecialTypes eNotValue = eINVALID;	eSpecialTypes eOrValue = eAND;	for(int i = 0; i < nLength; i++)	{		switch(cs[i])		{		case '"':			bInQuotes = !bInQuotes;			break;		case ' ':			if(bInQuotes == false)			{				eSpecialTypes sp = ConvetToKey(csCurrentWord);				switch(sp)				{				case eNOT:					eNotValue = sp;					break;				case eOR:				case eAND:					eOrValue = sp;					break;				default:					AddToSQL(csCurrentWord, eNotValue, eOrValue);				}				csCurrentWord = "";			}			else			{				csCurrentWord += cs[i];			}			break;		default:			csCurrentWord += cs[i];		}	}	if(csCurrentWord.GetLength() > 0)		AddToSQL(csCurrentWord, eNotValue, eOrValue);}CFormatSQL::eSpecialTypes CFormatSQL::ConvetToKey(CString cs){	cs.MakeUpper();	if(cs == "NOT" || 		cs == "!")	{		return eNOT;	}	else if(cs == "OR")	{		return eOR;	}	else if(cs == "AND")	{		return eAND;	}	return eINVALID;}CString CFormatSQL::GetKeyWordString(eSpecialTypes eKeyWord){	switch(eKeyWord)	{	case eNOT:		return " NOT ";	case eAND:		return " AND ";	case eOR:		return " OR ";	case eINVALID:		return " ";	}	return " ";}bool CFormatSQL::AddToSQL(CString cs, eSpecialTypes &eNOTValue, eSpecialTypes &eORValue){	CString csThisSQL;	cs.TrimLeft();	cs.TrimRight();	if(cs.Find("*") < 0 && cs.Find("?") < 0)	{		csThisSQL.Format("%s%sLIKE \'*%s*\'", m_csVariable, GetKeyWordString(eNOTValue), cs);	}	else	{		csThisSQL.Format("%s%sLIKE \'%s\'", m_csVariable, GetKeyWordString(eNOTValue), cs);	}	if(m_csWhere.GetLength() > 0)	{		m_csWhere += GetKeyWordString(eORValue) + csThisSQL;	}	else	{		m_csWhere = csThisSQL;	}	eNOTValue = eINVALID;	eORValue = eAND;	return true;}
 |