MySQL基础 (MySQL数据库思想、安装流程及企业版本的选择、MySQL卸载 、MySQL重点命令、 MySQL插入操作 、python中安装mysql数据库、MySQLClient操作数据分析)

本文主要是介绍MySQL基础 (MySQL数据库思想、安装流程及企业版本的选择、MySQL卸载 、MySQL重点命令、 MySQL插入操作 、python中安装mysql数据库、MySQLClient操作数据分析),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据分析之MySQL

      • MySQL数据库思想
      • MySQL数据库的实战
      • MySQL企业级安装流程以及企业版本的选择
      • MySQL卸载
      • MySQL重点命令
      • MySQL插入insert操作
      • python中安装mysql数据库
      • 实现MySQLClient操作数据分析案例

MySQL数据库思想

  • 数据库是一种关系数据库
    (1)对于Java语言和其他计算机语言作为后台开发来讲,数据库的关系体现在1对1 、1对多、 多对多(由中间表产生) 、多对1。
    (2)在python数据分析、人工智能技术领域上关系的理解是:将数据通过numpy、pandas、matplotlib进行数据分析,体现在数据的发布思想!将数据发布给用户、人工智能设备作为数据集。

MySQL数据库的实战

(1)只能满足小型企业级的开发,对于数据集不是很适合!数据存储量较大!数据不安全!
(2)Oracle针对于大数据/人工智能利用很多。
(3)数据库分为DDL、DCL、DML语句。

  • DML:数据库操作语言(Data Mannipliulation Language)—用于检索或者修改数据
  • DDL:数据库定义语言(Data Defination Language)—用于定义数据的结构
  • DCL:数据库控制语言(Data Control Language)—用于定义数据库用户的权限DB

MySQL企业级安装流程以及企业版本的选择

(1)mysql分为客户端服务端,MySQL自身会携带基于dos的客户端和服务端
(2)安装注意事项

  • 用户名和密码设置:root root
  • 端口默认3306 Oracle默认
  • 编码格式默认是英文手动改为utf8。数据库中没有- * !。。。特殊字符
  • 编码格式忘记修改不需要删除MySQL,只需找到my,ini文件,修改配置文件,重启!

MySQL卸载

(1)进入控制面板删除MySQL安装程序包
(2)进入安装目录删除MySQL文件
(3)进入c盘window下/用户下找MySQL字样,全部删除
(4)cmd窗口输入regedit进入注册表找

  • 计算机\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MySQL
  • 计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL

(5)回收站删除文件
(6)重启计算机

MySQL重点命令

(1)mysql -hlocalhost -uroot -p ------->登录操作,输入密码进入
(2)show databases; ------->展示数据库
(3)use shop; —Database changed show tables; ------>显示指定库中的表
(4)create database 库名; ------>建库
(5)use 库名; create table 表名 (字段设定列表); ----->建表
(6)drop database 库名;  drop table 表名;------>删库和删表

char和varchar的区别
①varchar执行效率快,但会产生磁盘垃圾。数据库回收磁盘垃圾,会造成内存浪费。MySQL自身内存小不建议使用,Oracle追求读写速度建议使用!
②char执行效率较快,但是不产生磁盘垃圾。适合MySQL!

MySQL插入insert操作

(1) insert into 表 (字段名1,字段名2,字段名3)value(值1,值2,值3);---->字段名和值一一对应,数据安全、数据好维护、效率高!sql底层只执行一次匹配字段
(2) insert into 表 values(值1,值2,值3);----->字段和值没有一一对应,数据不是很匹配、数据不好维护、效率较高!sql底层只能先寻找key和value 执行2次以上匹配
(3)insert into 表 values(值2,值3);----->此写法必须满足id是主键,然后通过主键去自动匹配数据库的字段名对应的value

python中安装mysql数据库

(1) python3.2以前的版本官网下载exe文件安装
(2) python3.2以后的版本,cdm进入python的安装目录,执行命令pip install MySQLClient进行注册安装。-----企业大量使用!

实现MySQLClient操作数据分析案例

