当前位置:Gxlcms > 数据库问题 > MySQL数据库初识

MySQL数据库初识

时间:2021-07-01 10:21:17 帮助过:8人阅读

      其中最后一句挺重要的:不同数据库系统之间的SQL不能完全相互通用

    

    常用的关系型数据库:

技术图片 常见的关系型数据库介绍

 

2.2 非关系型数据库  

    非关系型数据库也被成为NoSQL数据库,NOSQL的本意是“Not Olnly SQL” 
    指的是非关系型数据库,而不是“No SQL”的意思,因此,NoSQL的产生并不是要彻底地否定关系型数据库,而是作为传统关系型数据库的一个有效补充。NOSQL数据库在特定的场景下可以发挥出难以想象的高效率和高性能。 

    随着互联网Web2.0网站的星期,传统的关系型数据库在应付web2,0网站,特别是对于规模日益扩大的海量数据,超大规模和高并发的微博、微信、SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题。 

    例如:传统的关系型数据库IO瓶颈、性能瓶颈都难以有效突破,于是出现了大批针对特定场景,以高性能和使用便利为目的功能特异化的数据库产品。NOSQL(非关系型)类的数据就是在这样的情景下诞生并得到了非常迅速的发展 

    高性能、高并发、对数据一致性要求不高 
    开源的NoSQL体系,如Facebook的Cassandra,Apache的HBase,也得到了广泛认同,Redis,mongb也逐渐越来越受到各类大中小型公司的欢迎和追捧 

    NOSQL非关系型数据库小结: 
    1、NOSQL不是否定关系数据库,而是作为关系数据库的一个重要补充 
    2、NOSQL为了高性能、高并发而生,忽略影响高性能,高并发的功能 
    3、NOSQL典型产品memcached (纯内存),redis(持久化缓存),mongodb(文档的数据库) 

    

    非关系型数据库又分为以下4种

技术图片 非关系数据库分类

 

    常见的非关系型数据库

技术图片 常见的非关系型数据库介绍

 

  看了这么多的数据库,我们主要讲的是MySQL,这个公司里面非常常用的又非常nb的关系型数据库,后面还会将一些非关系型数据库的使用,来吧,我们好好认识一下MySQL,看下一节介绍!

 

二 MySQL介绍

   

  1.mysql版本
    双授权版本:社区版(完全免费,功能也够nb了)和商业版(更好,功能更多更强大一些,但是收费,VIP,有售后服务,也会参考和吸收社区版的一些nb的功能,安全性和稳定性都是最好的,大几十万),一般NB的开源软件都是双授权的
    每个版本又分四个版本依次进行发布:
      Alpha版:一般只在开发公司内部使用,不对外公开,测试、自我检查的版本
      Beta版:一般是开发完也测试完的版本,一般不会出现比较大的性能bug(一般我们不用,阿里、去哪儿会使用这个版本,有些新功能,内部有高手能调,也能评估新功能的性能)
      RC版:根据Beta版测试之后收集到一些bug等在进行完善的一个版本
      GA版:软件正式发布的版本,没有特别的需求一定要使用GA版,有些公司追求新功能会使用Beta版,这是个例。

  2.MySQL的产品线:(mysql是C++写的,oracle 9i版本之前是C语言写的,之后主要是java)
    最早期,mysql是按照3.x--4.x--5.x等来开发的,但是为了提高MySQL的竞争优势,以及提高性能、降低开发维护成本等原因,同时,更方便企业用户更精准的选择合适的版本产品用于自己的企业生产环境中,MySQL在发展到5.1系列版本之后,重新规划为三条产品线。
    第一条:5.0.xx 到 5.1.xx产品线系列介绍
    第二条:5.4.xx 到 5.7.xx产品线系列介绍(主流:5.5和5.6)
    第三条:6.0.xx 到 7.1.xx产品线系列介绍

  3. MySQL数据库软件命名介绍

    以mysql-5.6.42.tar.gz的版本号来解释:
      1.第一个数字5是主版本号,描述了文件格式。所有版本5发行都有相同的文件格式。
      2.第二个数字6是发行级别。主版本号和发行级别组合到一起便构成了发行序列号。
      3.第三个数据42是在此发行系列的版本号,随每个新发布版递增。通常你需要已经选择发行的最新版本,每次更新后,版本字符串的最后一个数字会递增。如果增加了一些新功能或者微小的不兼容性,版本字符串的第二个数字会递增。如果文件格式改变,第一个数字会递增。
    一般有的版本也会加上上面我们说的4个版本的后缀,beta、alpha、rc版、ga版等等,我们举得这个例子是不带后缀的,就相当于GA版

 

  4.1 MySQL版本选择建议
    1.稳定版:选择开源的社区版的稳定版GA版本
    2.产品线:可以选择5.1、5.5、5.6,互联网公司主流5.5和5.6,其次是5.1.
    3.选择MySQL数据库GA版发布后6个月以上的GA版本。
    4.要选择前后几个月没有大的BUG修复的版本,而不是大量修复BUG的集中版本
    5.最好向后较长时间没有更新发布的版本。
    6.开发、测试、运维、DBA进行自己本地测试的时候,最好要和线上的版本一致,最差也要兼容,所以作为开发,你要清楚公司用的哪个版本的数据库
    7.作为内部开发测试数据库环境,跑大概3-6个月的时间。
    8.优先企业非核心业务采用新版本的数据库GA版本的软件。
    10.想DBA高手请教,或者在技术分为好的群里和大家一起交流,使用真正高手用过的好用的GA版本产品


    经过上述工序后,若没有重要的功能BUG或者性能瓶颈,则可以开始考虑作为任何业务数据服务的后端数据库软件。

   好了,同志们,铺垫了这么多,我们要开始学习实战内容啦,来看第四大节,修改密码~~

 

