Microsoft MVP성태의 닷넷 이야기
SQlike Like 구문 - 1시간째 인데 안되네요 [링크 복사], [링크+제목 복사],
조회: 10501
글쓴 사람
guest
홈페이지
첨부 파일
 

DB Browser for SQLite에서는 잘 작동합니다
Update stoptable SET timestop = '202303071755' WHERE loadtime LIKE '20230307%'

그런데 VS에서는 작동하지 않네요
오류는 나지 않는데 Update가 안되네요

string today = DateTime.Now.ToString();
                            
string UPDATECmd = "Update stoptable SET timestop = @timestop WHERE loadtime LIKE @today + '%'"; //date

using (var cmd = new SQLiteCommand(UPDATECmd, sqlite_conn))
{
   cmd.Parameters.AddWithValue("@today", today);
   cmd.Parameters.AddWithValue("@timestop", DateTime.Now.ToString("HHmmss"));

   cmd.ExecuteNonQuery();
}








[최초 등록일: ]
[최종 수정일: 3/7/2023]


비밀번호

댓글 작성자
 



2023-03-07 06시28분
잘 보시면 % 문자 있는 곳의 인용부호가 잘못돼 있습니다.
정성태
2023-03-07 06시37분
[guest] 시도 해본 것은 다음과 같습니다 모두 실패
"Update stophero SET timestop = @timestop WHERE loadtime LIKE @today%";
"Update stophero SET timestop = @timestop WHERE loadtime LIKE @today" + "%";
"Update stophero SET timestop = @timestop WHERE loadtime LIKE @today || '%' ";

사실 이번 시도는 저번에 1주일 실패하고 매뉴얼화해 놓은 것을 참고로 한 것이라
더 좌절감이 생기네요 ㅜㅜ
[guest]
2023-03-07 07시20분
어렵게 생각하지 마시고 변수에 값을 다 치환해보세요. 정상 동작하는 그 코드랑 다른 점을 맞춰주시면 됩니다.

예를 들어, @timestop == '2', @today== '10'으로 치환해 보면,

Update stoptable SET timestop = '2' WHERE loadtime LIKE '10' + '%'

Update stophero SET timestop = '2' WHERE loadtime LIKE '10'%
Update stophero SET timestop = '2' WHERE loadtime LIKE '10'%
Update stophero SET timestop = '2' WHERE loadtime LIKE '10' || '%'