# 导包/模块
import os;
import pandas;
import MySQLdb;
# 连接数据库  
connection = MySQLdb.connect(host='localhost',user='root',passwd='root',db='python',charset='utf8');       
#导入数据到MySQL。遍历目录,把里面的所有数据入库
rootDir="C:\\ZhangTao\\python课件\\0808\\测试数据\\";
# 定义一个exeSQL输出SQL执行结果
def exeSQL(sql):print("exeSQL: " + sql)connection.query(sql);for fileName in os.listdir(rootDir): print(fileName)path = os.path.join(rootDir, fileName)     if ".txt" in fileName:path = path.replace("\\", "\\\\");#拿到文件名中的时间字段datetime = fileName[0:8];tableName = "订购明细" + datetime;#建表、导入数据到表中exeSQL("drop table if exists " + tableName)exeSQL("create table " + tableName + "(订单编号 int, 订购日期 datetime, 用户ID int, 产品 char(8), `单价(元)` int, 数量 int, 订购金额 int);");#mysql将数据导入表的固定语句exeSQL("LOAD DATA LOCAL INFILE '" + path + "' INTO TABLE `" + tableName + "` CHARACTER SET 'UTF8' COLUMNS TERMINATED BY ',' LINES TERMINATED BY '\\n' IGNORE 1 ROWS;");#建立日订购统计表exeSQL("create table if not exists 日订购统计表(统计日期 date, 订购用户数 int, 订购次数 int, 人均订购金额 double, 订购总额 double);");exeSQL("delete from 日订购统计表 where 统计日期='" + datetime + "';");exeSQL("insert into 日订购统计表 select '" + datetime + "', count(distinct 用户ID), count(用户ID), sum(订购金额)/count(distinct 用户ID), sum(订购金额) from `" + tableName + "`;");statDay = pandas.read_sql('select * from 日订购统计表;', con=connection);
#关闭数据库
connection.close();
print('\n日订购统计表数据如下:');
print(statDay);#绘图
font = {'family' : 'SimHei'
}matplotlib.rc('font', **font);# 1.折线图
plot1 = plt.plot(statDay['统计日期'], statDay['订购用户数']);
plt.show();
plot2 = plt.plot(statDay['统计日期'], statDay['订购次数']);
plt.show();
plot3 = plt.plot(statDay['统计日期'], statDay['人均订购金额']);
plt.show();
plt.legend(('订购用户数', '订购次数', '人均订购金额'))# 2.柱状图
x=statDay['统计日期']
x_labels=['0901','0902','0903','0904','0905','0906','0907','0908']
y=statDay['订购总额']
plt.bar(x,y,width=0.5)
plt.rcParams['font.sans-serif']=['SimHei'] #用来正常显示中文标签
plt.xticks(x,x_labels)
#修改x坐标
plt.xlabel('统计日期')
#修改y坐标
plt.ylabel('订购总额')
#添加标题
plt.title('柱状图')
plt.show()# 3.饼状图
price=statDay['订购总额']
prices=sum(statDay['订购总额'])
price_perc=price/prices
#添加名称
labels=['0901','0902','0903','0904','0905','0906','0907','0908']
#添加颜色
colors=['blue','red','blue','red','blue','red','blue','red']
#绘制饼状图  pie
plt.rcParams['font.sans-serif']=['SimHei'] #用来正常显示中文标签
# labels 名称 colors:颜色,explode=分裂  autopct显示百分比
paches,texts,autotexts=plt.pie(price_perc,labels=labels,colors=colors,autopct='%0.1f%%')
#设置饼状图中的字体颜色
for text in autotexts:text.set_color('white')
#设置字体大小
for text in texts+autotexts:text.set_fontsize(20)
plt.show()

结果如下:

①exeSQL: drop table if exists 订购明细20110908
②exeSQL: create table 订购明细20110908(订单编号 int, 订购日期 datetime, 用户ID int, 产品 char(8), 单价(元) int, 数量 int, 订购金额 int);
③exeSQL: LOAD DATA LOCAL INFILE ‘C:\ZhangTao\python课件\0808\测试数据\20110908.txt’ INTO TABLE 订购明细20110908 CHARACTER SET UTF8 COLUMNS TERMINATED BY ‘,’ LINES TERMINATED BY ‘\n’ IGNORE 1 ROWS;
④exeSQL: create table if not exists 日订购统计表(统计日期 date, 订购用户数 int, 订购次数 int, 人均订购金额 double, 订购总额 double);
⑤exeSQL: delete from 日订购统计表 where 统计日期=‘20110908’;
⑥exeSQL: insert into 日订购统计表 select ‘20110908’, count(distinct 用户ID), count(用户ID), sum(订购金额)/count(distinct 用户ID), sum(订购金额) from 订购明细20110908;

日订购统计表数据如下:

统计日期订购用户数订购次数人均订购金额订购总额
02011-09-0114649240531824.99419826734340.0
12011-09-0222134486472466.56004354594840.0
22011-09-0328248796093210.81209390699020.0
32011-09-0428016765343076.43846486189500.0
42011-09-05642780661391.9962668946360.0
52011-09-06669883811389.7790399308740.0
62011-09-07707189911406.2537129943620.0
72011-09-08661378591331.4108578804620.0

1.折线图
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
2.柱状图
在这里插入图片描述
3.饼状图
在这里插入图片描述

这篇关于MySQL基础 (MySQL数据库思想、安装流程及企业版本的选择、MySQL卸载 、MySQL重点命令、 MySQL插入操作 、python中安装mysql数据库、MySQLClient操作数据分析)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767234

相关文章

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

使用Python实现高效的端口扫描器

《使用Python实现高效的端口扫描器》在网络安全领域,端口扫描是一项基本而重要的技能,通过端口扫描,可以发现目标主机上开放的服务和端口,这对于安全评估、渗透测试等有着不可忽视的作用,本文将介绍如何使... 目录1. 端口扫描的基本原理2. 使用python实现端口扫描2.1 安装必要的库2.2 编写端口扫

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P