python数据库操作Mysql-Redis-Mongodb之一Mysql(一) - Go语言中文社区

python数据库操作Mysql-Redis-Mongodb之一Mysql(一)


欢迎进我的个人博客Danniel'S,不定时更新

讲讲数据存储

  1. 什么是数据库?
    数据库(DataBase)这个术语的用法很多,是一个以某种有组织的方式存储的数据集合,顾名思义它好比一个电子化文件柜(保存有组织的数据的容器),可以对其进行新增、查找、更新删除等操作。
    2018年1月数据库排名TOP10(数据来源于网络)(https://db-engines.com/en/ranking)

    Image (5).png

  2. 常用数据库有三种

数据库名 类型 用途
mysql 关系型数据库 无所不能,受到真正的批评是它并不总是支持其他DBMS提供的功能和特性
mongodb 基于分布式文件存储的数据库 海量存储数据
redis 内存数据库 redis做高速缓存 ,可用来调度

mongodb非关系型数据库,不需要太费心去考虑爬下来数据的关系结构,而且爬数据往往比较杂乱,不容易统一数据关系,mongodb存数据的时候也不需要关系检测,而且mongo缓存机制好一些,存数据也快一些。mongodb存储好后,假如需要清洗分析数据,我就会考虑将mongodb导入到mysql。

  1. 数据库之一:MySQL
    正如上述所说的,数据的所有存储、检索、管理和处理实际上是由数据库软件--DBMS(数据库管理系统)完成的,MySQL 是一种DBMS,是一种数据库软件。
    为什么会有那么多的公司和开发人员使用MySQL呢?以下列出其原因:
  • 成本:MySQL是开源的,一般可以免费使用(甚至可以免费修改)
  • 性能:MySQL执行快
  • 简单 MySQL很容易安装和使用

MySQL如何安装?

  1. MySQL for linux
    Ubuntu、centos系统下 安装MySQL 这里就拿ubuntu举例
    首先:
    sudo apt-get update #系统检测更新
    sudo apt-get install mysql-server #安装mysql服务
    sudo mysql_secure_installation #配置mysql安全脚本
    系统将提示您在安装过程中创建 root 密码。选择一个安全的密码,并确保你记住它,因为你以后需要它。接下来,我们将完成 MySQL 的配置。
    BUG点提示:
    MySQL提示:The server quit without updating PID file问题的解决办法
    出错地方:
MySQL server PID file could not be found![失败]
Starting MySQL...The server quit without updating PID file (/usr/local/mysql/data/snsgou.pid).[失败]

问题可能原因有多种,具体什么原因最好的办法是先查看下错误日志,这里我就不一一举例了,因为这不是我的正题,还是来点简单粗暴的方式:
直接删除mysql再安装

  • 删除mysql
    sudo apt-get autoremove --purge mysql-server-5.0
    sudo apt-get remove mysql-server
    sudo apt-get autoremove mysql-server
    sudo apt-get remove mysql-common (非常重要)
  • 清理残留数据
    dpkg -l |grep ^rc|awk '{print $2}' |sudo xargs dpkg -P
  • 安装mysql
    sudo apt-get install mysql-server
    sudo apt-get install mysql-client
  • 检查mysql是否正在运行
    一旦安装完成,MySQL服务器应该自动启动了,你可以在终端输入命令来检查MySQL服务器是否正在运行
    sudo netstat -tap | grep mysql
    能看到类似的运行结果
    root@ubuntu:~# sudo netstat -tap | grep mysql
    tcp 0 0 localhost.localdo:mysql : LISTEN 870/mysqld
    如果服务器不能正常运行,您可以通过下列命令启动它:

sudo /etc/init.d/mysql restart
通过上述命令检查之后,如果看到有mysql 的socket处于 listen 状态则表示安装成功。
  登陆mysql数据库可以通过如下命令:

mysql -u root -p
-u 表示选择登陆的用户名, -p 表示登陆的用户密码,上面命令输入之后会提示输入密码,此时输入密码就可以登录到mysql。

  1. MySQL for win
    MySQL官方下载地址(https://www.mysql.com/downloads/
    MySQL Enterprise Edition 企业版
    MySQL Cluster CGE 集群
    MySQL Community Edition 社区版

开始步入正题

ae4e363b52aeaa6368cef5528984f4bc.jpg
  • 从官网下载包


    20180410161230.png

    20180410162014.png

    1.png

    2.png

    3.png
  • 点击下载并完成后安装mysql
    双击下载好的mysql安装文件“mysql-installer-community-5.7.21.0.msi”打开安装程序,打开后需要稍等一下


    4.png
  • 选择安装类型(个人需求选项


    5.png
  • 我这里选择自定义安装
    ε=(´ο`*)))唉 卸了装,装了卸 为了一日记整的不想截图了 满桌面屏幕全是图片
    直接找个详细教程的放一哈 (https://www.cnblogs.com/jjg0519/p/6753465.html

mysql可视化管理软件推荐使用Navicat for MySQL premium,记得一定要专业版哦 补丁网上一大堆,没事多google,多向度娘提问。
这里放个ubuntu的Navicat for mysql安装及永久使用

Ubuntu Navicat for MySQL安装及永久使用

首先登陆Navicat官网下载Linux版本: https://www.navicat.com.cn/download/navicat-premium

1. 下载 navicat112_premium_cs_x64.tar.gz 文件

2. 下载后解压tar文件

tar -zxvf  /home/wilbur/download/navicat112_premium_cs_x64.tar.gz 

3. 解压后  进入解压后的目录运行命令:
./start_navicat   

OK,这样就完啦

创建Navicat快捷方式,cd usr/share/applications,sudo vim navicat.desktop

[Desktop Entry]
Encoding=UTF-8
Name=Navicat
Comment=Navicat Premium
Exec=/opt/Navicat/start_navicat
Icon=/opt/Navicat/navicat.png
Terminal=false
StartupNotify=true
Type=Application
Categories=Application;Development;

连接上数据库后里面的中文数据是乱码,如果是用的中文版,界面也会是乱码,需要修改字符集,修改方法:

1.打开start_navicat文件,会看到 export LANG="en_US.UTF-8" 将这句话改为 export LANG="zh_CN.UTF-8"

2.查看系统支持的字符集: locale -a

3.修改字符集: export LANG=zh_CN.utf8

注意:start_navicat文件和终端locale命令的返回信息这一句:export LANG=zh_CN.utf8一定要保持一致

4.还需要修改数据库字符集。vim打开/etc/mysql/mysql.conf.d路径下的mysqld.cnf文件,

   sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf,

   在[mysqld]段落中添加如下两行:

   character-set-server=utf8

   collation-server=utf8_general_ci

   重启MySQL:/etc/init.d/mysql restart

   输入密码登录:mysql -uroot -p

   然后查看数据库字符集设置:

  danniel@dylan:~$ mysql -u root -p

   mysql> show variables like 'character_set_%';



   查看字符集排序设置:

   mysql> show variables like 'collation_%';



   返回结果如图所示就大功告成了。

再推一个mysql工具 mycli 优于新手使用,毕竟在写sql语句时能有提示嘛,等玩六了,就还是直接用mysql写sql语句把

MySQL如何操作?

这在就不重复写了,可以回看我原先个人博客记录的笔记(https://dannieldylan.github.io/danniel/2018/01/21/MySQL%E6%95%B0%E6%8D%AE%E5%BA%93%E7%9F%A5%E8%AF%86%E5%B0%8F%E7%BB%93/

推荐书书籍
mysql必知必会 、 mysql技术内幕
redis开发与运维,redis实战
mongodb权威指南,mongodb管理与开发精要,mongodb实战。

感谢您的阅读,以上是本人遇到过或学习过程记录的笔记,水平有限,仅供参考,如果发现错误请及时联系作者,谢谢!

版权声明:本文来源简书,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://www.jianshu.com/p/ed5d96a269f5
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-01-12 13:24:27
  • 阅读 ( 1607 )
  • 分类:数据库

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