이런 쿼리가 되는데 오류가 나는 것이 당연합니다.
정성태
2023-03-07 09시28분
[guest] C# sqlite
VS에서 아래 2개 모두 실패했습니다 답 좀 알려주시면 안되나요 ㅜㅜ
"Update stophero SET timestop = @timestop WHERE loadtime LIKE @today%";
"Update stophero SET timestop = @timestop WHERE loadtime LIKE '@today%'";
[guest]
2023-03-07 09시32분
[guest] 이거는 저번에 작동해서 메모해놓은 것인데 지금은 작동하지 않네요
"Update stoptable SET timestop = @timestop WHERE loadtime LIKE @today";
using (var cmd = new SQLiteCommand(UPDATECmd, sqlite_conn))
{
   cmd.Parameters.AddWithValue("@today", today + "%");
[guest]
2023-03-08 09시23분
제가 신경써서 살펴보지 않았군요. ^^; 사과드립니다.

보니까... 처음 글을 올려주셨을 때의 쿼리가 동작해야 하는데요. 질문을 참고했을 때, "오류는 나지 않는다고" 하셨는데, 그렇다면 쿼리가 정상적으로 수행된 것은 맞습니다. 그런데, DateTime.Now.ToString()은 "20230307"과 같은 문자열을 돌려주지 않습니다. 혹시 그걸 알고 쿼리를 쓰신 건가요?
정성태
2023-03-08 11시31분
[guest] 거기서 에러가 난 것같습니다 ㅜㅜ 금시초문입니다 15년째 취미코딩을 하는 중입니다만 ㅜㅜ
DateTime.Now.String()이 string이 아니라굽쇼 ㅜㅜ
살펴보겠습니다
Sqlite는 UPDATE 구문이 참 예민하더라고요 Sqlite에서 JAL 설정도 해줘야 하고
Transection 등등
[guest]
2023-03-08 11시35분
[guest] 감사합니다
항상 찍어봐야 되는데 익숙한게 정확히 아는게 아니거늘
안다고 밀어붙이니 ㅜㅜ
언제나 겸손 ㅜㅜ 해결될 것같습니다 ㅜㅜ
[guest]
2023-03-08 11시44분
DateTime.Now.ToString()은 string이 맞습니다. 단지, 그 문자열이 "20230307" 형식의 문자열이 아니라는 것입니다.

그런 식으로 나오게 하려면 포맷팅을 해야 하는데 이에 대해서는 다음의 글을 참고하세요.

날짜: 표준 Format Specifier
; https://www.csharpstudy.com/Tip/Tip-datetime-format.aspx
정성태
2023-03-08 12시43분
[guest] 말귀를 못알아들어 죄송
20230307이 아니라 2023/03/07이란 말씀이지요 ㅜㅜ
수고하세요
[guest]
2023-03-08 07시13분
아래와 같이,

Console.WriteLine(DateTime.Now.ToString()); // 출력 결과: 2023-03-08 오후 7:10:34

출력이 되는데, 당연히 "2023-03-08 오후 7:10:34" 문자열을 쿼리에 적용하고 싶지는 않았을 것입니다.

Update stoptable SET timestop = '2' WHERE loadtime LIKE '2023-03-08 오후 7:10:34' + '%'

--------------

비록 취미 코딩이라고는 해도, 제 생각에는 (꼭 제 책이 아니더라도) 기본서 하나 정도는 읽어보시길 바랍니다. 언뜻 초기 시간을 투자하는 듯해도, 위와 같은 문제로 헤매는 시간을 고려해 보면 나중에는 틀림없이 투자한 시간만큼의 값어치를 할 것입니다.
정성태
2023-03-09 04시24분
[지나가던사람] DateTime.Now.ToString("yyyyMMdd")

쿼리를 로그로 한 번이라도 찍어보셨거나 디버깅으로 보았다면 나오지 않았을 질문인데...
[guest]
2023-03-09 06시35분
[guest] ㅋ 맞아요 DateTime.Now.ToString()이 20231022 이라고 확신
다른 Update쪽에 신경쓰다보니
[guest]

... 31  32  33  34  35  36  37  38  39  [40]  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4883솔솔8/30/201716077dataview에서 select한 index 가져오기 [1]
4882user8/30/201718403UI 변경 작업 여러개를 동시에 사용하려면 어떻게 해야되나요 ?? [7]
4884user8/31/201715389    답변글 [답변]: UI 변경 작업 여러개를 동시에 사용하려면 어떻게 해야되나요 ??파일 다운로드1
4881kmi8/30/201715421진행속도가 중간에 더뎌지는 문제가 있는데 해결할 수 있는 방법이 있나 궁금합니다. [3]
4880김호종8/29/201715744HTTP JSON POST 관련 질문 드립니다. [1]
4879aos8/27/201716544DateTime 표시할 때 포맷 설정시 밀리초까지 포함하는 법이 궁금합니다 [1]
4878heyh...8/25/201716448프로세스의 프로세스 찾기(?) [2]
4877강준8/24/201715533SQLite journal_mode=wal 관련하여 질문드립니다. [1]
4876heyh...8/23/201716108프로세스 초기화하기 [1]
4874ho8/22/201715503파일 확장자명을 이용해 파일의 실행 프로그램의 전체 경로를 얻어 올 수 있을까요? [1]
4875ho8/23/201716839    답변글 [답변]: 파일 확장자명을 이용해 파일의 실행 프로그램의 전체 경로를 얻어 올 수 있을까요? [1]
4873kmi8/21/201718013전역 변수를 쓰지 않고 여러 군데에서 같은 변수를 공용하는 방법이 궁금합니다. [4]
4872abcd8/18/201716669프로세스를 초기화 하는 명령어도 있나요? [1]
4871kmi8/17/201718542메모리 부족으로 종료되는 현상의 여러가지 이유가 무엇인지 궁금합니다. [2]
4870heyh...8/14/201716831프로그램 실행시 중복일 때 버튼 색깔 원래대로 돌리기 [1]
4868kmi8/4/201716076string[] 에 Reverse 적용방법 질문해봅니다 [3]
4867heyh...8/4/201715474EventHandler에 관한 [1]
486610년차8/3/201715921dsoframer axframer open시 기존 오픈되어있는 엑셀을 먹어버리는 현상 [1]
4865heyh...7/31/201717535클릭원스로 배포 한 프로젝트가 끝났는지 알 수 있는 방법 [8]
4864초보자7/28/201716736DllIImport질문 드립니다. [1]
4863다연아빠7/23/201717396전역 예외처리에 대해 질문있습니다. [3]
4861라르크7/17/201723930window form 예제 따라하는 중인데 12.3 서비스 응용 프로그램에서 진행이 안됩니다. [3]파일 다운로드1
4859heyh...7/10/201717539다른 환경에서 실행하기 [1]
4858heyh...7/10/201716594Clickonce update에 관한질문입니다. [1]
4857heyh...7/7/201717290제가 여태까지 작성한 보고서입니다. [2]파일 다운로드1
4856heyh...7/6/201715672성태님 다른질문입니다. [4]
... 31  32  33  34  35  36  37  38  39  [40]  41  42  43  44  45  ...