三 MySQL的下载安装、简单应用及目录介绍

  1.下载安装

    这个下载安装内容我专门整理了一个博客,专门针对的windows10的:Win10下安装MySQL5.6,大家参考其中的第二种下载安装方法,我们后面的学习就是根据第二种方法来的。

    linux系统下MySQL数据库企业生产中常用的4中安装方法介绍(将来如果需要你一个开发人员来安装数据库或者自己想研究数据库的时候再自行去研究吧~~~这里就简单给大家提一下~~~)
      1.yum/rpm方式安装MySQL
      2.常规方式编译安装MySQL
      3.采用cmake方式编译安装MySQL
      4.采用二进制方式免编译安装MySQL

    以上的安装方法都可以,性能上也不会有太多的差距,只是不同层次的人的安装习惯不同,了解一下就可以了,多数的运维人员习惯使用cmake编译方式安装,如果数据库服务器很多,而且对定制化有要求,可以选择通过源码定制rpm包,搭建yum参数的方式安装,但是需要你有一定的能力,还有好多专业的DBA选择二进制免编译安装的方式进行安装。

    将来大家更多的是面对linux下的mysql安装和使用(没有包含上述的所有安装方法),我也给大家整理了一篇博客(centos7.1下安装mysql5.6):CentOS 7 安装 MySQL

    如果我上面这篇博客安装的时候有问题,并且自己解决不了的话,删除你已经安装的mysql,然后看另外一篇博客进行安装(centos7下安装mysql5.6),其实道理都差不多,我的那一篇详细一些,还有一些关于防火墙的设置,话不多说。这一篇博客也挺好的,转载过来给大家看看:Centos7安装并配置mysql5.6完美教程

     如果你们公司用的是红帽或者是Ubuntu,可以自行百度教程来尝试安装,这里我就不给大家演示啦。

     这位同学,如果你mac本,我给你找了两篇博客,可以参考一下,我大致看了一下,过程是差不多的:

        mac 安装mysql5.6 :https://blog.csdn.net/mike694439716/article/details/48218239?utm_source=blogxgwz0

        mac 安装tar.gz版MySQL5.6:https://blog.csdn.net/zmx729618/article/details/72769840

        如果Mac本安装完mysql之后,登陆以后,不管运行什么指令,总是提示这个:mac mysql error You must reset your password using ALTER USER statement before executing this statement.

        你需要做的就是修改密码就行了,默认安装完成之后,mysql应该是安装在了/usr/local/mysql这个目录下,里面的目录结构和windows的是一样的。

 

     mysql安装的简单总结:

技术图片 win10下安装mysql

 

