zoukankan      html  css  js  c++  java
  • 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 表示:约束(不能重复且不能为空);加速查找
    

      

     

     

  • 相关阅读:
    在Visual Studio中使用NUnit
    C#调用Exe
    网页用chrome打开为乱码
    ctags最基本用法
    Facebook Connect
    SVM初体验
    python中可恶的回车符
    初识PowerDesigner
    Mysql中文乱码问题解决
    stat函数
  • 原文地址:https://www.cnblogs.com/a438842265/p/8474731.html
Copyright © 2011-2022 走看看