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

다음 구문에서요... (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]

... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5214Jang...9/4/20198116[DB 테이블의 데이터 변경에 대한 알림 처리] SQL-Server말고 MySQL은 불가능하겠죠? [1]
5213진우8/31/20197390c# 람다 변수 캡쳐 문의 [2]
5212심성보8/29/20199053Clipboard내 여러개의 이미지를 PictureBox로 불러오는 문제 [2]
5211최휘철8/24/20198236CLR20r3 관련된 윈도우 오류입니다. ㅠㅠ 도와주세요. / 아래글 관련하여 관련 파일 올려 드려요^^ [1]파일 다운로드1
5210최휘철8/23/201912154CLR20r3 관련된 윈도우 오류입니다. ㅠㅠ 도와주세요. [5]
5209세퉁8/21/20197795폰트 파일 속성 값을 가져오는 방법 질문 드립니다. [2]파일 다운로드1
5208홍길동8/19/20198593DebugDiag에서 .Net의 Stack Trace를 Windbg에서는 어떻게 볼 수 있나요? [3]
5207민성8/16/20196936네 소스 전체를 올리도록 하겠습니다. [2]파일 다운로드1
5206민성8/14/20197071전 재현 가능하다고 봤는데 다시올리도록 하겠습니다. [1]
5205miny...8/14/20197936안녕하세요 .WPF ListBox시 체크박스가 있는데 체크박스에서 체크가 되었는지 알수 있는 방법이 있을까요? [1]
5204영민8/8/201910709안녕하세요 디버깅시 콘솔창을 띠어서 볼수가 없나요? [7]
5202민성8/6/20197453WPF에서 <Application.Resources에 xaml에 있는 icon 값을 저장하고 xaml에 불러다 사용하고 싶은데요 [1]
5201김대훈8/3/20197080상속시 생성자에 대해 질문드립니다 [3]
5200농상7/30/20199766foreach로 데이터 변경 [2]
5190오리다람7/20/20197168질문드립니다. [3]
5189진우7/19/20197682C# 스레드풀 코어별 실행 문의 [2]
5188황태관7/19/20196905비주얼베이직 2019 실행 할때 마다.. [3]
5187플하7/19/20199732UWP 관련 궁금한 사항에 대해서 [1]
5186김대훈7/14/20198325박싱과 언박싱에 대해 [2]
5185농상7/13/20197188Nullable에 대해서 [1]
5184김대훈7/4/20197074저자님의 책을 다 본후에는 [2]
51837/2/20197777.NET Compact Freamwork 컨트롤러 더블버퍼링 [1]
5182wpf ...7/2/20197964wpf 질문 드립니다. [1]파일 다운로드1
51817/1/20198387DataGridview Doublebuffer 에 대해서 질문드립니다. [2]
5180김대훈6/25/20198423배열과 반복문에서 질문드립니다 [2]
5177농상6/13/20199575멀티스레드 건의 [2]
... 16  17  18  19  20  21  22  23  24  25  26  [27]  28  29  30  ...