백엔드 개발 파이썬 튜토리얼 Python에서 SQLite 데이터베이스를 작동하는 단계에 대한 자세한 설명

Python에서 SQLite 데이터베이스를 작동하는 단계에 대한 자세한 설명

Jun 18, 2017 am 11:22 AM
python sqlite ~에 대한 작동하다 데이터 베이스

이 글은 주로 Python이 SQLite 데이터베이스를 운영하는 방법을 소개합니다. Python의 sqlite 데이터베이스 모듈 설치에 대한 자세한 분석과 sqlite 데이터베이스에 대한 일반적인 운영 기술을 제공합니다.

이 글의 예는 다음과 같습니다. Python을 사용하여 SQLite 데이터베이스 방식을 운영합니다. 참조를 위해 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

SQLite에 대한 간략한 소개

SQLite 데이터베이스는 매우 작은 임베디드 오픈 소스 데이터베이스 소프트웨어로, 독립적인 유지 관리 프로세스가 없으며 모든 유지 관리가 필요하지 않습니다. 프로그램 자체에서 나옵니다. ACID를 준수하는 관계형 데이터베이스 관리 시스템으로, 임베디드 장치에서 매우 낮은 리소스를 차지하도록 설계되었습니다. 충분한. Windows/Linux/Unix와 같은 주류 운영 체제를 지원할 수 있으며 Tcl, C#, PHP, Java 등과 같은 많은 프로그래밍 언어 및 ODBC 인터페이스와 결합할 수 있습니다. 또한 두 가지 개방형 인터페이스와 비교됩니다. MySQL 및 PostgreSQL의 소스 세계에서는 유명한 데이터베이스 관리 시스템 중 처리 속도가 가장 빠릅니다. SQLite의 첫 번째 알파 버전은 2000년 5월에 탄생했습니다. 이제 10년이 지났으며 SQLite도 SQLite 3 버전이 출시되었습니다.

설치 및 사용

1. Python SQLITE 데이터베이스 모듈 가져오기

Python2.5 이후에는 SQLite3이 내장되어 내장 모듈이 됩니다. ~


import sqlite3
로그인 후 복사

2. 데이터베이스 생성/열기

연결 함수 호출 시 라이브러리 이름을 지정하고, 존재하지 않으면 데이터베이스를 직접 엽니다. 새 것을 열고 열어보세요.


cx = sqlite3.connect("E:/test.db")
로그인 후 복사

메모리에 데이터베이스를 생성할 수도 있습니다.


con = sqlite3.connect(":memory:")
로그인 후 복사

3. 데이터베이스 연결 개체

데이터베이스를 열 때 반환되는 개체 cx는 다음 작업을 포함할 수 있는 데이터베이스 연결 개체입니다. )- - 트랜잭션 롤백

3 close()--데이터베이스 연결 닫기

4cursor()--커서 생성

commit()과 관련하여 Isolation_level 격리 수준이 기본값인 경우 모든 작업에 이를 사용해야 합니다. 데이터베이스 명령에서isolation_level=None을 설정할 수도 있습니다. 그러면 자동 제출 모드로 변경됩니다.

4.

커서

를 사용하여 데이터베이스 쿼리 데이터베이스를 쿼리하고 쿼리 개체를 얻으려면 커서 개체 SQL 문을 사용해야 합니다. 다음과 같은 방법으로 커서를 정의합니다.

cu=cx.cursor()

커서 개체에는 다음과 같은 작업이 있습니다.

①execute()--sql 문 실행 ②executemany--여러 sql 문 실행

3 close()--닫기 커서

4 fetchone()--결과에서 하나의 레코드를 가져오고 커서를 다음 레코드로 가리킵니다.
⑤ fetchmany()--결과에서 여러 레코드를 가져옵니다.
⑥ fetchall()-결과에서 모든 레코드를 가져옵니다.
7 스크롤()--커서 스크롤


1. 테이블 만들기

코드 복사

코드는 다음과 같습니다.

cu.execute("테이블 카탈로그 만들기(id integer

기본 키, pid 정수, 이름 varchar) (10) UNIQUE, 별명 텍스트 NULL)")

위 명령문은 기본 키 ID, pid 및 이름이 있는 카탈로그라는 테이블을 생성합니다. 이름은 반복될 수 없으며 별명의 기본값은 NULL입니다.

2.

데이터 삽입

다음과 같이 쓰지 않도록 주의하세요.

# Never do this -- insecure 会导致注入攻击
pid=200
c.execute("... where pid = '%s'" % pid)
로그인 후 복사

올바른 방법은 t가 단일 값인 경우에도 다음과 같은 형식이어야 합니다. t=(n,), 왜냐하면 튜플은 불변이기 때문입니다.