技术图片 linux下安装mysql

     

    在linux上使用mysql的时候,一定要注意的就是权限问题,linux恶心的地方就是权限问题。

 

  2.mysql的简单使用演示

    这里只是给大家演示一下mysql是个什么样子,具体怎么管理数据,后面我们会学,这里只做演示用,因为演示一下之后,你对这个东西就有了一些简单的认识和了解,再进行后面的学的时候,你就不会摸着黑听理论了,所谓的瞎听了,哈哈。注意,我们下面会输入一些指令进行操作数据库,数据库里面的指令必须要用;分号结尾,然后才能执行,切记。
      1.开启服务端,mysqld\ net start mysql
      2.使用mysql自带的客户端进行连接,cmd下输入mysql -u root -p,然后回车,会提示你输入密码,此时初始的root用户还没有密码,所以还是直接回车就可以连接上了
      3.show databases;先不讲里面的内容,说一下这是几个库,每个项目可以有自己单独的一个库,里面放这个项目的所有数据表
      4.创建一个库:create database CRM;然后show databases;查看一下就有了这个crm库,不分大小写,统一会变成小写,对照着我们mysql安装目录下的data文件夹里面的内容看一下,库就是对应的文件夹。
      5.我们目前在所有数据库之上,想在我们自己项目的库里面操作数据,就需要切换到我们自己这个crm项目的库里面进行数据的操作,切换数据库使用use + 库名,例如:use crm;就提示你切换成功了。
      6.我们说过,库里面维护的数据就像一张一张的数据表,类似excel,对不对,那我们创建一张表看一下,命令:
      create table student(
        id int,
        name char(10),
        age int
      );
      7.再执行show tables;就可以看到有了一个student表
      8.查看一下这个表里的数据select * from student;发现什么数据也没有
      9.插入几条数据,写几条数据:insert into student values(1,‘d‘,18),(2,‘x‘,11),(3,‘d‘,10),(4,‘k‘,9);然后回车,就执行了这条指令,然后我们再查看一下这个表里面有没有数据了,执行上一条指令,select * from student;发现里面就有数据了:
        结果:
        mysql> select * from student;
        +------+------+------+
        | id | name | age |
        +------+------+------+
        | 1 | d | 18 |
        | 2 | x | 11 |
        | 3 | d | 10 |
        | 4 | k | 9 |
        +------+------+------+
        4 rows in set (0.00 sec)

    分析一下:上面这些就是mysql数据帮我们保存的数据,以表格的外貌展示,第一行为表头,从第二行开始都是对应的数据,每列都是自己这一列规定的内容,比如id这一列是你插入的这几条数据的id,我们这个insert就是插入数据,select就是查看数据,这就是我们通过MySQL自带的客户端来操作的MySQL服务端来进行数据的操作。MySQL服务端和操作系统及硬盘打交道,快速的帮你实现数据的操作,其他的语言开发的客户端就是通过这种形式来操作数据库里面的数据的,将来我们使用python操作数据库的时候,会使用一个叫做pymysql的工具来搞,到时候会给你们讲,他就是一个咱们MySQL服务器的客户端,连接上服务端就可以操作服务端的保存的你的项目的数据了。例如用户要查看自己的信息,就通过你写的程序接受到客户的请求,通过自己的mysql客户端去MySQL服务端查看对应的信息,然后mysql服务端将这些信息发送给你的py程序客户端,你通过程序再将数据返回给你的用户,你的用户就看到了自己的信息,就是这么个过程,大家理解了吗。
    真正的数据库维护优化等高级数据库的技术一般都是由公司的DBA来做,或者由比较懂数据库的运维来做,一般不会让开发来搞,除非你开发人员的数据库能力很强,这些NB的技术包括:数据库优化,数据库BUG解决,数据库备份(冷备、热备),保证数据不丢失,集群,高可用等等保证项目的稳定性和可用性及高并发用(很多的用户都来操作数据,你要并发),数据库各项配置参数的调优,慢sql语句的提炼和调优,数据库开发、数据库更新,数据迁移,数据恢复,分库分表等等,这些是数据库的高端技术,而针对开发人员,一般你需要学习这些:基本的开发环境使用的数据库搭建,然后增删改查就差不多了。当然如果想提升自己的能力和水平(还有薪资水平),数据库是你必须要学好的内容,但是那是你做开发之后的事情了,而且有好多同学目前已经在数据库或者运维方面很NB了,但是开发还不行啊,对不对,哈哈,好好学python,数据库不是你学习python的重点,但是必须要会一些基本的内容,懂得越多越好,ok吗,同志们~~~
    

   3.MySQL安装目录介绍

    看图:

      技术图片

    其中,我们重点看一下data文件夹:如果你找不到自己建立的库或者表的文件,可能不在这个data文件夹下面,连接上mysql之后,输入show global variables like "%datadir%";来查看数据文件存储路径,找到路径之后,到对应路径下如果找不到这个文件夹,那么可能是隐藏的,把隐藏的文件显示一下就行了。

        技术图片

        技术图片

      

    关于数据库中的这4个初始的库的详细介绍,有兴趣的同学可以来看看我的这篇文章(目前作为了解用):MySQL5.6的4个自带库详解

    其中mysql这个库我需要提一下:

      mysql:这个是mysql整个服务的核心数据库,类似于sql server中的master表,主要负责存储数据库的用户、权限设置、关键字等mysql自己需要使用的控制和管理信息。不可以删除,如果对mysql不是很了解,也不要轻易修改这个数据库里面的表信息。

  总结:其实这些库就是我们电脑上对应的文件夹,在mysql中显示为对应的库,来方便我们管理数据,而文件或者文件夹这种与硬盘打交道的事情就交给mysql了,我们只需要对mysql库中的数据进行操作就可以了,你可以看到,我们刚才简单使用的时候创建的一个crm库,也就是在data目录下的生成了一个crm文件夹。

  说到这里,大家对数据库有个基本的了解了呢。那么我们返回去看一下mysql的一些其他知识(提高逼格的内容~~),回到数据库分类及mysql介绍~~~~~

 

四 root用户密码设置及忘记密码的解决方法

  再怎么说我们的root用户密码也不能为空啊对不对,所以需要设置一个密码,看下面设置密码的方法,我给了三种方法:

  方法1: 用SET PASSWORD命令 

    首先登录MySQL,使用mysql自带的那个客户端连接上mysql。 
    格式:mysql> set password for 用户名@localhost = password(‘新密码‘); 
    例子:mysql> set password for root@localhost = password(‘123‘); 

  

  方法2:用mysqladmin 

 

