How to Create A Table In MySQL With Python?

13 minutes read

To create a table in MySQL using Python, you can follow these steps:

  1. Import the necessary modules: Begin by importing the mysql.connector module, which allows you to connect and execute SQL queries in Python.
  2. Establish a connection: Use the connect() function from mysql.connector to establish a connection with your MySQL database. Specify the database credentials (host, user, password, and database name) while establishing the connection.
  3. Create a cursor object: After connecting to the database, create a cursor object using the cursor() method. It allows you to execute SQL queries.
  4. Write the SQL query: Use the cursor object to execute SQL commands. To create a table, write an SQL CREATE TABLE statement. Specify the table name and column names along with their data types and any additional constraints.
  5. Execute the query: Once the SQL query is ready, execute it using the execute() method of the cursor object. Pass the SQL query as a parameter to this method.
  6. Commit the changes: After executing the query, call the commit() method to save the changes made to the database.
  7. Close the cursor and connection: Finally, close the cursor and connection by calling the close() method.


Example code:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import mysql.connector

# Establish a connection
cnx = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="your_database"
)

# Create a cursor object
cursor = cnx.cursor()

# Write the SQL query to create a table
create_table_query = """
CREATE TABLE new_table (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(50),
    age INT,
    email VARCHAR(100)
)
"""

# Execute the SQL query
cursor.execute(create_table_query)

# Commit the changes
cnx.commit()

# Close the cursor and connection
cursor.close()
cnx.close()


Make sure to replace "localhost", "your_username", "your_password", and "your_database" with your actual database host, username, password, and database name, respectively. The example above creates a table named new_table with four columns: id, name, age, and email. The id column is a primary key with auto-increment functionality.

Best MySQL Managed Hosting Providers in 2025

1
Vultr

Rating is 5 out of 5

Vultr

  • Ultra-fast Intel Core
  • High Performance and Cheap Cloud Dedicated Servers
  • 1 click install Wordpress
  • Low Price and High Quality
2
Digital Ocean

Rating is 4.9 out of 5

Digital Ocean

  • Active Digital Community
  • Simple Control Panel
  • Starting from 5$ per month


How to specify column names and data types when creating a table in MySQL with Python?

To specify column names and data types when creating a table in MySQL with Python, you can use the CREATE TABLE statement with the necessary column definitions. Here's an example:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import mysql.connector

# Connect to MySQL
conn = mysql.connector.connect(
    host="localhost", user="your_username", password="your_password", database="your_database"
)

# Create a cursor object to execute SQL queries
cursor = conn.cursor()

# Define the CREATE TABLE query
query = """
CREATE TABLE your_table_name (
    column1_name data_type,
    column2_name data_type,
    column3_name data_type,
    ...
)
"""

# Execute the query
cursor.execute(query)

# Commit the changes to make them permanent
conn.commit()

# Close the cursor and connection
cursor.close()
conn.close()


In the CREATE TABLE query, replace your_table_name with the desired table name, and specify column names and data types within parentheses, separated by commas. Replace column1_name, column2_name, etc. with the desired column names, and data_type with the appropriate data type for each column (e.g., INT, VARCHAR(255), etc.).


You can add as many columns as needed by repeating the column_name data_type pattern, and you can also include additional constraints, such as primary keys, foreign keys, and constraints on data values within individual columns.


What is the syntax for a WHERE clause in MySQL using Python?

The syntax for a WHERE clause in MySQL using Python is as follows:

1
2
3
SELECT column1, column2, ...
FROM table_name
WHERE condition;


Here, column1, column2 are the columns to be retrieved from the table, and table_name is the name of the table from which the data is to be retrieved. The WHERE clause is used to filter the results based on a specified condition.


For example, to retrieve all rows from a table named "customers" where the "age" column is greater than 25, the query would be:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import mysql.connector

# Establish a connection to the MySQL database
mydb = mysql.connector.connect(
  host="localhost",
  user="yourusername",
  password="yourpassword",
  database="yourdatabase"
)

# Create a cursor object to execute SQL queries
mycursor = mydb.cursor()

# Execute the query with the WHERE clause
sql = "SELECT * FROM customers WHERE age > 25"
mycursor.execute(sql)

# Fetch all the rows returned by the query
result = mycursor.fetchall()

# Print the rows
for row in result:
  print(row)


Make sure to replace "yourusername", "yourpassword" and "yourdatabase" with your own MySQL credentials and database information.


How to update data in a MySQL table using Python?

To update data in a MySQL table using Python, you can follow these steps:

  1. Import the required modules:
1
import mysql.connector


  1. Establish a connection to the MySQL database:
1
cnx = mysql.connector.connect(user='your_username', password='your_password', host='your_host', database='your_database')


Replace "your_username", "your_password", "your_host", and "your_database" with the appropriate values for your MySQL setup.

  1. Create a cursor object:
1
cursor = cnx.cursor()


  1. Write the UPDATE query to update the desired record(s):
1
update_query = "UPDATE table_name SET column1 = %s, column2 = %s WHERE condition"


Replace "table_name" with the name of your table and define the proper update conditions.

  1. Execute the UPDATE query using the cursor:
