python executmany 사용 및 주의사항

1563 단어 pythonexecutemany
executmany 를 사용 하여 데 이 터 를 대량으로 삽입 하려 면 사항 을 주의해 야 합 니 다.

#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 의 사용 및 주의사항 입 니 다.도움 이 되 셨 으 면 좋 겠 습 니 다.궁금 한 점 이 있 으 시 면 메 시 지 를 남 겨 주세요.편집장 님 께 서 바로 답 해 드 리 겠 습 니 다.여기 서도 저희 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기