(因为我们将bin已经添加到环境变量了,这个mysqladmin也在bin目录下,所以可以直接使用这个mysqladmin功能,使用它来修改密码)

    关于mysqladmin的介绍:是一个执行管理操作的客户端程序。它可以用来检查服务器的配置和当前状态、创建和删除数据库、修改用户密码等等的功能,虽然mysqladmin的很多功能通过使用MySQL自带的mysql客户端可以搞定,但是有时候使用mysqladmin操作会比较简单。
    格式:mysqladmin -u用户名 -p旧密码 password 新密码 
    例子:mysqladmin -uroot -p123456 password 123 

    只用mysqladmin的时候,会出现一个warning警告信息:Warning: Using a password on the command line interface can be insecure.,这个没关系,是提示你,你直接在cmd下使用明文设置密码的时候,是不安全的,因为别人可以通过翻看你输入指令的历史记录来查看到你设置的密码,所以提示你一下,不信你按上下键,可以看到自己之前输入的命令,或者输入下面这个指令也可以看到:

    技术图片

    所以我们最好连接进入到mysql里面之后,在进行密码的修改和设置。


  方法3:用UPDATE直接编辑那个自动的mysql库中的user表 

    首先登录MySQL,连接上mysql服务端。 
    mysql> use mysql;   use mysql的意思是切换到mysql这个库,这个库是所有的用户表和权限相关的表都在这个库里面,我们进入到这个库才能修改这个库里面的表。
    mysql> update user set password=password(‘123‘) where user=‘root‘ and host=‘localhost‘;   其中password=password(‘123‘) 前面的password是变量,后面的password是mysql提供的给密码加密用的,我们最好不要明文的存密码,对吧,其中user是一个表,存着所有的mysql用户的信息。

    mysql> flush privileges;  刷新权限,让其生效,否则不生效,修改不成功。

  在忘记root密码的时候,可以这样(注意:root密码最好不要忘记,找地方记录下来,不然如果是工作中你们使用的数据库(不管是测试的还是线上的,都是比较麻烦的事情,数据库轻易不会让你重启的,不过作为一个开发来讲,你应该是无法用root用户的~~~))
  以windows为例: 
    1. 关闭正在运行的MySQL服务,net stop mysql(这个mysql是你添加的mysqld到系统服务时的服务名)。 
    2. 打开DOS窗口,转到mysql\bin目录。 
    3. 输入mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证,因为之所以mysql启动之后,客户端连接的时候需要登陆认证,输入密码什么的,是因为mysql服务端启动的时候,加载了自己内部的一些权限相关信息的授权表、权限认证表什么的,这样就要求客户端必须有认证,如果启动的时没有加载这些表和设置,那么我们客户端再进行登陆的时候,就不需要认证了,那么就可以登陆上了,登陆之后,我们到mysql这个存有所有用户信息的表中去修改root用户或者别的用户的密码了,还是比较6的,但是这样搞需要关闭服务端,在实际工作中想关闭mysql服务??你觉得可能吗??记住这个问题,我后面给大家解决。 

      注意一个问题,如果我们直接使用的上面这个指令,也即是mysqld --skip-grant-tables,也就是直接通过mysqld启动的mysql服务的话,我们就不能通过net stop mysql的方式来关闭mysql服务了。但是可以通过别的方式来关闭,我在安装mysql的那篇博客里面写到了,杀进程的方式,知道你肯定忘记了,再给你写一下(win10):tasklist |findstr mysqld找到这个mysqld服务的端口号,然后taskkill /F /PID 端口号来杀死这个mysql服务的进行,以后就可以使用net start/stop mysql的方式来启动和关闭了。

      技术图片

    4. 再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。 
    5. 输入mysql回车,如果成功,将出现MySQL提示符 >。 
    6. 连接权限数据库: use mysql; 。 
    6. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号) 。 
    7. 刷新权限(必须步骤):flush privileges; 。凡是涉及到密码修改或者后面我们会学到的权限修改,修改完之后全部要再执行一下这一句。 
    8. 退出 quit。 
    9. 注销系统,再进入,使用用户名root和刚才设置的新密码123登录。

   注意:我们在使用cmd的时候,经常需要使用管理员身份来运行cmd窗口,每次都需要自己右键选择管理员身份运行,很麻烦,所有有永久解决的方法,看我下面的操作:

    1、去”C:/Windows/System32”目录找到”cmd.exe”: 
      技术图片

    2、右击属性,选择“以管理员身份运行”: 
      技术图片

    

    永久解决办法:

      1、创建“cmd.exe”快捷方式: 
        技术图片

      2、右击选择“属性”,选择“快捷方式”,再选择“高级”,在选择“以管理员身份运行”,再单击“确定”。 
      技术图片

      以后只要打开快捷方式就可以以管理员的身份运行cmd了!

 

 

****总结一下*****,到目前为止,我们已经大致了解mysql了,并且知道怎么使用自带的mysql客户端来连接mysql服务端,还知道怎么修改密码什么的了,那后面的我们是不是就应该实战了呢,哈哈,实战之前,本来想带着大家使用xshell这个客户端工具来操作一下mysql,不过学它需要一些后面的知识,后面再学吧~~~不过还需要做一件事情,那就是数据库的编码问题,我们知道自己写socket简单对话程序的时候还需要双方规定好编码方式,是gbk啊还是utf-8啊等问题,不然容易报错或者乱码,对吧,mysql也存在这个问题,这个问题搞不清楚,将来你们学习、甚至工作中都会非常头疼~~~来,我们就学一下怎么把mysql的编码调好~~~

 