1
2
3
data = ('new_value1', 'new_value2')
cursor.execute(update_query, data)
cnx.commit()


Replace "new_value1" and "new_value2" with the new values you want to update for column1 and column2. You can pass the new values as a tuple or list.

  1. Close the cursor and the database connection:
1
2
cursor.close()
cnx.close()


Here's a complete example:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
import mysql.connector

# Establish a connection to the MySQL database
cnx = mysql.connector.connect(user='your_username', password='your_password', host='your_host', database='your_database')

# Create a cursor object
cursor = cnx.cursor()

# Write the UPDATE query
update_query = "UPDATE table_name SET column1 = %s, column2 = %s WHERE condition"

# Execute the UPDATE query
data = ('new_value1', 'new_value2')
cursor.execute(update_query, data)
cnx.commit()

# Close the cursor and the connection
cursor.close()
cnx.close()


Make sure to replace "your_username", "your_password", "your_host", "your_database", "table_name", and "condition" with the appropriate values for your situation.

Best MySQL Database Books to Read in 2025

1
Murach's MySQL (3rd Edition)

Rating is 5 out of 5

Murach's MySQL (3rd Edition)

2
Learning MySQL: Get a Handle on Your Data

Rating is 4.9 out of 5

Learning MySQL: Get a Handle on Your Data

3
MySQL Crash Course: A Hands-on Introduction to Database Development

Rating is 4.8 out of 5

MySQL Crash Course: A Hands-on Introduction to Database Development

4
PHP & MySQL: Server-side Web Development

Rating is 4.7 out of 5

PHP & MySQL: Server-side Web Development

5
MySQL Cookbook: Solutions for Database Developers and Administrators

Rating is 4.6 out of 5

MySQL Cookbook: Solutions for Database Developers and Administrators

6
The MySQL Workshop: A practical guide to working with data and managing databases with MySQL

Rating is 4.5 out of 5

The MySQL Workshop: A practical guide to working with data and managing databases with MySQL

7
Murach's PHP and MySQL (4th Edition)

Rating is 4.4 out of 5

Murach's PHP and MySQL (4th Edition)

8
High Performance MySQL: Proven Strategies for Operating at Scale

Rating is 4.3 out of 5

High Performance MySQL: Proven Strategies for Operating at Scale

9
MySQL(TM): The Complete Reference

Rating is 4.2 out of 5

MySQL(TM): The Complete Reference


What is the syntax for updating data in a MySQL table using Python?

To update data in a MySQL table using Python, you can use the following syntax:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import mysql.connector

# Establish database connection
db = mysql.connector.connect(
    host="localhost",
    user="yourusername",
    password="yourpassword",
    database="yourdatabase"
)

# Create a cursor object to execute queries
cursor = db.cursor()

# SQL query to update data in the table
update_query = "UPDATE table_name SET column1 = value1, column2 = value2 WHERE condition"

# Execute the query
cursor.execute(update_query)

# Commit the changes
db.commit()

# Close the cursor and database connection
cursor.close()
db.close()


Note that you need to replace yourusername, yourpassword, yourdatabase, table_name, column1, value1, column2, value2, and condition with relevant values specific to your database and table structure. After executing the update query, make sure to commit the changes using db.commit() and close the cursor and database connection using cursor.close() and db.close() respectively.


How to add a foreign key constraint while creating a table in MySQL using Python?

To add a foreign key constraint while creating a table in MySQL using Python, you can use the following code:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import mysql.connector

# Connect to the MySQL database
mydb = mysql.connector.connect(
  host="localhost",
  user="yourusername",
  password="yourpassword",
  database="yourdatabase"
)

# Create a cursor object to interact with the database
mycursor = mydb.cursor()

# Create the main table
mycursor.execute("""
    CREATE TABLE customers (
      id INT PRIMARY KEY AUTO_INCREMENT,
      name VARCHAR(255),
      country_id INT,
      FOREIGN KEY (country_id) REFERENCES countries(id)
    )
  """)

# Create the referenced table
mycursor.execute("""
    CREATE TABLE countries (
      id INT PRIMARY KEY AUTO_INCREMENT,
      name VARCHAR(255)
    )
  """)

# Commit the changes and close the connection
mydb.commit()
mycursor.close()
mydb.close()


In the above code, we create two tables: "customers" and "countries". The "customers" table contains a foreign key constraint on the "country_id" column, which references the "id" column of the "countries" table.


Make sure to replace "yourusername", "yourpassword", and "yourdatabase" with your MySQL connection details. Additionally, you can modify the table and column names according to your requirements.

Facebook Twitter LinkedIn Telegram Whatsapp Pocket

Related Posts:

To import the mysql.connector module in Python, you can follow these steps:Make sure you have the mysql-connector-python library installed. If not, you can install it using pip by running the following command in your terminal: pip install mysql-connector-pyth...
To find MySQL usernames and passwords, you can check the following locations:MySQL Configuration File: The usernames and passwords for MySQL are usually specified in the "my.cnf" or "my.ini" configuration file. This file can be found in differe...
The MySQL config file contains important configuration settings for the MySQL database server. The location of the MySQL config file depends on the operating system you are using.On Unix-based systems (such as Linux and macOS), the MySQL config file is typical...