Mysql 第一篇:初识数据库

第一篇:初识数据库

一、数据库管理软件的由来

基于我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问一个文件仅仅只能存在于某一台机器上。

如果我们暂且忽略直接基于文件来存取数据的效率问题,并且假设程序所有的组件都运行在一台机器上,那么用文件存取数据,并没有问题。

很不幸,这些假设都是你自己意淫出来的,上诉假设存在以下几个问题:

1.程序所有的组件就不可能运行在一台机器上

#因为这台机器一旦挂掉则意味着整个软件的崩溃,并且程序的执行效率依赖于承载它的硬件,而一台机器的性能总归是有限的,受限于目前的硬件水平,就一台机器的性能垂直进行扩展是有极限的

#于是我们只能通过水平扩展来增强我们系统的整体性能,这就需要我们将程序的各个组件分布于多台机器去执行

2.数据安全问题

#根据1的描述,我们将程序的各个组件分布到各台机器,但需知各组件仍然是一个整体,言外之意,所有组件的数据还是要共享的。但每台机器上的组件都只能操作本机的文件,这就导致了数据不然一致

#于是我们想到看将数据与应用程序分离,把文件存放于一台机器,然后将多台机器通过网络去访问这台机器上的文件(用socket实现),即共享这台机器上的文件,共享则意味着竞争,会发生数据不安全,需要加锁处理。

3、并发 

  

#根据2的描述,我们必须写一个socket服务端来管理这台机器(数据库服务器)上的文件,然后写一个socket客户端,完成如下功能:


#1.远程连接(支持并发)
#2.打开文件
#3.读写(加锁)
#4.关闭文件

 总结:

我们在编写任何程序之前,都需要事先写好基于网络操作一台主机上文件的程序(socket服务端与客户端),于是有人讲此程序写成一个专门的处理软件,这就是mysql等数据库管理软件的由来,但是mysql解决的不仅仅是数据共享的问题,还有查询效率,安全性等一系列问题,总之,把程序员从数据管理中解脱出来,专注于自己的程序逻辑的编写

二、数据库的概述

1 什么是数据(Data)

  描述事物的符号记录称为数据

egon,male,18,1999,山东,计算机系,2017
大家所知道的都是数据.比如:你同学的名字,年龄,性别等等

  单纯的一条记录并没有任何意义,如果我们按逗号作为分隔,依次定义各个字段的意思,相当于定义表的标题  

1 name,sex,age,birth,born_addr,major, #字段
2 egon,male,18,1999,山东,计算机系,2017, #记录 

这样我们就可以了解egon,性别为男,年龄18岁,出生于1999年,出生地为山东

2.什么是数据库

数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,而且数据是按一定的格式存放的

3.数据库的特点

⑴ 实现数据共享

数据共享包含所有用户可同时存取数据库中的数据,也包括用户可以用各种方式通过接口使用数据库,并提供数据共享。

⑵ 减少数据的冗余度

同文件系统相比,由于数据库实现了数据共享,从而避免了用户各自建立应用文件。减少了大量重复数据,减少了数据冗余,维护了数据的一致性。

⑶ 数据一致性和可维护性,以确保数据的安全性和可靠性

主要包括:①安全性控制:以防止数据丢失、错误更新和越权使用;

     ②完整性控制:保证数据的正确性、有效性和相容性;

     ③并发控制:使在同一时间周期内,允许对数据实现多路存取,又能防止用户之间的不正常交互作用。

⑷ 故障恢复

由数据库管理系统提供一套方法,可及时发现故障和修复故障,从而防止数据被破坏。数据库系统能尽快恢复数据库系统运行时出现的故障,可能是物理上或是逻辑上的错误。比如对系统的误操作造成的数据错误等。

三、数据库的下载和安装

https://jingyan.baidu.com/article/cd4c2979033a17756f6e6047.html

四、初识sql语句

数据管理系统可以接收一些命令,对数据文件进行添加、删除、修改、查询等操作,这些命令就是SQL

SQL:(Structured Query Language)是结构化查询语言缩写。是一门专门与数据库管理系统打交道的语言。

具体可以把SQL分为4个部分:

数据控制语言 ( DCL): 主要用于控制用户的访问权限。其中GRANT语句用于给用户增加权限,REVOKE语句用于收回用户的权限

数据定义语言(DDL):DROP、CREATE、ALTER等语句;
           数据库定义语言。主要用于定义数据库,表,视图,索引和触发器等。
            CREATE语句主要用于创建数据库,创建表,创建视图。
            ALTER语句主要用于修改表的定义,修改视图的定义。
            DROP语句主要用于删除数据库,删除表和删除视图等。 数据操作语言(DML):INSERT、UPDATE、DELETE语句;数据库操作语言。主要用于插入数据,更新数据,删除数据。INSERT语句用于插入数据,UPDATE语句用于更新数据,DELETE语句用于           删除数据. 数据查询语言(DQL):SELECT语句。主要用于查询数据。

  

#1. 操作文件夹
        增:create database db1 charset utf8;
        查:show databases;
        改:alter database db1 charset latin1;
        删除: drop database db1;


#2. 操作文件
    先切换到文件夹下:use db1
        增:create table t1(id int,name char);
        查:show tables
        改:alter table t1 modify name char(3);
              alter table t1 change name name1 char(2);
        删:drop table t1;
    

#3. 操作文件中的内容/记录
        增:insert into t1 values(1,'egon1'),(2,'egon2'),(3,'egon3');
        查:select * from t1;
        改:update t1 set name='sb' where id=2;
        删:delete from t1 where id=1;

        清空表:
            delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。
            truncate table t1;数据量大,删除速度比上一条快,且直接从零开始,

            auto_increment 表示:自增
            primary key 表示:约束(不能重复且不能为空);加速查找

  

 

 

原文地址:https://www.cnblogs.com/a438842265/p/8474731.html