이유
최근에 저는 온라인 페이지를 크롤링하는 데 필요한 작은 도구를 작업하고 있습니다. 그런 다음 구문 분석하십시오. 결과를 데이터베이스에 넣습니다.
저는 이 분야에 Python이 장점이 있다는 것을 알고 선택했습니다.
서버에 mysql이 설치되어 있어서 자연스럽게 사용하게 되네요. 데이터베이스를 운영하면서 많은 문제가 발생했습니다. 여러분의 상호 격려를 위해 여기에 기록하겠습니다.
Python에서 mysql 호출
Baidu는 MySQLdb를 통해 데이터베이스 작업을 수행할 수 있습니다. 설명서를 확인하고 Python이 mysql의 c 언어 API를 직접 구현하는 mysql을 제공한다는 것을 알아보세요. MySQLdb는 더 높은 수준의 캡슐화이므로 사용하기가 더 편리합니다. mysql을 사용할 수도 있지만 더 좋은 방법은 MySQLdb를 사용하는 것입니다.
설치 중 발생하는 문제
http://sourceforge.net/projects/mysql-python/ 페이지에서 다운로드할 수 있습니다. 최신 버전의 MySQLdb의 경우, 압축 해제 후 설치 실행 시 일부 문제가 발생할 수 있습니다.
Python setup.py 빌드를 통해 설치를 실행하면 No module name setuptools라는 메시지가 표시됩니다
해결 방법, 설치
sudo apt-get install python-setuptools
다시 실행해도 여전히 mysql_config를 찾을 수 없다는 오류가 발생할 수 있습니다
이때 mysqld-dev를 설치해야 합니다
sudo apt-get install libmysqld-dev
다시 실행하면 계속 발생할 수 있습니다. 오류가 발생했습니다. 이와 같은 `
Building 'mysql' 확장 gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -Dversion_info=(1,2,3, ' 최종',0) -Dversion=1.2.3 -I/usr/include/mysql -I/usr/include/python2.7 -c mysql.c -o build/temp.linux-i686-2.7/mysql.o - DBIG_JOINS=1 -fno-strict-aliasing -DUNIV_LINUX -DUNIV_LINUX mysql.c:29:0에 포함된 파일: pymemcompat.h:10:20: 치명적인 오류: Python.h: 해당 파일 또는 디렉터리가 없습니다
솔루션
sudo apt-get install python-dev
이 단계는 Python용 개발 헤더 파일을 설치하는 단계입니다.
기본적으로 처음 세 가지 방법 이후에는 다른 문제가 발생하지 않습니다.
단, mysql은 직접 설치했다고 가정하겠습니다. 또한, lib 파일이 /usr/local/lib 아래에 위치하지 않으면 오류가 보고됩니다.
해결 방법은 파일을 이 폴더에 소프트 링크하거나 시스템의 /etc/ld.so.cnf 파일을 수정하고 lib가 있는 폴더를 배치하는 것입니다. 두 가지 방법 모두 작동합니다. 그런 다음 ldconfig에서 적용되도록 하십시오.
예를 들어 첫 번째 방법인 ln -s /usr/local/mysql/lib/mysql/libmysqlclient* /usr/lib
실제 사용
을 소개합니다. MySQLdb 라이브러리
MySQLdb 가져오기
데이터베이스에 연결
conn=MySQLdb.connect(host="localhost",user="root",passwd="sa",db ="mytable ",charset="utf8")
제공된 연결 메소드는 데이터베이스와의 연결을 설정하는 데 사용되며 여러 매개변수를 수신하고 연결 개체를 반환합니다.
명령문을 실행합니다. 결과를 얻습니다
Cursor=conn.cursor() n=cursor.execute(sql,param)
먼저 연결 객체를 사용하여 커서 객체를 얻습니다. 커서가 제공하는 메서드를 사용하여 작업합니다. 이 메서드에는 두 가지 주요 범주가 있습니다: 1. 명령 실행, 2. 반환 값 수신
이에 대해서는 나중에 자세히 설명하겠습니다. 여기서는 알 수 없음
끝. 데이터베이스 연결 닫기
포인터 개체와 연결 개체를 별도로 닫아야 합니다.
Cursor.close()
conn.close라는 이름의 메서드가 있습니다. ()
자주 사용하는 작업 API
트랜잭션 작업 지원, 표준 메서드 commit() submit
rollback()rollback
커서가 사용하는 메서드 실행 명령:
callproc(self, procname, args): 저장 프로시저를 실행하는 데 사용되는 매개변수는 저장 프로시저 이름과 매개변수 목록이며, 반환 값은 영향을 받는 행의 수입니다.
실행( self, query, args): 수신된 매개변수는 SQL 문 자체이며 반환 값은 영향을 받은 행의 수입니다.
executemany(self , query, args): 단일 SQL 문을 실행하지만 매개변수 목록의 매개변수를 반복적으로 실행하고 반환 값은 영향을 받은 행 수입니다. nextset(self): 다음 결과 집합으로 이동
메서드 반환 값을 받기 위해 커서에 사용됩니다.
fetchall(self): 반환된 모든 결과 행을 받습니다.
fetchmany(self, size=None): 크기 반환 결과 행을 받습니다. size 값이 반환된 결과 행보다 큽니다.
fetchone(self):
스크롤(self, value, mode='relative'): 포인터를 특정 행으로 이동합니다. mode='relative'인 경우 현재 행에서 값 막대를 이동한다는 의미입니다. mode='absolute'인 경우 첫 번째 행에서 값 막대를 이동한다는 의미입니다.
끝에 문장 삽입: 🎜>
컴퓨터가 ubuntu14.04로 업그레이드되고 다시 설치되었습니다. 이전 블로그 저장소가 사라지고 github에서 다시 가져왔습니다. 문제가 발생했습니다. 파일을 삭제했더니 이 글이 거의 없어졌습니다. 이제라도 이 글을 읽을 수 있어서 다행이다.