五 修改字符集编码

  

  使用数据库的时候要注意的字符集编码,其实主要的是中文乱码的问题,大家应该对编码比较熟悉了,双方沟通需要编码相同不然容易报错或者出现乱码的问题,在使用数据库的时候也会存在这样的问题,所以我们需要解决这个问题:
    先来模拟一下这个问题:
    我们将刚才的student数据表删除,我们再来创建一个student表,然后往这个表里面插入几条含有中文的数据来看一下效果:
      1.create table student(id int,name char(10),age int);
      2.insert into student value(1,‘呵呵‘,11),(2,‘老刁‘,12),(3,‘dsb‘,10),(4,‘你好‘,9);
      3.select * from student;
      +------+------+------+
      | id | name | age |
      +------+------+------+
      | 1 | ?? | 11 |
      | 2 | ?? | 12 |
      | 3 | dsb | 10 |
      | 4 | ?? | 9 |
      +------+------+------+
      4 rows in set (0.00 sec)
    发现什么问题,插入的中文怎么成了??号了,乱码了。。。
    什么原因呢?我们先来看看我们创建这个crm库的时候,是怎么创建的,输入查看库创建的是时候mysql内部实际执行的创建语句的指令(咱们自己写了个指令,但是mysql在执行的时候会按照自己的方式来执行这个执行,现在就看看它实际执行的时候是个什么语句):show database crm\G;然后看结果:
      mysql> show create database crm\G
      *************************** 1. row ***************************
      Database: crm
      Create Database: CREATE DATABASE `crm` /*!40100 DEFAULT CHARACTER SET latin1 */
      1 row in set (0.04 sec)
    可以看到,我们创建这个库的时候,mysql默认帮我们指定了一个字符集:latin1,就是上面的后面半句DEFAULT CHARACTER SET latin1,创建库的时候默认指定了latin1的意思是,在这个库里面我们创建的数据表,只要没有给表指定字符集,那么这个库里面的所有表都将是latin1字符集的(除了库创建的时候可以指定字符集之外,创建表的时候也可以指定字符集),来看一下创建表的时候,查看表创建语句的指令(此时我们并没有在创建表的时候指定字符集对吧):show create table student\G;看结果:
      mysql> show create table student\G;
      *************************** 1. row ***************************
      Table: student
      Create Table: CREATE TABLE `student` (
        `id` int(11) DEFAULT NULL,
        `name` char(10) DEFAULT NULL,
        `age` int(11) DEFAULT NULL
      ) ENGINE=InnoDB DEFAULT CHARSET=latin1
      1 row in set (0.00 sec)

    发现创建表的时候,mysql也默认给我们指定了一个字符集,也是latin1,因为库就是latin1的。
    下面我们来看一下MySQL的一些初始信息:通过指令(\s)来查看,注意只需要看里面的有关characterset的部分
      mysql> \s
      --------------
      mysql Ver 14.14 Distrib 5.6.42, for Win64 (x86_64)

      Connection id: 12
      Current database: crm
      Current user: root@localhost
      SSL: Not in use
      Using delimiter: ;
      Server version: 5.6.42 MySQL Community Server (GPL)
      Protocol version: 10
      Connection: localhost via TCP/IP
      Server characterset: latin1 #服务端是latin1
      Db characterset: latin1 #数据库默认是latin1
      Client characterset: gbk #我们现在用的客户端是gbk
      Conn. characterset: gbk #双方连接也是gbk编码的,这个不用管
      TCP port: 3306
      Uptime: 4 days 18 hours 52 min 50 sec

      Threads: 1 Questions: 88 Slow queries: 0 Opens: 70 Flush tables: 1 Open tables: 61 Queries per second avg: 0.000
      --------------

    上面看的不够清晰,那么我们再看一下各个角色的编码(客户端、服务端,数据库等等):
    在mysql中执行指令:show variables like ‘%char%‘;看结果:
      mysql> show variables like "%char%";
      +--------------------------+-------------------------------------------+
      | Variable_name | Value |
      +--------------------------+-------------------------------------------+
      | character_set_client | gbk |
      | character_set_connection | gbk |
      | character_set_database | latin1 |
      | character_set_filesystem | binary |
      | character_set_results | gbk |
      | character_set_server | latin1 |
      | character_set_system | utf8 |
      | character_sets_dir | F:\jj\mysql-5.6.42-winx64\share\charsets\ |
      +--------------------------+-------------------------------------------+
      8 rows in set (0.00 sec)

    关于上面这些编码的详细解释,看我的博客:MySQL字符集详解,我就不给大家详细说啦。


    那为什么出现乱码问题呢?又如何解决乱码问题呢?
      原因:因为客户端mysql的字符集和服务端的字符集不一样,注意一下其中的character_set_client、character_set_connection、character_set_results这三项,我们在这里可以简单称为客户端三炮,就是因为这三炮和服务端的编码不一致导致的,所以我们需要将这三项改为和服务端一致的字符集就可以了。
      解决方案:

        一.在插入数据之前,先执行一条指令:set names latin1;

临时修改客户端三炮的字符集,让客户端插入数据的时候按照服务端的字符集编码来插入数据,然后我们再插入一条数据,然后看效果:
            mysql> set names latin1;
            Query OK, 0 rows affected (0.14 sec)
          然后我们再查看一下编码:
            mysql> show variables like "%char%";
            +--------------------------+-------------------------------------------+
            | Variable_name | Value |
            +--------------------------+-------------------------------------------+
            | character_set_client | latin1 |
            | character_set_connection | latin1 |
            | character_set_database | latin1 |
            | character_set_filesystem | binary |
            | character_set_results | latin1 |
            | character_set_server | latin1 |
            | character_set_system | utf8 |
            | character_sets_dir | F:\jj\mysql-5.6.42-winx64\share\charsets\ |
            +--------------------------+-------------------------------------------+
            8 rows in set (0.00 sec)
          发现客户端三炮都改为和服务端一致的latin1了,按照我们刚才说的,按理说再插入数据应该就不会乱码了。来插入一条数据试试看:

            mysql> insert into student value(5,‘不乱了吧‘,111);
            Query OK, 1 row affected (0.09 sec)

            mysql> select * from student;
            +------+----------+------+
            | id | name | age |
            +------+----------+------+
            | 1 | ?? | 11 |
            | 2 | ?? | 12 |
            | 3 | dsb | 10 |
            | 4 | ?? | 9 |
            | 5 | 不乱了吧 | 111 | #再次插入的数据就不乱吗了,但是之前乱码的内容还是乱码的内容
            +------+----------+------+
            5 rows in set (0.00 sec)
          总结:在进行DQL和DML语句(关于DQL和DML的解释我们后面会讲的,你就理解为一些sql语句)之前,先执行set names latin1;
