Skip to content

Latest commit

 

History

History
100 lines (64 loc) · 4.45 KB

README.md

File metadata and controls

100 lines (64 loc) · 4.45 KB

ChEMBL_MySQL_Tutorial

ChEMBL is the largest, open-access database of bioactive molecules with drug-like properties, maintained by the European Bioinformatics Institute (EBI) of the European Molecular Biology Laboratory (EMBL). This code gives examples of how to navigate the ChEMBL schema to curate a database for your specific research question using MySQL.

EMBL already provides great SQL examples and Free online tutorials on how to access different EMBL-EBI resources programmatically. This guide is intended to provide a bit more context for SQL beginners and visual guidance for relational database management in ChEMBL.

Note

This guide is for implementing MySQL in a Jupyter Notebook or similar python environment. I chose this approach over command line because it enables direct testing of the code. If you are interested in completing smaller queries, command line might be a simpler option for you.

First things first

The ChEMBL database is organised in a schema that can be found on the ChEMBL Schema Page. Navigating through the schema allows for the incorporation of data selection criteria and curation of a personalised database with columns of interest.

ChEMBL_33 Schema from May 31 2023

By looking at the ChEMBL schema, discern which information is relevant to your research. Are you interested in compounds and their bioactivity in binding assays? Are you interested in binding site information? Find the column headers of interest and think about how to connect them.

Getting started

Step 1: Download the chembl_33_mysql.tar.gz (or newest release) from ChEMBL Downloads Page. Unzip this file and save it to your directory of choice.

Note

This file is 1.6G and may take a while to install depending on your device.

Tip

For smaller queries, you may want to use the ChEMBL API instead of downloading the entire database.

Step 2: Download MySQL via MySQL website

Step 3:

create table tmp_data as 
SELECT DISTINCT molecule_dictionary.chembl_id,compound_structures.canonical_smiles,ASSAYS.TID,target_dictionary.chembl_id AS target_chembl_id,
TARGET_DICTIONARY.ORGANISM,ACTIVITIES.*,assays.chembl_id AS assay_chembl_id 
from molecule_dictionary,compound_structures,assays,activities,target_dictionary

Imports

import pandas as pd
import mysql.connector
import pyodbc
import pymssql
import seaborn as sns
import numpy as np
import csv

Connecting to MySQL in Jupyter Notebook

host = 'localhost'
database = 'chembl'
user = 'root'
password = 'newpassword'

cnx = mysql.connector.connect(user=user, password=password, 
                              host=host, database=database)

Example: Retrieve and filter activity, target and molecule data

a_query = "SELECT activities.standard_units, activities.molregno, activities.standard_value, activities.assay_id FROM activities WHERE activities.standard_type = 'IC50' AND activities.standard_value IS NOT NULL AND activities.standard_units IS NOT NULL"
activities = pd.read_sql_query(a_query, cnx)
activities['pIC50'] = activities.apply(lambda x: convert_to_pchembl(x['standard_value'], x['standard_units']), axis=1)

t_query = "SELECT * FROM target_dictionary WHERE ORGANISM = 'Homo sapiens' AND TARGET_TYPE = 'SINGLE PROTEIN'"
target_dictionary = pd.read_sql_query(t_query, cnx)

m_query = "SELECT * FROM molecule_dictionary WHERE molecule_type = 'Small molecule'"
molecule_dictionary = pd.read_sql_query(m_query, cnx)

s_query = "SELECT * FROM target_components"
target_components = pd.read_sql_query(s_query, cnx)

p_query = "SELECT * FROM protein_classification"
protein_classification = pd.read_sql_query(p_query, cnx)

o_query = "SELECT * FROM component_class"
component_class = pd.read_sql_query(o_query, cnx)

x_query = "SELECT * FROM assays"
assays = pd.read_sql_query(x_query, cnx)

mw_query = "SELECT * FROM compound_properties"
compound_properties = pd.read_sql_query(mw_query, cnx)

cmpd_query = "SELECT * FROM compound_structures"
compound_structures = pd.read_sql_query(cmpd_query, cnx)