Biopython-BioSQL 모듈
BioSQL주로 모든 RDBMS 엔진에 대한 시퀀스 및 관련 데이터를 저장하도록 설계된 일반 데이터베이스 스키마입니다. GenBank, Swissport 등과 같은 모든 인기있는 생물 정보학 데이터베이스의 데이터를 보유하도록 설계되었습니다. 사내 데이터를 저장하는 데에도 사용할 수 있습니다.
BioSQL 현재 아래 데이터베이스에 대한 특정 스키마를 제공합니다-
- MySQL (biosqldb-mysql.sql)
- PostgreSQL (biosqldb-pg.sql)
- Oracle (biosqldb-ora / *. sql)
- SQLite (biosqldb-sqlite.sql)
또한 Java 기반 HSQLDB 및 Derby 데이터베이스에 대한 최소한의 지원을 제공합니다.
BioPython은 BioSQL 기반 데이터베이스와 함께 작동하는 매우 간단하고 쉬운 고급 ORM 기능을 제공합니다. BioPython provides a module, BioSQL 다음 기능을 수행하려면-
- BioSQL 데이터베이스 생성 / 제거
- BioSQL 데이터베이스에 연결
- GenBank, Swisport, BLAST 결과, Entrez 결과 등과 같은 시퀀스 데이터베이스를 구문 분석하고 BioSQL 데이터베이스에 직접로드합니다.
- BioSQL 데이터베이스에서 시퀀스 데이터 가져 오기
- NCBI BLAST에서 분류 데이터를 가져와 BioSQL 데이터베이스에 저장
- BioSQL 데이터베이스에 대해 SQL 쿼리 실행
BioSQL 데이터베이스 스키마 개요
BioSQL에 대해 자세히 알아보기 전에 BioSQL 스키마의 기본 사항을 이해하겠습니다. BioSQL 스키마는 25 개 이상의 테이블을 제공하여 시퀀스 데이터, 시퀀스 기능, 시퀀스 카테고리 / 온톨로지 및 분류 정보를 보유합니다. 중요한 테이블 중 일부는 다음과 같습니다.
- biodatabase
- bioentry
- biosequence
- seqfeature
- taxon
- taxon_name
- antology
- term
- dxref
BioSQL 데이터베이스 생성
이 섹션에서는 BioSQL 팀에서 제공 한 스키마를 사용하여 샘플 BioSQL 데이터베이스 인 biosql을 생성 해 보겠습니다. 시작하기가 정말 쉽고 복잡한 설정이 없기 때문에 SQLite 데이터베이스로 작업 할 것입니다.
여기에서는 아래 단계를 사용하여 SQLite 기반 BioSQL 데이터베이스를 생성합니다.
Step 1 − SQLite 데이터베이스 엔진을 다운로드하고 설치합니다.
Step 2 − GitHub URL에서 BioSQL 프로젝트를 다운로드하십시오. https://github.com/biosql/biosql
Step 3 − 콘솔을 열고 mkdir을 사용하여 디렉토리를 생성하고 입력하십시오.
cd /path/to/your/biopython/sample
mkdir sqlite-biosql
cd sqlite-biosql
Step 4 − 아래 명령을 실행하여 새 SQLite 데이터베이스를 생성합니다.
> sqlite3.exe mybiosql.db
SQLite version 3.25.2 2018-09-25 19:08:10
Enter ".help" for usage hints.
sqlite>
Step 5 − BioSQL 프로젝트 (/ sql / biosqldb-sqlite.sql`)에서 biosqldb-sqlite.sql 파일을 복사하여 현재 디렉토리에 저장합니다.
Step 6 − 아래 명령을 실행하여 모든 테이블을 생성합니다.
sqlite> .read biosqldb-sqlite.sql
이제 모든 테이블이 새 데이터베이스에 생성됩니다.
Step 7 − 아래 명령을 실행하여 데이터베이스의 모든 새 테이블을 확인하십시오.
sqlite> .headers on
sqlite> .mode column
sqlite> .separator ROW "\n"
sqlite> SELECT name FROM sqlite_master WHERE type = 'table';
biodatabase
taxon
taxon_name
ontology
term
term_synonym
term_dbxref
term_relationship
term_relationship_term
term_path
bioentry
bioentry_relationship
bioentry_path
biosequence
dbxref
dbxref_qualifier_value
bioentry_dbxref
reference
bioentry_reference
comment
bioentry_qualifier_value
seqfeature
seqfeature_relationship
seqfeature_path
seqfeature_qualifier_value
seqfeature_dbxref
location
location_qualifier_value
sqlite>
처음 세 명령은 형식화 된 방식으로 결과를 표시하도록 SQLite를 구성하는 구성 명령입니다.
Step 8 − BioPython 팀에서 제공 한 샘플 GenBank 파일 ls_orchid.gbk를 복사합니다. https://raw.githubusercontent.com/biopython/biopython/master/Doc/examples/ls_orchid.gbk 현재 디렉토리에 넣고 orchid.gbk로 저장하십시오.
Step 9 − 아래 코드를 사용하여 python 스크립트 load_orchid.py를 생성하고 실행합니다.
from Bio import SeqIO
from BioSQL import BioSeqDatabase
import os
server = BioSeqDatabase.open_database(driver = 'sqlite3', db = "orchid.db")
db = server.new_database("orchid")
count = db.load(SeqIO.parse("orchid.gbk", "gb"), True) server.commit()
server.close()
위의 코드는 파일의 레코드를 구문 분석하고이를 Python 개체로 변환하여 BioSQL 데이터베이스에 삽입합니다. 이후 섹션에서 코드를 분석 할 것입니다.
마지막으로 새로운 BioSQL 데이터베이스를 생성하고 여기에 샘플 데이터를로드했습니다. 다음 장에서 중요한 테이블에 대해 논의 할 것입니다.
간단한 ER 다이어그램
biodatabase 테이블은 계층 구조의 맨 위에 있으며 주요 목적은 일련의 시퀀스 데이터를 단일 그룹 / 가상 데이터베이스로 구성하는 것입니다. Every entry in the biodatabase refers to a separate database and it does not mingle with another database. BioSQL 데이터베이스의 모든 관련 테이블에는 biodatabase 항목에 대한 참조가 있습니다.
bioentry테이블은 시퀀스 데이터를 제외한 시퀀스에 대한 모든 세부 정보를 보유합니다. 특정의 시퀀스 데이터bioentry 에 저장됩니다 biosequence 표.
taxon 및 taxon_name은 분류 세부 정보이며 모든 항목은이 테이블을 참조하여 해당 분류 정보를 지정합니다.
스키마를 이해 한 후 다음 섹션에서 몇 가지 쿼리를 살펴 보겠습니다.
BioSQL 쿼리
데이터가 어떻게 구성되고 테이블이 서로 관련되어 있는지 더 잘 이해하기 위해 몇 가지 SQL 쿼리를 살펴 보겠습니다. 계속하기 전에 아래 명령을 사용하여 데이터베이스를 열고 몇 가지 형식 지정 명령을 설정합니다.
> sqlite3 orchid.db
SQLite version 3.25.2 2018-09-25 19:08:10
Enter ".help" for usage hints.
sqlite> .header on
sqlite> .mode columns
.header and .mode are formatting options to better visualize the data. SQLite 편집기를 사용하여 쿼리를 실행할 수도 있습니다.
시스템에서 사용 가능한 가상 시퀀스 데이터베이스를 아래에 나열하십시오.
select
*
from
biodatabase;
*** Result ***
sqlite> .width 15 15 15 15
sqlite> select * from biodatabase;
biodatabase_id name authority description
--------------- --------------- --------------- ---------------
1 orchid
sqlite>
여기에는 데이터베이스가 하나만 있습니다. orchid.
데이터베이스에서 사용할 수있는 항목 (상위 3 개) 나열 orchid 아래 주어진 코드로
select
be.*,
bd.name
from
bioentry be
inner join
biodatabase bd
on bd.biodatabase_id = be.biodatabase_id
where
bd.name = 'orchid' Limit 1,
3;
*** Result ***
sqlite> .width 15 15 10 10 10 10 10 50 10 10
sqlite> select be.*, bd.name from bioentry be inner join biodatabase bd on
bd.biodatabase_id = be.biodatabase_id where bd.name = 'orchid' Limit 1,3;
bioentry_id biodatabase_id taxon_id name accession identifier division description version name
--------------- --------------- ---------- ---------- ---------- ---------- ----------
---------- ---------- ----------- ---------- --------- ---------- ----------
2 1 19 Z78532 Z78532 2765657 PLN
C.californicum 5.8S rRNA gene and ITS1 and ITS2 DN 1
orchid
3 1 20 Z78531 Z78531 2765656 PLN
C.fasciculatum 5.8S rRNA gene and ITS1 and ITS2 DN 1
orchid
4 1 21 Z78530 Z78530 2765655 PLN
C.margaritaceum 5.8S rRNA gene and ITS1 and ITS2 D 1
orchid
sqlite>
주어진 코드를 사용하여 항목 (수탁-Z78530, 이름-C. fasciculatum 5.8S rRNA 유전자 및 ITS1 및 ITS2 DNA)과 관련된 시퀀스 세부 정보를 나열합니다.
select
substr(cast(bs.seq as varchar), 0, 10) || '...' as seq,
bs.length,
be.accession,
be.description,
bd.name
from
biosequence bs
inner join
bioentry be
on be.bioentry_id = bs.bioentry_id
inner join
biodatabase bd
on bd.biodatabase_id = be.biodatabase_id
where
bd.name = 'orchid'
and be.accession = 'Z78532';
*** Result ***
sqlite> .width 15 5 10 50 10
sqlite> select substr(cast(bs.seq as varchar), 0, 10) || '...' as seq,
bs.length, be.accession, be.description, bd.name from biosequence bs inner
join bioentry be on be.bioentry_id = bs.bioentry_id inner join biodatabase bd
on bd.biodatabase_id = be.biodatabase_id where bd.name = 'orchid' and
be.accession = 'Z78532';
seq length accession description name
------------ ---------- ---------- ------------ ------------ ---------- ---------- -----------------
CGTAACAAG... 753 Z78532 C.californicum 5.8S rRNA gene and ITS1 and ITS2 DNA orchid
sqlite>
아래 코드를 사용하여 항목 (수탁-Z78530, 이름-C. fasciculatum 5.8S rRNA 유전자 및 ITS1 및 ITS2 DNA)과 관련된 전체 시퀀스를 가져옵니다.
select
bs.seq
from
biosequence bs
inner join
bioentry be
on be.bioentry_id = bs.bioentry_id
inner join
biodatabase bd
on bd.biodatabase_id = be.biodatabase_id
where
bd.name = 'orchid'
and be.accession = 'Z78532';
*** Result ***
sqlite> .width 1000
sqlite> select bs.seq from biosequence bs inner join bioentry be on
be.bioentry_id = bs.bioentry_id inner join biodatabase bd on bd.biodatabase_id =
be.biodatabase_id where bd.name = 'orchid' and be.accession = 'Z78532';
seq
----------------------------------------------------------------------------------------
----------------------------
CGTAACAAGGTTTCCGTAGGTGAACCTGCGGAAGGATCATTGTTGAGACAACAGAATATATGATCGAGTGAATCT
GGAGGACCTGTGGTAACTCAGCTCGTCGTGGCACTGCTTTTGTCGTGACCCTGCTTTGTTGTTGGGCCTCC
TCAAGAGCTTTCATGGCAGGTTTGAACTTTAGTACGGTGCAGTTTGCGCCAAGTCATATAAAGCATCACTGATGAATGACATTATTGT
CAGAAAAAATCAGAGGGGCAGTATGCTACTGAGCATGCCAGTGAATTTTTATGACTCTCGCAACGGATATCTTGGCTC
TAACATCGATGAAGAACGCAG
sqlite>
바이오 데이터베이스, 난초와 관련된 분류군 목록
select distinct
tn.name
from
biodatabase d
inner join
bioentry e
on e.biodatabase_id = d.biodatabase_id
inner join
taxon t
on t.taxon_id = e.taxon_id
inner join
taxon_name tn
on tn.taxon_id = t.taxon_id
where
d.name = 'orchid' limit 10;
*** Result ***
sqlite> select distinct tn.name from biodatabase d inner join bioentry e on
e.biodatabase_id = d.biodatabase_id inner join taxon t on t.taxon_id =
e.taxon_id inner join taxon_name tn on tn.taxon_id = t.taxon_id where d.name =
'orchid' limit 10;
name
------------------------------
Cypripedium irapeanum
Cypripedium californicum
Cypripedium fasciculatum
Cypripedium margaritaceum
Cypripedium lichiangense
Cypripedium yatabeanum
Cypripedium guttatum
Cypripedium acaule
pink lady's slipper
Cypripedium formosanum
sqlite>
BioSQL 데이터베이스에 데이터로드
이 장에서는 시퀀스 데이터를 BioSQL 데이터베이스에로드하는 방법을 알아 보겠습니다. 이전 섹션에서 데이터베이스에 데이터를로드하는 코드가 이미 있으며 코드는 다음과 같습니다.
from Bio import SeqIO
from BioSQL import BioSeqDatabase
import os
server = BioSeqDatabase.open_database(driver = 'sqlite3', db = "orchid.db")
DBSCHEMA = "biosqldb-sqlite.sql"
SQL_FILE = os.path.join(os.getcwd(), DBSCHEMA)
server.load_database_sql(SQL_FILE)
server.commit()
db = server.new_database("orchid")
count = db.load(SeqIO.parse("orchid.gbk", "gb"), True) server.commit()
server.close()
우리는 코드의 모든 줄과 그 목적에 대해 자세히 살펴볼 것입니다.
Line 1 − SeqIO 모듈을로드합니다.
Line 2− BioSeqDatabase 모듈을로드합니다. 이 모듈은 BioSQL 데이터베이스와 상호 작용하는 모든 기능을 제공합니다.
Line 3 − os 모듈을로드합니다.
Line 5− open_database는 구성된 드라이버 (드라이버)로 지정된 데이터베이스 (db)를 열고 BioSQL 데이터베이스 (서버)에 대한 핸들을 반환합니다. Biopython은 sqlite, mysql, postgresql 및 oracle 데이터베이스를 지원합니다.
Line 6-10− load_database_sql 메소드는 외부 파일에서 SQL을로드하여 실행합니다. commit 메소드는 트랜잭션을 커밋합니다. 스키마가있는 데이터베이스를 이미 생성 했으므로이 단계를 건너 뛸 수 있습니다.
Line 12 − new_database 메소드는 새로운 가상 데이터베이스 인 orchid를 생성하고 orchid 데이터베이스에 대해 명령을 실행하기 위해 핸들 db를 반환합니다.
Line 13− load 메소드는 시퀀스 항목 (반복 가능한 SeqRecord)을 orchid 데이터베이스에로드합니다. SqlIO.parse는 GenBank 데이터베이스를 구문 분석하고 모든 시퀀스를 반복 가능한 SeqRecord로 반환합니다. 로드 방법의 두 번째 매개 변수 (True)는 시스템에서 아직 사용할 수없는 경우 NCBI blast 웹 사이트에서 시퀀스 데이터의 분류 세부 정보를 가져 오도록 지시합니다.
Line 14 − commit은 트랜잭션을 커밋합니다.
Line 15 − close는 데이터베이스 연결을 닫고 서버 핸들을 파괴합니다.
시퀀스 데이터 가져 오기
다음과 같이 난초 데이터베이스에서 식별자 2765658이있는 시퀀스를 가져 오겠습니다.
from BioSQL import BioSeqDatabase
server = BioSeqDatabase.open_database(driver = 'sqlite3', db = "orchid.db")
db = server["orchid"]
seq_record = db.lookup(gi = 2765658)
print(seq_record.id, seq_record.description[:50] + "...")
print("Sequence length %i," % len(seq_record.seq))
여기서 server [ "orchid"]는 가상 databaseorchid에서 데이터를 가져 오기위한 핸들을 반환합니다. lookup 메서드는 기준에 따라 시퀀스를 선택하는 옵션을 제공하며 식별자 2765658을 사용하여 시퀀스를 선택했습니다. lookup시퀀스 정보를 SeqRecordobject로 반환합니다. 우리는 이미 SeqRecord`로 작업하는 방법을 알고 있기 때문에 데이터를 쉽게 가져올 수 있습니다.
데이터베이스 제거
데이터베이스를 제거하는 것은 적절한 데이터베이스 이름으로 remove_database 메서드를 호출 한 다음 아래에 지정된대로 커밋하는 것처럼 간단합니다.
from BioSQL import BioSeqDatabase
server = BioSeqDatabase.open_database(driver = 'sqlite3', db = "orchid.db")
server.remove_database("orchids")
server.commit()