1. 기본 데이터베이스 작업
1. 데이터베이스에 중국어 쓰기를 허용하려면 데이터베이스 생성 시 다음 명령을 사용하면 됩니다
CREATE database zcl charset utf8;
2. 학생 테이블 구조 보기
desc students;
3. 학생 테이블 구조를 만드는 문 보기
show create table students;
4. 데이터베이스 삭제
drop database zcl;
5. 새 필드 만들기
alter table students add column nal char(64);
추신: 저는 위의 "간단한 설명 + 코드" 블로그를 정말 싫어합니다. 사실 그 당시 mysql 터미널에서 예제를 많이 작성했는데, 당시 컴퓨터에서 동영상 시청 소프트웨어가 실행되고 있었기 때문에 Ctrl+C/V를 할 수 없었습니다. 이제 너무 게으릅니다 ㅎㅎ~~
2. Python 데이터베이스 연결
python3은 더 이상 mysqldb를 지원하지 않습니다. 대체 모듈은 PyMySQL입니다. 이 문서의 예제는 python3.4 환경에 있습니다.
1. pymysql 모듈을 설치합니다
pip3 install pymysql
2. 데이터베이스 및 데이터 삽입 예
import pymysql #生成实例,连接数据库zcl conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl') #生成游标,当前实例所处状态 cur = conn.cursor() #插入数据 reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Jack','man',25,1351234,"CN")) reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Mary','female',18,1341234,"USA")) conn.commit() #实例提交命令 cur.close() conn.close() print(reCount)
결과 보기:
mysql> select* from students; +----+------+-----+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+------+-----+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | +----+------+-----+-----+-------------+------+ rows in set
3. 데이터 가져오기
import pymysql conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl') cur = conn.cursor() reCount = cur.execute('select* from students') res = cur.fetchone() #获取一条数据 res2 = cur.fetchmany(3) #获取3条数据 res3 = cur.fetchall() #获取所有(元组格式) print(res) print(res2) print(res3) conn.commit() cur.close() conn.close()
출력:
(1, 'zcl', 'man', 22, '15622341234', None) ((2, 'alex', 'man', 30, '15622341235', None), (5, 'Jack', 'man', 25, '1351234', 'CN'), (6, 'Mary', 'female', 18, '1341234', 'USA')) ()
3. 트랜잭션 롤백
데이터가 데이터베이스에 기록되기 전에 트랜잭션 롤백이 실행됩니다. 롤백 인스턴스가 conn.commit() 명령을 제출하기 전에 conn.rollback()을 롤백합니다. 데이터를 제출하지 않는 한 롤백이 가능하지만 롤백 후 ID가 자동 증가됩니다. 다음 예를 참조하세요.
3개의 데이터 삽입(트랜잭션 롤백 참고):
import pymysql #连接数据库zcl conn=pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl') #生成游标,当前实例所处状态 cur=conn.cursor() #插入数据 reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Jack', 'man', 25, 1351234, "CN")) reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s,%s,%s,%s,%s)', ('Jack2', 'man', 25, 1351234, "CN")) reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Mary', 'female', 18, 1341234, "USA")) conn.rollback() #事务回滚 conn.commit() #实例提交命令 cur.close() conn.close() print(reCount)
실행되지 않음 명령 전과 명령 실행 후(롤백 작업 포함)(ID 번호 참고): 위 코드를 실행하지 않은 것과 위 코드를 실행한 결과는 동일합니다. 트랜잭션이 롤백되었기 때문에 학생 테이블은 데이터를 추가하지 마세요!
mysql> select* from students; +----+------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | +----+------+--------+-----+-------------+------+ rows in set
명령 실행 후(롤백 작업 제외): 위 코드의 11번째 줄을 주석 처리하세요.
mysql> select* from students; +----+-------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+-------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | | 10 | Jack | man | 25 | 1351234 | CN | | 11 | Jack2 | man | 25 | 1351234 | CN | | 12 | Mary | female | 18 | 1341234 | USA | +----+-------+--------+-----+-------------+------+ rows in set
요약: 트랜잭션이 롤백되더라도 ID는 계속 증가하고 롤백으로 인해 취소되지는 않지만, 이는 데이터의 일관성에 영향을 주지 않습니다(기본 원리는 모르겠습니다~)
4. 데이터를 일괄 삽입
import pymysql #连接数据库zcl conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl') #生成游标,当前实例所处状态 cur = conn.cursor() li = [ ("cjy","man",18,1562234,"USA"), ("cjy2","man",18,1562235,"USA"), ("cjy3","man",18,1562235,"USA"), ("cjy4","man",18,1562235,"USA"), ("cjy5","man",18,1562235,"USA"), ] #插入数据 reCount = cur.executemany('insert into students(name,sex,age,tel,nal) values(%s,%s,%s,%s,%s)', li) #conn.rollback() #事务回滚 conn.commit() #实例提交命令 cur.close() conn.close() print(reCount)
pycharm에서 출력: 5
mysql 터미널 디스플레이:
mysql> select* from students; #插入数据前 +----+-------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+-------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | | 10 | Jack | man | 25 | 1351234 | CN | | 11 | Jack2 | man | 25 | 1351234 | CN | | 12 | Mary | female | 18 | 1341234 | USA | +----+-------+--------+-----+-------------+------+ rows in set mysql> mysql> select* from students; #插入数据后 +----+-------+--------+-----+-------------+------+ | id | name | sex | age | tel | nal | +----+-------+--------+-----+-------------+------+ | 1 | zcl | man | 22 | 15622341234 | NULL | | 2 | alex | man | 30 | 15622341235 | NULL | | 5 | Jack | man | 25 | 1351234 | CN | | 6 | Mary | female | 18 | 1341234 | USA | | 10 | Jack | man | 25 | 1351234 | CN | | 11 | Jack2 | man | 25 | 1351234 | CN | | 12 | Mary | female | 18 | 1341234 | USA | | 13 | cjy | man | 18 | 1562234 | USA | | 14 | cjy2 | man | 18 | 1562235 | USA | | 15 | cjy3 | man | 18 | 1562235 | USA | | 16 | cjy4 | man | 18 | 1562235 | USA | | 17 | cjy5 | man | 18 | 1562235 | USA | +----+-------+--------+-----+-------------+------+ rows in set
mysql 데이터베이스 운영과 관련된 더 많은 기사를 보려면 python, PHP 중국어 사이트를 주목해주세요!