SQLite3의 바인딩 함수 패밀리 사용 및 참고 사항 상세 정보
본고에서 여러분께 보여준 코드는 실제적으로 어떻게 Sqlite3의 매개 변수화기를 이용하여 데이터 삽입을 하는지, 업데이트 조작도 할 수 있는지, 당신이 어떻게 놀았는지에 달려 있습니다. 여기에 코드만 열거한 다음에 주의사항을 말씀드리겠습니다.
다음 코드에 문제가 있습니다. 삽입된 것은 틀림없습니다.
INSERT INTO "work" VALUES(' ',' ',NULL,NULL,NULL,NULL,' ',NULL,NULL,110.0,1.0,108.9,NULL,NULL,' ',NULL,NULL,NULL,' ',NULL,NULL,NULL);
문제가 있는 코드를 보십시오.
sqlite3_stmt *stmt;
CString sql = "insert into work values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
int rc = sqlite3_prepare_v2(db, sql.GetString(), -1, &stmt, NULL);
if(rc != SQLITE_OK)
{
MessageBox("sqlite3_prepare_v2 Failed!");
return;
}
count = 0;
p_wnd = PrevWnd;
while(count++ < ID_TOTALCOUNT)
{
CString DbStr;
p_wnd = CWnd::GetNextDlgTabItem(p_wnd, FALSE);
if(p_wnd == NULL)
{
return;
}
p_wnd->GetWindowText(DbStr);
do
{
if(!DbStr.GetLength())
{
rc = sqlite3_bind_null(stmt, count);
break;
}
//
if( count == ID_CHUDANRIQI ||
count == ID_CHUFARIQI ||
count == ID_HUANKUANRIQI ||
count == ID_HUOLIRIQI)
{
CDateTimeCtrl *TimeCtl = (CDateTimeCtrl *)p_wnd;
CString time = DateTimeToString(*TimeCtl);
rc = sqlite3_bind_text(stmt, count, time.GetString(), time.GetLength(), SQLITE_STATIC);
break;
}
else
{
// real
if( count == ID_BAOXIANJINE ||
count == ID_YONGJINBILV ||
count == ID_JINGBAOFEI ||
count == ID_HUANKUANJINE ||
count == ID_LIRUNBILV ||
count == ID_LIRUNJINE)
{
double tMoney = 0.0;
int rtn = sscanf_s(DbStr.GetString(), "%lf", &tMoney);
ASSERT(rtn == 1);
rc = sqlite3_bind_double(stmt, count, tMoney);
}
else
{
char *str = (char *)DbStr.GetString();
int c = strlen(str);
int c1 = DbStr.GetLength();
rc = sqlite3_bind_text(stmt, count, DbStr.GetString(), -1/*DbStr.GetLength()*/, SQLITE_STATIC);
}
}
}while(0);
if(rc != SQLITE_OK)
{
CString ErrStr = sqlite3_errstr(rc);
MessageBox(ErrStr);
return;
}
}
rc = sqlite3_step(stmt);
if(rc != SQLITE_DONE)
{
if(rc == SQLITE_ERROR)
{
CString DbErr;
DbErr.Format("Sql Insert failed, %s", sqlite3_errmsg(db));
MessageBox(DbErr);
}
else
{
MessageBox("sqlite3_step Failed!");
}
}
sqlite3_finalize(stmt);
왜죠?왜냐하면, sqlite3_bind_text 귀속된 text, 해야 할 일:
rc = sqlite3_step(stmt);
때 통일적으로 제출하고 위의 코드가 사용하는 임시 변수rc = sqlite3_step(stmt);
는 존재하지 않았다.그래서 코드를 어지럽히는 것도 정상이다.다음과 같이 수정합니다.
sqlite3_stmt *stmt;
CString sql = "insert into work values (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
int rc = sqlite3_prepare_v2(db, sql.GetString(), -1, &stmt, NULL);
if(rc != SQLITE_OK)
{
MessageBox("sqlite3_prepare_v2 Failed!");
return;
}
count = 0;
p_wnd = PrevWnd;
CString DbStr[ID_TOTALCOUNT + 1];
while(count++ < ID_TOTALCOUNT)
{
DbStr[count].Empty();
p_wnd = CWnd::GetNextDlgTabItem(p_wnd, FALSE);
if(p_wnd == NULL)
{
return;
}
p_wnd->GetWindowText(DbStr[count]);
do
{
if(!DbStr[count].GetLength())
{
rc = sqlite3_bind_null(stmt, count);
break;
}
//
if( count == ID_CHUDANRIQI ||
count == ID_CHUFARIQI ||
count == ID_HUANKUANRIQI ||
count == ID_HUOLIRIQI)
{
CDateTimeCtrl *TimeCtl = (CDateTimeCtrl *)p_wnd;
CString time = DateTimeToString(*TimeCtl);
DbStr[count] = time;
rc = sqlite3_bind_text(stmt, count, time.GetString(), time.GetLength(), SQLITE_STATIC);
}
else
{
// real
if( count == ID_BAOXIANJINE ||
count == ID_YONGJINBILV ||
count == ID_JINGBAOFEI ||
count == ID_HUANKUANJINE ||
count == ID_LIRUNBILV ||
count == ID_LIRUNJINE)
{
double tMoney = 0.0;
int rtn = sscanf_s(DbStr[count].GetString(), "%lf", &tMoney);
ASSERT(rtn == 1);
rc = sqlite3_bind_double(stmt, count, tMoney);
}
else
{
rc = sqlite3_bind_text(stmt, count, DbStr[count].GetString(), DbStr[count].GetLength(), SQLITE_STATIC);
}
}
}while(0);
if(rc != SQLITE_OK)
{
CString ErrStr = sqlite3_errstr(rc);
MessageBox(ErrStr);
return;
}
}
rc = sqlite3_step(stmt);
if(rc != SQLITE_DONE)
{
if(rc == SQLITE_ERROR)
{
CString DbErr;
DbErr.Format("Sql Insert failed, %s", sqlite3_errmsg(db));
MessageBox(DbErr);
}
else
{
MessageBox("sqlite3_step Failed!");
}
}
sqlite3_finalize(stmt);
데이터베이스에서 만든 sql 구문을 첨부합니다.
sqlite> .dump work
PRAGMA foreign_keys=OFF;
BEGIN TRANSACTION;
CREATE TABLE work (baodanhao text unique primary key , chudanriqi text,qudao text,lianxiren text,xiaoshou text,beibaorenxingming text,chufar
iqi text,baoxianpinpai text,baoxianjihua text,baoxianjine real,yongjinbilv real,jingbaofei real,huankuanfangshi text,haikuanjine real,huanku
anriqi text,shifouquane text,lirunbilv real,lirunjine real,huoliriqi text,fapiaojisong text,shifubaoxiangongsi text,beizhu text);
총결산이상은 바로 이 글의 전체 내용입니다. 본고의 내용이 여러분의 학습이나 업무에 일정한 도움을 줄 수 있기를 바랍니다. 만약에 의문이 있으면 여러분은 댓글을 남겨 교류할 수 있습니다. 저희에 대한 지지에 감사드립니다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
flask와 sqlite3 연결Flask를 사용하여 1에서 응용 프로그램을 만들고 필요한 기술을 배울 수 있도록 정리하고 있습니다. 데이터베이스를 사용해보십시오 ← ★ 현재 여기 데이터베이스 설치 및 설정 이번에는 SQLite를 사용합니다. ※ ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.