for t in[(0,10,'abc','Yu'),(1,20,'cba','Xu')]:
  cx.execute("insert into catalog values (?,?,?,?)", t)
로그인 후 복사

두 행의 데이터를 삽입하기만 하면 됩니다. 하지만 제출 후에만 적용된다는 점에 유의하세요. 데이터베이스 연결 개체 cx를 사용하여 커밋 및 롤백 작업을 수행합니다.

cx.commit()
로그인 후 복사


3. 쿼리

cu.execute("select * from catalog")
로그인 후 복사

쿼리된 데이터를 추출하려면 다음과 같이 커서의 가져오기 기능을 사용하세요.

In [10]: cu.fetchall()
Out[10]: [(0, 10, u'abc', u'Yu'), (1, 20, u'cba', u'Xu')]
로그인 후 복사

cu.fetchone()을 사용하면 목록의 첫 번째 항목이 먼저 반환됩니다. 다시 사용하시면 2번째 항목으로 돌아가서 순서대로 진행하세요

In [12]: cu.execute("update catalog set name='Boy' where id = 0")
In [13]: cx.commit()
로그인 후 복사
참고, 데이터 수정 후 제출


cu.execute("delete from catalog where id = 1") 
cx.commit()
로그인 후 복사

6 . 중국어를 사용하세요

먼저 IDE 또는 시스템 기본 인코딩이 utf-8인지 확인하고 중국어 앞에 u


를 추가하세요.

x=u'鱼'
cu.execute("update catalog set name=? where id = 0",x)
cu.execute("select * from catalog")
cu.fetchall()
[(0, 10, u'\u9c7c', u'Yu'), (1, 20, u'cba', u'Xu')]
로그인 후 복사

如果要显示出中文字体,那需要依次打印出每个字符串


In [26]: for item in cu.fetchall():
  ....:   for element in item:
  ....:     print element,
  ....:   print
  ....: 
0 10 鱼 Yu
1 20 cba Xu
로그인 후 복사

7.Row类型

Row提供了基于索引和基于名字大小写敏感的方式来访问列而几乎没有内存开销。 原文如下:

sqlite3.Row provides both index-based and case-insensitive name-based access to columns with almost no memory overhead. It will probably be better than your own custom dictionary-based approach or even a db_row based solution.

Row对象的详细介绍

class sqlite3.Row
A Row instance serves as a highly optimized row_factory for Connection objects. It tries to mimic a tuple in most of its features.
It supports mapping access by column name and index, iteration, representation, equality testing and len().
If two Row objects have exactly the same columns and their members are equal, they compare equal.
Changed in version 2.6: Added iteration and equality (hashability).
keys()
This method returns a tuple of column names. Immediately after a query, it is the first member of each tuple in Cursor.description.
New in version 2.6.

下面举例说明


