Linux高级系统编程- mysql数据库安装及环境配置

简介

数据库DB

        数据库( DataBase DB )从本质上讲就是一个文件系统,它能够将数据有组织地集合在一起,按照一定的规则长期存储到计算机的磁盘中,并且能够供多个用户共享和 使用,同时,用户能够对数据库中的数据进行插入、删除、修改和查询等操作。

数据库管理系统DBMS

        数据库管理系统(DataBase Management System DBMS 从本质讲就是一个为管 理数据库中的数据而设计的一套管理系统。它依托数据库,对外提供统一管理数据库中 数据的功能和接口能够有效地对数据库的安全、认证、数据 备份、数据恢复、数据传输等进行统一的管理。同时,数据库管理系统能够根据所依托的数据库模型对数据库进行相应的分类。大多数的数据库都是通过数据库管理系统对数据库中的数据进行管理和 维护的。

DBDBMS的关系

Linux高级系统编程- mysql数据库安装及环境配置_第1张图片

数据库的分类

关系型数据库

        依据所有存储数据的模型之间的关系建立的数据库。所谓关系模型,指的是“ 一对一、 一对多、多对多” 等 关系型。常见的关系型数据库如下:
        Oracle:是 Oracle 公司的数据库产品
        Mysql: 最早属于瑞典的 MysqlAB 公司的,后被 Sun 公司收购, Sun 2009 年 4月 20 号被 Oracle 收购。
        SQLServer:微软旗下的数据库产品
        Access:微软旗下的数据库产品
        DB2:IBM 公司旗下的数据库产品

非关系型数据库

        泛指非关系型的数据库,区别于关系数据库。采用了没有特定关系模型来组织数据。常见的非关系型数据库如下:
        MongoDB:是一个面向文档的开源 NoSQL 数据库 .MongoDB 使用 JSON 之类的文档来存储任何数据. 它是用 c++ 写的。
        Cassandra:是 Facebook 为收件箱搜索开发的 .Cassandra 是一个用于处理大量结构化数据的分布式数据存储系统
        Redis:是最著名的键值存储。 Redis 是用 C 语言编写的。它是根据 BSD 授权的。
        HBase:谷歌为 BigTable 数据库设计的分布式非关系数据库

数据库的安装及配置

安装

安装命令:
        sudo apt-get update #更新软件源
        sudo apt-get install mysql-server #安装 mysql
        安装过程会提示设置mysql root 用户的密码
连输两遍密码
Linux高级系统编程- mysql数据库安装及环境配置_第2张图片

启动或关闭MySQL

启动命令
        service mysql start
关闭命令
        service mysql stop
重启命令
        service mysql restart
注意 : 默认安装完成后, MySQL 为启动状态

确认是否启动成功

命令 :
        sudo netstat -tap | grep mysql
注意 :
        mysql节点处于 LISTEN 状态表示启动成功

进入MySQL Shell

命令 :
        mysql -u root -p
        回车
        输入安装mysql 时的密码

mysql中文乱码

原因
        character_set_server 默认设置是 latin1
查看命令 :
        show variables like "char%";
查看结果如下
Linux高级系统编程- mysql数据库安装及环境配置_第3张图片
解决方案 : 修改 mysql 配置
步骤0:        
        退出mysql
        exit
步骤 1: 编辑配置文件 sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
步骤 2: 在文件 [mysqld] 下添加 character_set_server=utf8. 保存退出
步骤 3: 重启 mysql 服务
        service mysql stop
        service mysql start
        service mysql restart
步骤 4: 登录 MySQL, 并查看 MySQL 目前设置的编码。 show variables like "char%";
Linux高级系统编程- mysql数据库安装及环境配置_第4张图片

外部工具连接mysql失败

原因:
        Ubuntu下默认安装 MySQL 只支持本地机的 localhost 127.0.0.1 进行连接访问 , 不能通 过虚拟机的IP 地址进行远程访问 MySQL
修改
        1,修改 mysql
                1.1:在Ubuntu 系统的 dos 中打开 mysql 库。
                        mysql -u root -p
                        这时会提示你输入 root 的密码,输入 root 密码后登陆进入 mysql 控制台。
                在 mysql 控制台中执行如下 sql 语句
                1.2:切换之mysql 库中
                        use mysql;
                1.3:修改权限表,将 root 的登陆 host 改为 ‘%’, 即允许所有 ip
                        update user set host = '%' where user = 'root';
                1.4:立刻刷新权限
                        flush privileges;
                注意:如果你还是不能远程连接,则继续执行下一步操作
        2,修改 mysql 配置文件
                sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
                修改其中的 bind-address 后面的 ip 值为 0.0.0.0 ,如下:
                        bind-address = 0.0.0.0
                保存修改,重启 mysql ,即可。命令如下 :
                        service mysql restart
        至此,即可通过远程 ip 登陆 mysql

SQL语句

简介

        SQL( Structured Query Language )结构化查询语言,用于存取、查询、更新数据以 及管理关系型数据库系统
        SQL是在 1981 年由 IBM 公司推出,一经推出基于其简洁的语法在数据库中得到了广泛的 应用,成为主流数据库的通用规范
        SQL由 ANSI 组织确定规范 在不同的数据库产品中遵守SQL 的通用规范,但是也对 SQL 有一些不同的改进,形成了一 些数据库的专有指令
MySQL limit
SQLServer top
Oracle rownum

分类

根据 SQL 指令完成的数据库操作的不同,可以将 SQL 指令分为四类
数据存在表中 , 表是存储在数据库中 ,mysql 中可以有多个数据库
: 类似与 Execl
 - DDL(Data Definition Language )数据定义语言
- 用于完成对数据库对象(数据库、数据表、视图、索引等)的创建、删除、修改
- DML Data Manipulation Language )数据操作 / 操纵语言
- 用于完成对数据表中的数据的添加、删除、修改操作
- 添加:将数据存储到数据表
- 删除:将数据从数据表移除
- 修改:对数据表中的数据进行修改
- DQL Data Query Language )数据查询语言
- 用于将数据表中的数据查询出来
- DCL Data Control Language )数据控制语言
- 用于完成事务管理等控制性操作

基础语法

        在MySQL Command Line Client 或者 Navicat 等工具中都可以编写 SQL 指令
- SQL 指令不区分大小写
        但是在后期编写sql 指令时 ,sql 提供的关键字一般使用大写 , 自定义的名称用小写
- 每条 SQL 表达式结束之后都以 ; 结束
- SQL 关键字之间以空格进行分隔
- SQL 之间可以不限制换行(可以有空格的地方就可以有换行)
- MySQL 注释:
        - 单行注释: -- 注释内容
        注意: -- 后要加空格
        - 单行注释: # 注释内容
        - 多行注释: /* 注释内容 */

你可能感兴趣的:(Linux高级系统编程,MySQL数据库,C语言,数据库,mysql)