但是我们如果断开连接,退出数据库之后,在连接进来以后,插入数据时如果不执行set names latin1,还是会乱码,说明这句指令没有让字符集永久生效。
          不信,我们退出一下,然后再连接进来看看:
            mysql> quit
            Bye

            C:\Users\chao>mysql -uroot -p #连接进来

            mysql> use crm; #切换库
            Database changed
            mysql> select * from student; #查看crm库中的student表中的数据
            +------+-----------+------+
            | id | name | age |
            +------+-----------+------+
            | 1 | ?? | 11 |
            | 2 | ?? | 12 |
            | 3 | dsb | 10 |
            | 4 | ?? | 9 |
            | 5 | ??????°? | 111 |
            +------+-----------+------+
            5 rows in set (0.00 sec)

          发现还是tm的乱码,真恶心啊,果然没有永久生效,我们在使用一下set names latin1;然后再查看一下表中的数据
            mysql> set names latin1;
            Query OK, 0 rows affected (0.00 sec)

            mysql> select * from student;
            +------+----------+------+
            | id | name | age |
            +------+----------+------+
            | 1 | ?? | 11 |
            | 2 | ?? | 12 |
            | 3 | dsb | 10 |
            | 4 | ?? | 9 |
            | 5 | 不乱了吧 | 111 |
            +------+----------+------+
            5 rows in set (0.00 sec)
          发现第五条数据,也就是我们之前使用latin1插入的数据,在查看之前使用set names latin1;还是可以看到对应的不乱码的数据的,因为我们就是以latin1的字符集插入的,只是查看的时候客户端三炮还是之前的gbk的编码,所以直接查看结果的时候还是乱码的。
          这样虽然可以解决乱码问题,但是没办法永久解决乱码问题,所以每次在进行sql语句输入之前都要先执行一下set names latin1;(latin1这里代指的是服务端的字符集,不一定就是latin1),所以我们还有其他的方法来解决,修改配置文件,看第二种方法!
          注意一点:如果想把之前已经乱码的数据改为不乱码,在工作中,我们需要将数据全部导出来,然后重新建库建表,再把数据导进来。

 

        二.在配置文件里面修改客户端和服务端参数