In [30]: cx.row_factory = sqlite3.Row
In [31]: c = cx.cursor()
In [32]: c.execute('select * from catalog')
Out[32]: <sqlite3.Cursor object at 0x05666680>
In [33]: r = c.fetchone()
In [34]: type(r)
Out[34]: <type &#39;sqlite3.Row&#39;>
In [35]: r
Out[35]: <sqlite3.Row object at 0x05348980>
In [36]: print r
(0, 10, u&#39;\u9c7c&#39;, u&#39;Yu&#39;)
In [37]: len(r)
Out[37]: 4
In [39]: r[2]      #使用索引查询
Out[39]: u&#39;\u9c7c&#39;
In [41]: r.keys()
Out[41]: [&#39;id&#39;, &#39;pid&#39;, &#39;name&#39;, &#39;nickname&#39;]
In [42]: for e in r:
  ....:   print e,
  ....: 
0 10 鱼 Yu
로그인 후 복사

使用列的关键词查询


In [43]: r[&#39;id&#39;]
Out[43]: 0
In [44]: r[&#39;name&#39;]
Out[44]: u&#39;\u9c7c&#39;
로그인 후 복사

위 내용은 Python에서 SQLite 데이터베이스를 작동하는 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

XML 형식을 여는 방법 XML 형식을 여는 방법 Apr 02, 2025 pm 09:00 PM

대부분의 텍스트 편집기를 사용하여 XML 파일을여십시오. 보다 직관적 인 트리 디스플레이가 필요한 경우 Oxygen XML 편집기 또는 XMLSPy와 같은 XML 편집기를 사용할 수 있습니다. 프로그램에서 XML 데이터를 처리하는 경우 프로그래밍 언어 (예 : Python) 및 XML 라이브러 (예 : XML.etree.elementtree)를 사용하여 구문 분석해야합니다.

휴대 전화 용 무료 XML에서 PDF 도구가 있습니까? 휴대 전화 용 무료 XML에서 PDF 도구가 있습니까? Apr 02, 2025 pm 09:12 PM

모바일에는 간단하고 직접 무료 XML에서 PDF 툴이 없습니다. 필요한 데이터 시각화 프로세스에는 복잡한 데이터 이해 및 렌더링이 포함되며 시장에있는 소위 "무료"도구의 대부분은 경험이 좋지 않습니다. 컴퓨터 측 도구를 사용하거나 클라우드 서비스를 사용하거나보다 신뢰할 수있는 전환 효과를 얻기 위해 앱을 개발하는 것이 좋습니다.

XML을 PDF로 변환 할 수있는 모바일 앱이 있습니까? XML을 PDF로 변환 할 수있는 모바일 앱이 있습니까? Apr 02, 2025 pm 08:54 PM

XML을 PDF로 직접 변환하는 응용 프로그램은 근본적으로 다른 두 형식이므로 찾을 수 없습니다. XML은 데이터를 저장하는 데 사용되는 반면 PDF는 문서를 표시하는 데 사용됩니다. 변환을 완료하려면 Python 및 ReportLab과 같은 프로그래밍 언어 및 라이브러리를 사용하여 XML 데이터를 구문 분석하고 PDF 문서를 생성 할 수 있습니다.

XML 수정에 프로그래밍이 필요합니까? XML 수정에 프로그래밍이 필요합니까? Apr 02, 2025 pm 06:51 PM

XML 컨텐츠를 수정하려면 프로그래밍이 필요합니다. 대상 노드를 추가, 삭제, 수정 및 확인하려면 정확한 찾기가 필요하기 때문입니다. 프로그래밍 언어에는 XML을 처리하기위한 해당 라이브러리가 있으며 운영 데이터베이스와 같이 안전하고 효율적이며 제어 가능한 작업을 수행 할 수있는 API를 제공합니다.

권장 XML 서식 도구 권장 XML 서식 도구 Apr 02, 2025 pm 09:03 PM

XML 서식 도구는 규칙에 따라 코드를 입력하여 가독성과 이해를 향상시킬 수 있습니다. 도구를 선택할 때는 사용자 정의 기능, 특수 상황 처리, 성능 및 사용 편의성에주의하십시오. 일반적으로 사용되는 도구 유형에는 온라인 도구, IDE 플러그인 및 명령 줄 도구가 포함됩니다.

XML 형식을 아름답게하는 방법 XML 형식을 아름답게하는 방법 Apr 02, 2025 pm 09:57 PM

XML 미화는 합리적인 압입, 라인 브레이크 및 태그 구성을 포함하여 기본적으로 가독성을 향상시키고 있습니다. 원칙은 XML 트리를 가로 지르고 레벨에 따라 들여 쓰기를 추가하고 텍스트가 포함 된 빈 태그와 태그를 처리하는 것입니다. Python의 xml.etree.elementtree 라이브러리는 위의 미화 프로세스를 구현할 수있는 편리한 Pretty_XML () 기능을 제공합니다.

휴대 전화에서 XML 파일을 PDF로 변환하는 방법은 무엇입니까? 휴대 전화에서 XML 파일을 PDF로 변환하는 방법은 무엇입니까? Apr 02, 2025 pm 10:12 PM

단일 애플리케이션으로 휴대 전화에서 직접 XML에서 PDF 변환을 완료하는 것은 불가능합니다. 두 단계를 통해 달성 할 수있는 클라우드 서비스를 사용해야합니다. 1. 클라우드에서 XML을 PDF로 변환하십시오. 2. 휴대 전화에서 변환 된 PDF 파일에 액세스하거나 다운로드하십시오.

휴대 전화에서 XML을 PDF로 변환하는 방법은 무엇입니까? 휴대 전화에서 XML을 PDF로 변환하는 방법은 무엇입니까? Apr 02, 2025 pm 10:18 PM

휴대 전화에서 XML을 PDF로 직접 변환하는 것은 쉽지 않지만 클라우드 서비스를 통해 달성 할 수 있습니다. 가벼운 모바일 앱을 사용하여 XML 파일을 업로드하고 생성 된 PDF를 수신하고 클라우드 API로 변환하는 것이 좋습니다. Cloud API는 Serverless Computing Services를 사용하고 올바른 플랫폼을 선택하는 것이 중요합니다. XML 구문 분석 및 PDF 생성을 처리 할 때 복잡성, 오류 처리, 보안 및 최적화 전략을 고려해야합니다. 전체 프로세스에는 프론트 엔드 앱과 백엔드 API가 함께 작동해야하며 다양한 기술에 대한 이해가 필요합니다.

See all articles