Python3分析MySQL数据库

1.在bash_profile中配置全局环境变量 终端open ~/.bash_profile打开环境变量配置文件,写入:

# mysql
export PATH=$PATH:/usr/local/mysql/bin

保存后退出,重新打开终端,使用命令mysql启动。

2.设置MySQL的root密码:

lishiqiangdeMacBook-Pro:~ bakufu$ MySQL -u root
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 7
Server version: 5.6.39 MySQL Community Server (GPL)

Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('150428');
Query OK, 0 rows affected (0.01 sec)

创建数据库并查看已有数据库

mysql> CREATE DATABASE my_suppliers;
Query OK, 1 row affected (0.01 sec)

mysql> SHOW DATABASES;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| my_suppliers       |
| mysql              |
| performance_schema |
| test               |
+--------------------+
5 rows in set (0.01 sec)

创建数据表先选择数据库

mysql> USE my_suppliers;
Database changed
mysql> CREATE TABLE IF NOT EXISTS Suppliers
    -> (Supplier_Name VARCHAR(20),
    -> Invoice_Number VARCHAR(20),
    -> Part_Number VARCHAR(20),
    -> Cost FLOAT,
    -> Purchase_Date DATE);
Query OK, 0 rows affected (0.03 sec)

如果数据库不存在数据表Suppliers ,命令就创建数据表Suppliers,含5个列(fields或attributes)。

  • VARCHAR型字段:可变字符,为字段中的数据分配20个字符。
  • CHAR型字段:用于设置有固定数量字符的字段,或者需要将字段中的值向右补齐到一个固定长度时。
  • ENUM型字段:用于字段取值是允许值列表(如small、medium、large)时。
  • BLOB型字段:用于字段内容是长度可变的大量文本时。
  • FLOAT型字段:浮点数字段保存浮点数近似值。本例包含货币值,所以用NUMERIC替代FLOAT型字段。
  • NUMERIC型字段:即定点确定值类型字段。不使用FLOAT,使用NUMERIC(11, 2),11是数值的精度,或者是为数值保存的数位总数,2是小数位数。
  • DATE型字段:用于保存日期('YYYY-MM-DD'),无时间部分。

验证数据表创建正确

显示列名、数据类型和值可否为NULL。

mysql> DESCRIBE Suppliers;
+----------------+-------------+------+-----+---------+-------+
| Field          | Type        | Null | Key | Default | Extra |
+----------------+-------------+------+-----+---------+-------+
| Supplier_Name  | varchar(20) | YES  |     | NULL    |       |
| Invoice_Number | varchar(20) | YES  |     | NULL    |       |
| Part_Number    | varchar(20) | YES  |     | NULL    |       |
| Cost           | float       | YES  |     | NULL    |       |
| Purchase_Date  | date        | YES  |     | NULL    |       |
+----------------+-------------+------+-----+---------+-------+
5 rows in set (0.00 sec)

创建新用户并授权

mysql> CREATE USER 'shiqiang'@'localhost' IDENTIFIED BY '150428';
Query OK, 0 rows affected (0.00 sec)

# 向新用户授权,使用两条命令
mysql> GRANT ALL PRIVILEGES ON my_suppliers.* TO 'shiqiang'@'localhost';
Query OK, 0 rows affected (0.01 sec)

mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

4.2.1 向表中插入新记录

准备从CSV文件中将记录加载到数据表中。

Python会将数据从CSV文件插入到数据表,然后展示表中数据。 4db_mysql_load_from_csv.py

#!/usr/bin/env python3
import csv
import MySQLdb
import sys
from datetime import datetime, date

# CSV输入文件的路径和文件名
input_file = sys.argv[1]
# 连接MySQL数据库
con = MySQLdb.connect(host='localhost', port=3306, db='my_suppliers', \
user='root', passwd='150428')
c = con.cursor()
# 向Suppliers表中插入数据

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Golang语言社区

使用 Go 语言学会 Tensorflow

Tensorflow 并不是一个专门用于机器学习的库,相反的,它是一个通用的用于图计算的库。它的核心部分是用 C++ 实现的,同时还有其它语言的接口库。Go 语...

56520
来自专栏PaddlePaddle

技术流|主流深度学习框架比较

目前市面上主流深度学习框架近十余种,每种框架各具特色。如何选择合适的深度学习框架?本篇对主流深度学习框架进行综合比较,帮助大家理清思路。

12820
来自专栏维恩的派VNPIE

采集CTP数据到MySql的代码样例

vn.py目前所使用的数据库是MongoDB,鉴于一些用户更加习惯使用mySql,论坛内desont提供了一个vn.py与mySql相结合管理数据的示例,感谢d...

17430
来自专栏Golang语言社区

Golang Template 简明笔记

作者:人世间 链接:https://www.jianshu.com/p/05671bab2357 來源:简书

10120
来自专栏互联网杂技

2018年3月份GitHub上最热门的Python项目:深度学习占半壁江山

https://github.com/NVIDIA/FastPhotoStyle Star 5978

13320
来自专栏AI研习社

Github 项目推荐 | 用 Python 实现的大规模线性回归、分类和排名库 —— lightning

Lightning 稳定版本的预编译二进制文件在主要平台可用,需要用 pip 安装:

18110
来自专栏农夫安全

Knock 子域名扫描工具

Knock是一款Python编写的工具,通过单词列表来枚举目标域上的子域。扫描DNS区域传输,并尝试绕过通配DNS记录。再最新版本中knockpy支持查询Vir...

91130
来自专栏PaddlePaddle

AI不思议|说说那些偶尔混淆的概念

但是产品和运营两队小伙伴一不小心就遇到概念混淆的场景,有些时候是自己记模糊了、有些时候自己没记错、却被别人“拐到沟里“了…

14010
来自专栏维恩的派VNPIE

适用于python3的CTP交易接口

目前vn.py官方适用的python版本是2.7,有关python3的版本正在开发中,但鉴于最近大家对python3需求的呼声较高,论坛有两个帖子提供了适用于p...

1K40
来自专栏互联网杂技

Propel: 由Node.js之父创建的JavaScript科学计算库

Propel 是一个新推出的 JavaScript 科学计算库,它使用图形处理器来支持 JavaScript 中的机器学习和科学计算。

17240

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励