Simple Remote MySQL Server Configuration from Scratch with Python
1. Step-to-step MySQL Installation
2. Server and Database Configuration with Python
3. Client-side Python Example
Step-to-step MySQL Installation
data:image/s3,"s3://crabby-images/d4458/d4458225aa2cee7a8955e890a0b365e5b6acb48a" alt=""
data:image/s3,"s3://crabby-images/727fa/727fa820d43b3a9fab74609dddd02c7ca3cb5558" alt=""
data:image/s3,"s3://crabby-images/88d69/88d694cbd8e9d9b3a7923ef923f1a257208e5547" alt=""
data:image/s3,"s3://crabby-images/3797f/3797f4b344e290e70c276a1f8728d41c708d12b3" alt=""
data:image/s3,"s3://crabby-images/36135/36135e5075dbe006d96b6fa8b09b1c7fd10d938d" alt=""
data:image/s3,"s3://crabby-images/9d735/9d7352ab1006be0930dad33037faa62d63f03af5" alt=""
Note: There is not really a difference between Developer Computer and Server Computer for this tutorial
data:image/s3,"s3://crabby-images/e5358/e53589bd8ea9844de0f4203d8ec53f3b1511b709" alt=""
data:image/s3,"s3://crabby-images/d777e/d777e669107c67d43b2178985031f1dc640a41d1" alt=""
data:image/s3,"s3://crabby-images/29de0/29de05ec5b634b37d2ed2c0791a2dba54e1972b4" alt=""
data:image/s3,"s3://crabby-images/0cda9/0cda985cdfb80f7f8dba73e638a97d8f6921c75e" alt=""
data:image/s3,"s3://crabby-images/26f96/26f9662c2e868a4e912fdaa5c6af1184ece3d88f" alt=""
data:image/s3,"s3://crabby-images/03ee3/03ee32c7bb82efde399dac8d2d7cfb93b3ab5822" alt=""
data:image/s3,"s3://crabby-images/f9c49/f9c49ffc2db604af2fa258b9777ac851ce227e55" alt=""
data:image/s3,"s3://crabby-images/4b3ce/4b3ce133dbdb65d5b958767f86030da77c3a17bf" alt=""
Server And Database Configuration with Python
Note: The following can be done in MySQL Shell, but I decided to do so in Python as you may want to implement the following code in your projects.
Install the Connector
First, in the CommandPrompt enter
pip install mysql-connector
to install the connector to be used in Python. We can start creating our python file.
Python Step-by-Step
Let's start by importing the recently installed package.
setup_example.py
import mysql.connector as db
Then, we create an instance of MySQLConnection
using the root account and the password created during the MySQL installation and initialize the cursor.setup_example.py
mydb = db.connect(
host = "localhost",
user = "root",
passwd = "password"
)
mycursor = mydb.cursor()
After this, we create a database and a user with privileges to use the database.setup_example.py
mycursor.execute("CREATE DATABASE IF NOT EXISTS my_database;")
# the username should be quoted as well as the user's password.
# replace clientipaddress with the client-computer's ip address
mycursor.execute("CREATE USER IF NOT EXISTS 'username'@clientipaddress IDENTIFIED BY 'password';")
mycursor.execute("GRANT ALL PRIVILEGES ON *.* to 'username'@clientipaddress;")
After this we can access the database to create a simple table.setup_example.py
mycursor.execute("use my_database;")
mycursor.execute("CREATE TABLE my_table (name varchar(20),age int(2));")
With this, we have finished the configuration of the database.Python Full Code
setup_example.py
import mysql.connector as db
mydb = db.connect(
host = "localhost",
user = "root", # the server's main account
passwd = "password" # and its password
)
mycursor = mydb.cursor()
mycursor.execute("CREATE DATABASE IF NOT EXISTS my_database;")
# the username and password should be quoted should be quoted with ' ' .
# replace clientipaddress with the client-computer's ip address
mycursor.execute("CREATE USER IF NOT EXISTS 'username'@clientipaddress IDENTIFIED BY 'password';")
mycursor.execute("GRANT ALL PRIVILEGES ON *.* to 'username'@clientipaddress;")
# select which database we will be using
mycursor.execute("use my_database;")
# create the table
mycursor.execute("CREATE TABLE my_table (name varchar(20),age int(2));")
Let's make a simple example of a client application.Client-side Python Example
In this example we will connect to the remote database and insert a tuple into the 'my_table' table.
Python Step-by-Step
As before, we import the connector.
client_example.py
import mysql.connector as db
Then, we connect to the remote database and initialize our cursor.client_example.py
mydb = db.connect(
host = serverpaddress, # replace for the server's IP address
user = "username", # previously created user
passwd = "password", # and its password
database = "my_database" # we directly connect to the desired database
)
mycursor = mydb.cursor()
After this, we define the command, assign values, and execute the command. We also commit out database.client_example.py
sql_command = "INSERT INTO my_table (name, age) values (%s, %s);"
values = ('my_name', 1)
mycursor.execute(sql_command, values)
# save changes to the database
mydb.commit();
We can view the information inside the table using SELECT.client
sql_command = "select * from my_table"
mycursor.execute(sql_command)
[print(x) for x in mycursor.fetchall()]
The output should be ('my_name', 1)
Example's Full Code
client_example.py
#import necessary packages
import mysql.connector as db
# connect to the database
mydb = db.connect(
host = serveripaddress, # replace for the server's IP address
user = "username", # previously created user
passwd = "password", # and its password
database = "my_database" # we directly connect to the desired database
)
#initialize cursor
mycursor = mydb.cursor()
# define command
sql_command = "INSERT INTO my_table (name, age) values (%s, %s);"
# assign values
values = ('my_name', 1)
# execute command
mycursor.execute(sql_command, values)
# save changes to the database
mydb.commit();
# import information from the database
sql_command = "select * from my_table"
mycursor.execute(sql_command)
# output information
[print(x) for x in mycursor.fetchall()]
Reference
이 문제에 관하여(Simple Remote MySQL Server Configuration from Scratch with Python), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/ANNEX_IBS/items/f37ae8caf65ed2bc7539텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)