python executmany 사용 및 주의사항
1563 단어 pythonexecutemany
#coding:utf8
conn = MySQLdb.connect(host = “localhost”, user = “root”, passwd = “123456”, db = “myDB”)
cursor = conn.cursor()
sql = “insert into myTable (created_day,name,count) values(%s,%s,%s) ON DUPLICATE KEY UPDATE count=count+values(count)”
args=[("2012-08-27","name1",100),("2012-08-27","name1",200),("2012-08-27","name2",300)]
try:
cursor.executemany(sql, args)
except Exception as e:
print0(“ MySQL: %s :%s” % (sql, e))
finally:
cursor.close()
conn.commit()
conn.close()
여기 args 는 여러 개의 원 조 를 포함 하 는 배열 입 니 다.각 원 조 는 my sql 중의 한 데이터 에 대응 합 니 다.여기 created 에 주의 하 십시오.day 에 대응 하 는%s 에 따옴표 가 없습니다.여기 서 executemany 는 먼저 sql 문 구 를 정규 적 으로%s 와 일치 시 킨 다음 에 이 를 바탕 으로 문자열 을 삽입 처리 할 것 으로 추정 합 니 다.여기에%s 에 따옴표 가 붙 으 면 my sql 에 삽입 하면'0000-00-00〃형식의 오류 날짜 가 발생 할 것 입 니 다.한 번 에 여러 개의 데 이 터 를 삽입 하려 면 여기 서 execute many 를 사용 하 는 것 을 강력 히 추천 합 니 다.자신의 경험 으로 볼 때 한 개의 insert 는 2-3 시간 동안 데 이 터 를 삽입 하고 execute many 를 사용 하 는 데 2-3 초 밖 에 걸 리 지 않 습 니 다!!
여기 서 executemany 와 ON DUPLICATE KEY UPDATE 를 공동으로 사용 할 때 sql 일반 모드,즉 sql="insert into my Table(createdday,name,count)values(%s,%s,%s)ON DUPLICATE KEY UPDATE count=count+%s"에 버그 가 표 시 됩 니 다.
위 에서 말씀 드 린 것 은 편집장 님 께 서 소개 해 주신 python execute many 의 사용 및 주의사항 입 니 다.도움 이 되 셨 으 면 좋 겠 습 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.편집장 님 께 서 바로 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.