可以实现set names latin1;的效果,并且永久生效
          首先回答一个问题:至于为什么MySQL中的编码是latin1,是因为这是人家mysql规定好的,并写在自己的运行程序中的,只要mysql启动的时候,我们没有给人家指定一个字符集,那么它就会按照自己程序中写好的这个字符集来运行。
          所以,我们如果想永久的更改mysql的字符集(不管是客户端还是服务端的),就需要在mysql服务端启动之前给人家指定好,具体怎么指定呢,就需要看一下mysql启动的时候加载自己程序文件的过程(在并发编程的时候我们说过,任何程序运行都是通过加载自己的程序文件运行起来的),看看加载了哪些文件,并且哪些文件是关于mysql字符集的,我们只需要将这个关于字符集的文件里面的内容修改一下,就相当于间接的告诉mysql运行加载的时候需要使用的字符集格式。那么我们就可以做到永久修改mysql的字符集了,对不对。好,针对这个思路,我们研究了一下发现,这个包含字符集配置的配置文件叫做my.ini文件(win10,unix叫做my.cnf),这个文件是mysql启动的时候加载的一些用户自定制配置的文件,那么我们可以通过这个配置文件来改一改字符集,除了能填写字符集的配置项之外,还能填写一些你自己想要定制的其他的内容(需要研究mysql官方手册了~~)。
          如果你的安装目录里面没有这个文件并且没有在其他地方设置,那么mysql就会按照自己默认的配置参数来运行,我们可以通过写一个my.ini文件来指定,mysql运行起来时会读取这个my.ini文件中的一些配置,其中就可以配置指定字符集。

          我们知道这个文件叫做my.ini文件了,但是这个文件写在哪里呢?这里我们再说一个问题:有的人的博客上说mysql在启动的时候使用的配置文件在这个目录下(以win10举例):
            技术图片

          

          但是我查看了一下mysql启动的时候对my.ini文件的加载顺序:

            技术图片

 

          发现并没有加载上面这个文件夹中的my.ini文件,并且我测试了一下,将上面文件夹中my.ini文件中的mysqld下面的默认端口号3306改为了3307,然后我启动了mysql服务,然后我查了一下端口号,发现3307这个端口并没有被使用:
            技术图片


          所以验证出上面的这个文件夹中的文件并没有被加载生效。所以我确定,上面这个文件夹中的配置文件只是一个参考用的,我称它为伪配置文件。并不是有些博客里面的mysql中加载的那个my.ini文件。
                    

          并且我们通过上面的查看my.ini文件的加载顺序中看到,我们自己mysql的安装目录中的my.ini文件就是其中一个加载顺序的结果,所以,看样子我们自己在自己的mysql的安装目录下写一个my.ini文件就应该能行了,来就按照这个思路搞一搞(和大家确定说一下,这样肯定是可以的~~~)

          首先在安装目录下创建一个my.ini文件(copy一份my-default.ini文件,改名为my.ini文件),使用Notepad++打开,里面写上下面的内容,来看看是不是会生效

            技术图片


          之前我们连接mysql服务端的时候的指令是 mysql -uroot -p回车,其实我们直接输入mysql然后回车就能连接上mysql服务端,但是用户并不是root,而是mysql给我们创建一个用户,没啥用,可以忽略,工作中这个用户肯定是要被删除了,我们先来看一下这个用户,通过select user()来查看,并不是我们的root用户,root用户连接的时候是需要填密码的。

            技术图片

 

            技术图片

          之前我们用root用户连接输入库的命令是这样的:      

            C:\Users\chao>mysql -uroot -p
            Enter password: ***

           我们在我们创建的my.ini文件中写上下面几行,然后保存:       

            [mysql]   #配置客户端连接的时候,指定一下用户名和密码,那么我们在进行mysql客户端连接的时候,直接输入mysql然后回车就可以了,并且用户是我们下面指定的root用户
            user=root
            password=666

          重启mysql服务(一般修改配置文件,让其生效,需要重启服务,但是我测试了一下,这个用户名和密码的指定,貌似不需要重启服务就可以的):

            技术图片

          然后再起一个cmd客户端,直接输入mysql然后回车,再查看一下用户:

            技术图片

          改为root用户了~~~~配置文件生效~~~~

            
          通过上面的实验,我们知道,我们可以通过my.ini文件中的配置项,来更改mysql系统的一些服务,实现一些自定制配置,其实能够完成的配置非常多,将来深入学习mysql的时候,这个配置文件很关键,不过对于现在只做开发的你,就不必去研究那么多了,如果想看一下都可以进行哪些配置,可以参考一下我的那个centos7.1下安装mysql的博客最后面的内容,有关于其中的很多配置及解释,还可以参考上面我们提到的那个伪配置文件里面的内容来搞,但是记住一点,你写的这些配置必须是mysql能够认识的,也就是要按照人家规定的变量名称来配置,比如上面我们配置的用户名和密码,就叫做user和password,不能是username什么的,这个记住啦。

          下面我们通过配置文件来搞一搞编码,终于到了这一步了(windows和linux都是这个配置)
          在配置之前我们看一下各个角色的编码,还记得查看指令吗:
            mysql> show variables like "%char%";
            +--------------------------+-------------------------------------------+
            | Variable_name | Value |
            +--------------------------+-------------------------------------------+
            | character_set_client | gbk |
            | character_set_connection | gbk |
            | character_set_database | latin1 |
            | character_set_filesystem | binary |
            | character_set_results | gbk |
            | character_set_server | latin1 |
            | character_set_system | utf8 |
            | character_sets_dir | F:\jj\mysql-5.6.42-winx64\share\charsets\ |
            +--------------------------+-------------------------------------------+
            8 rows in set (0.00 sec)
          好,我们来改一改my.ini配置文件,文件中的内容写法,写完之后保存,然后重启mysql系统服务:
            #强调:配置文件中的注释可以有中文,但是配置项中不能出现中文
            #在mysql的解压目录下,新建my.ini,然后配置
            #1. 在执行mysqld命令时,下列配置会生效,即mysql服务启动时生效
            [mysqld]

            character_set_server=utf8
            collation-server=utf8_general_ci  #就是一个校对规则,一般默认都是这个,如果不是就改成这个就可以了,所以直接写上就行了,这个规则后面我们会讲的~~~

            还可以配置好多内容,比如下面的端口号,基准路径,数据文件路径:

              port=3306 # mysql服务端默认监听(listen on)的TCP/IP端口

              basedir="C:/Program Files/MySQL/MySQL Server 5.5/" # 基准路径,其他路径都相对于这个路径

              datadir="C:/Program Files/MySQL/MySQL Server 5.5/Data" # mysql数据库文件所在目录

            #2. 针对客户端命令的全局配置,当mysql客户端命令执行时,下列配置生效
            [client]
            default-character-set=utf8

            #3. 只针对mysql这个客户端的配置,2中的是全局配置,而此处的则是只针对mysql这个命令的局部配置
            [mysql]
            user=root
            password=666
            default-character-set=utf8

            #如果没有[mysql],则用户在使用mysql系统自带的mysql客户端来执行mysql命令时的配置以[client]为准

          重启mysql服务,让配置文件生效:
            C:\WINDOWS\system32>net stop mysql
            MySQL 服务正在停止..
            MySQL 服务已成功停止。

            C:\WINDOWS\system32>net start mysql
            MySQL 服务正在启动 .
            MySQL 服务已经启动成功。

          然后连接进入mysql,再次查看编码:
            C:\Users\chao>mysql -uroot -p
            Enter password: ***
            mysql> show variables like "%char%";
            +--------------------------+-------------------------------------------+
            | Variable_name | Value |
            +--------------------------+-------------------------------------------+
            | character_set_client | utf8 |
            | character_set_connection | utf8 |
            | character_set_database | utf8 |
            | character_set_filesystem | binary |
            | character_set_results | utf8 |
            | character_set_server | utf8 |
            | character_set_system | utf8 |
            | character_sets_dir | F:\jj\mysql-5.6.42-winx64\share\charsets\ |
            +--------------------------+-------------------------------------------+
            8 rows in set (0.00 sec)

          编码都编程utf8了,verygood,编码统一了,我们再来插入一条数据看看:
            首先我们将之前的crm库删除,然后再重新创建一个crm库,并在crm库里面重新创建一个student表,为什么删除呢?因为前面我们说了,之前的数据是乱码的,没办法改,所以我们先删除吧,然后重新创建一个,之前创建的crm库是Latin1的字符集的,所以为了简单演示,我们就删除重新创建吧,这里注意,如果将来你们公司使用的数据库的编码确实有问题,并且和你们现在要使用的编码不一致,那么就需要使用第一种临时修改字符集的方式来插入和查询数据,没办法,要不然就要重塑数据库,将编码调节好。
            来操作一下看看效果:
            首先看一下之前的crm库的创建语句:
              mysql> show create database crm\G
              *************************** 1. row ***************************
              Database: crm
              Create Database: CREATE DATABASE `crm` /*!40100 DEFAULT CHARACTER SET latin1 */
              1 row in set (0.08 sec)
              还是latin1的字符集

              mysql> drop database crm; #删除之前的crm库
              Query OK, 1 row affected (0.41 sec)

              mysql> show databases; #查看一下,crm库没有了
              +--------------------+
              | Database |
              +--------------------+
              | information_schema |
              | mysql |
              | performance_schema |
              | test |
              +--------------------+
              4 rows in set (0.01 sec)

              mysql> create database crm; #重新创建
              Query OK, 1 row affected (0.00 sec)

              mysql> show databases;
              +--------------------+
              | Database |
              +--------------------+
              | information_schema |
              | crm |
              | mysql |
              | performance_schema |
              | test |
              +--------------------+
              5 rows in set (0.00 sec)

            查看创建时的语句:
              mysql> show create database crm\G
              *************************** 1. row ***************************
              Database: crm
              Create Database: CREATE DATABASE `crm` /*!40100 DEFAULT CHARACTER SET utf8 */
              1 row in set (0.00 sec)
            已经改为了utf8的字符集
            然后我们插入数据,查看数据,看一下效果:
              mysql> use crm;
              Database changed
              mysql> create table student(id int,name char(10),age int);
              Query OK, 0 rows affected (0.47 sec)

              mysql> insert into student value(1,‘呵呵‘,11),(2,‘老刁‘,12),(3,‘dsb‘,10),(4,‘你好‘,9);
              Query OK, 4 rows affected (0.10 sec)
              Records: 4 Duplicates: 0 Warnings: 0

              mysql> select * from student;
              +------+--------+------+
              | id | name | age |
              +------+--------+------+
              | 1 | 呵呵 | 11 |
              | 2 | 老刁 | 12 |
              | 3 | dsb | 10 |
              | 4 | 你好 | 9 |
              +------+--------+------+

            good,完全没有乱码了~~~这就是解决方案

        总结:不乱码的思想:系统的编码、客户端、服务端、库、表、列,这几项的编码都要统一才不会出现乱码的情况。

        附赠:
          windows系统查看系统默认编码的指令:
          cmd窗口情况下:windows下cmd默认的编码是GBK
          想在windows下查看sqlite的utf-8中文需要先 执行chcp 65001把当前页换为utf-8编码
            chcp 命令:
            chcp 65001 就是换成UTF-8代码页,在命令行标题栏上点击右键,选择"属性"->"字体",将字体修改为True Type字体"Lucida Console",然后点击确定将属性应用到当前窗口
            chcp 936 可以换回默认的GBK 
            chcp 437 是美国英语
          linux系统查看系统默认编码的指令:
          执行指令:cat sysconfig i18n
            结果中有一条是:LANG="zh_CN.utf8"

 

     技术图片

 

 

