Microsoft MVP성태의 닷넷 이야기
mysql insert where not exists [링크 복사], [링크+제목 복사],
조회: 19975
글쓴 사람
힘찬도약
홈페이지
첨부 파일
 

다음 구문에서요... (primary key가 없는 상태이구요..)

----------------------------------
sql = "INSERT INTO logger_rain_acc (ID, RainDate, H20, DaySum) " +
      "select * from (select @id_3, @RainDate, @r_abs_hour_3, @DaySum) as tmp " +
      "where not exists (select ID from logger_rain_acc where ID=@id_3 and RainDate=@RainDate);";

cmd.ExecuteNonQuery();

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

조건에 맞는 컬럼이 없는 상태에서요.. insert가 되어야 하는 상황인데,
select * from (select @id_3, @RainDate, @r_abs_hour_3, @DaySum) as tmp 라고 쓰면 안써지구요..
select * from (select @id_3, @RainDate, 77, @DaySum) as tmp 라고 쓰면 써지는데 이 차이가 뭘까요?
(이 값을 변수로 넣어야 하거든요..)

참고로, ID : Varchar(15) / RDate : Varchar(10) / H20 : Int(2) / DaySum: Int(2) 입니다.

sql = "UPDATE logger_rain_acc SET H20=@r_abs_hour_3, DaySum=@DaySum ) " +
      "Where ID=@id_3 and RainDate=@RainDate;";
이 업데이트는 잘 됩니다. (똑같은 @r_abs_hour_3 변수를 썼는데요.)

sql = "INSERT INTO logger_rain_acc (ID, RainDate, H00, DaySum) VALUES(@id, @RainDate, @r_abs_hour, @DaySum);";
이 인서트 구문도 잘 됩니다.








[최초 등록일: ]
[최종 수정일: 10/31/2015]


비밀번호

댓글 작성자
 



2015-11-02 01시10분
안써진다는 것의 의미가??? 그냥 0 또는 null로 들어간다는 건가요?
정성태
2015-11-02 09시39분
[힘찬도약] 컬럼에 값이 Update가 안된다는 의미입니다
[guest]
2015-11-02 09시40분
[힘찬도약] 0으로도 안써집니다.

[guest]
2015-11-02 09시55분
[힘찬도약] Primary key가 하나도 없을때,
Mysql에서 insert if not exists or update 구문 쓰는게 가능한지?
기존에 썼다고는 하는데 어떻게 구문을 써야할지 모르겠습니다.
[guest]
2015-11-03 12시44분
문제를 보면 느낌상 딱히 외부에서 짚어줄 만한 것은 없고 문맥상 '힘찬도약'님이 해결해야 할 듯 합니다. 딱히 C# 관련 문제도 아니고... 더 이상 답변드릴 내용이 없군요. 나중에 해결되시면 어떤 문제였는지 덧글 좀 남겨주세요. ^^
정성태
2015-11-04 12시28분
[힘찬도약] sql = "INSERT INTO logger_rain_acc (ID, RainDate) " +
       "select * from (select @id_3, @RainDate) as tmp " +
       "where not exists (select ID from logger_rain_acc where ID=@id_3 and RainDate=@RainDate);";

위에서 ID와 RainDate 두개의 컬럼만 변수로 넣으니 정상동작을 합니다. (여러번 테스트해봐도)
다만, 왜 4개를 쓰면 (int type) insert가 안되는지 원인은 아직 잘 모르겠습니다. ^^

늘 관심있게 봐주셔서 감사드립니다.
[guest]

1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5946SunN...8/5/20248787TaskDefinition 에서 사용저가로그온상관없이실행 [3]파일 다운로드1
5945SunN...8/3/20248868윈도우 작업스케줄러 [1]
5944roya8/1/20248969C# dll을 C++ 프로젝트에서 사용을 하고 싶은데, 레지스트리 등록 없이 가능한걸까요?? [2]
5943SunN...8/1/20248878윈도우C#에서 리눅스FTP로 업로드 및 리눅스에 폴더생성(WindowsOS에서C#으로) [3]
5942vict...7/24/20248253dll 을 c#에서 쓰고 싶습니다 [1]
5941vict...7/17/202410959DependencyObject와 같은 스레드에서 DependencySource를 만들어야 합니다. 오류 [2]
5940ckm7/16/202411251선생님 안녕하세요 async await 교착 관련 질문입니다 [1]
5939괴물신인7/9/202411338템플릿 대체할수있는방법이 있을까요? [6]
5938씨제바보7/5/20249325책 질문드립니다. [1]
5937Thor... donator5/27/202410812C# 12 는 전자책이 언제쯤 나오게 될까요? [1]
5936ds4/26/202411809활성화 되어 있는 커뮤니티 발견하게 되어 기분이 좋습니다. 자주 놀러 올께요. (내용 없습니다. [2]
5935양승조 donator4/25/202411287Reflection 관련 질문 드립니다. [5]파일 다운로드1
5934양승조 donator4/24/202410587Reflection 관련 질문 드립니다. [1]
5933vict...4/23/202410335cpp 라이브러리 디버깅 방법 문의 드립니다. [1]
5932EK4/12/20249979다음 제네릭에서 널익셉션이 뜨는 이유를 알수있을까요? [1]
5931이대희4/2/202411162Windows 앱 SDK C# 템플릿의 용도가 무엇인지요? [1]
5930vict...2/22/202413141ef core, FromSqlRaw 맵핑 질문입니다. [4]
5929a2/17/202411887.Net 8 에서 디버거 변경 [1]
5928vict...2/5/202412558wpf에서 대량 데이터 보여주는 방법 추천 부탁드립니다. [1]
5926엄태영1/12/202413266잘못된 Task 사용으로 인한 데드락 관련 질문 입니다. [3]
5925Euni...12/22/202311496Visual Studio에서 nodejs 사용시 npm install -g @vue/cli 실행시 오류 [1]
5924Euni...12/21/202312557Visual Studio에서 nodejs 사용시 C:\Program Files\nodejs\\node.exe" "C:\Program Files\nodejs\\node_modules\npm\bin\npm-cli.js" prefix -g 를 찾지 못하는 설치 오류 [2]
5923정두호12/4/202311875MSSQL 데이터 전송과 공유폴더의 데이터 전송 차이점 [1]
5922Heeg...10/27/202313956C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]
5921한예지 donator10/3/202313945마샬링 정의 및 목적이 궁금합니다. [5]
5920한예지 donator10/3/202313718C#과 WIN32 API 관계 질문드립니다. [4]
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...