六 初识sql语句

 

  有了mysql这个数据库软件,就可以将程序员从对数据的管理中解脱出来,专注于对程序逻辑的编写。

  mysql服务端软件即mysqld帮我们管理好文件夹以及文件,前提是作为使用者的我们,需要下载mysql的客户端,或者其他模块来连接到mysqld,然后使用mysql软件规定的语法格式去提交自己命令,实现对文件夹或文件的管理。该命令的语法即sql(Structured Query Language 即结构化查询语言),sql语句又分为几类,具体看我的博客:MySQL的sql语言分类DML、DQL、DDL、DCL、,主要分为4中,DDL、DQL、DML、DCL。

  SQL语句主要是针对数据库里面三个角色进行操作,对象是:库、表、行,操作包括:增删改查。

    1、库(data文件夹中的文件夹,每创建一个库,这个库的名称就是文件夹的名称,文件夹里面保存着一些这个库相关的初始信息)

      增:create database db1 charset utf8; #创建一个库,可以指定字符集       

      查:show databases; #查看数据库中所有的库
        show create database db1; #查看单独某个库db1的信息       

      改:alter database db1 charset latin1; #修改库的字符集,注意语句的格式(其他语句也是这么个格式),alter(修改) database(修改数据库) db1(哪个数据库) charset(字符集) latin1(改成哪个字符集)       

      删除: drop database db1; #删除数据库

     2、表(操作文件,表是上面库文件夹里面的文件)

      先切换库:use db1; #要操作表文件,要先切换到对应的库下才能操作表

             查看当前所在的是哪个库:select database();

      增:create table t1(id int,name char(10) );  #创建表的时候,和excel一样,需要有字段啊,每个字段还需要只能一下这个字段数据的格式,这里指定的是两个字段列,id和name列,id和name是列名(字段名),id 后面的int的意思说id这一列中的数据只能是int类型的,name后面的char的意思是,name这一列中的数据只能是char类型的(char表示定长字符串类型),char里面的10是说这个字段的长度最长为10个字符,如果不指定这个长度,默认长度是1,注意是字符而不是字节,这些字段的内容我们后面会详解,这里知道一下就好啦。

        #在创建表的时候,我们去看一下mysql安装目录里面的data文件夹里面的db1文件夹里面的文件,然后我们执行创建表的指令,看看db1文件夹里面的变化,多了两个文件,分别是:db1.frm,db1.ibd文件,创建了一张表为什么会多了两个文件呢,这两个文件都是啥呢?看解释(里面涉及到存储引擎,关于存储引擎我们后面会讲的~~):  

技术图片 解释

 

      查:show tables;  #查看当前库中所有的表

        show create table t1; #查看单表的创建信息

        #还可以通过下面两句来查看表信息,以表格的形式展示结果:

        desc t1;

        describe t1;#上下这两句是一样的结果

      改:alter table t1 modify name char(3);  #修改字段属性的,将name字段的char长度改为3,改完之后我们在用上面的show create table t1;desc t1;describe t1;来查看一下修改结果。

        alter table t1 change name name1 char(2);

      删:drop table t1;

     

    3. 行(操作文件(表)中的内容/记录)(*****将来的重中之重)

      增:insert into t1 values(1,‘dsb1‘),(2,‘dsb2‘),(3,‘dsb3‘); #往t1表中插入三行数据,注意你插入的每行内容都要和你创建表的时候的字段个数和字段属性对应好,注意每行数据以逗号分隔。

        insert后面的into可以不用写。

      查:select * from t1; #查看t1表中所有字段的数据,sel

人气教程排行