• 初识数据库与SQL语句


    认识数据库

    1 什么是数据(Data)

    在计算机中描述一个事物,就需要抽取这一事物的典型特征,组成一条记录,就相当于文件里的一行内容,按逗号作为分隔,依次定义各个字段的意思,相当于定义表的标题

    id,name,sex,age,birth,born_addr,company # 字段/列名
    1,luffy,male,21,1997,风车村,pirate # 数据
    

      

    2 什么是数据库(DataBase,简称DB)

    数据库即存放数据的仓库,只不过这个仓库是在计算机存储设备上,而且数据是按一定的格式存放的。过去人们将数据存放在文件柜里,现在数据量庞大,已经不再适用。

    数据库是长期存放在计算机内、有组织、可共享的数据集合。

    数据库中的数据按一定的数据模型组织、描述和储存,具有较小的冗余度、较高的数据独立性和易扩展性,并可为各种 用户共享

    3 什么是数据库管理系统(DataBase Management System 简称DBMS)

    在了解了Data与DB的概念后,如何科学地组织和存储数据,如何高效获取和维护数据成了关键

    这就用到了一个系统软件---数据库管理系统

    如MySQL、Oracle、SQLite、Access、MS SQL Server

    mysql主要用于大型门户,例如搜狗、新浪等,它主要的优势就是开放源代码,因为开放源代码这个数据库是免费的,他现在是甲骨文公司的产品。
    oracle主要用于银行、铁路、飞机场等。该数据库功能强大,软件费用高。也是甲骨文公司的产品。
    sql server是微软公司的产品,主要应用于大中型企业,如联想、方正等。

    其中数据库分为关系型数据库和非关系型数据库:

    关系型数据库和非关系型数据库
        关系型
            一条数据包含了一个事物的多条信息,这些信息之间是有关联性的
        非关系型:存取频繁的,并且要求效率高的,不突出数据关联的
            k-v 结构
            id content
    
    
    
    关系型数据库
        MySQL   开源
        Oracle  企业级
        sqlite  轻量级
        sql server  微软
    
    
    非关系型数据库
        memcache    断电消失
        redis   断电不消失
        mongodb
        nosql
    

    4 数据库服务器、数据管理系统、数据库、表与记录的关系(重点)

    记录:1 路飞 13234567890 22(多个字段的信息组成一条记录,即文件中的一行内容)

    表:userinfo,studentinfo,courseinfo(即文件)

    数据库:db(即文件夹)

    数据库管理系统:如mysql(是一个软件)

    数据库服务器:一台计算机(对内存要求比较高)

    总结:

        数据库服务器-:运行数据库管理软件

        数据库管理软件:管理-数据库

        数据库:即文件夹,用来组织文件/表

        表:即文件,用来存放多行内容/多条记录

      

    初识sql语句

    #进入mysql客户端
    $mysql
    mysql> select user();  #查看当前用户
    mysql> exit     # 也可以用q quit退出
    
    # 默认用户登陆之后并没有实际操作的权限
    # 需要使用管理员root用户登陆
    $ mysql -uroot -p   # mysql5.6默认是没有密码的
    #遇到password直接按回车键
    mysql> set password = password('root'); # 给当前数据库设置密码
    
    # 创建账号
    mysql> create user 'eva'@'192.168.10.%'   IDENTIFIED BY PASSWORD '123';# 指示网段
    mysql> create user 'eva'@'192.168.10.5'   # 指示某机器可以连接
    mysql> create user 'eva'@'%'                    #指示所有机器都可以连接  
    
    # 远程登陆
    $ mysql -uroot -p123 -h 192.168.10.3
    
    # 给账号授权
    mysql> grant all on *.* to 'eva'@'%';
    mysql> flush privileges;    # 刷新使授权立即生效
    
    # 创建账号并授权
    mysql> grant all on *.* to 'eva'@'%' identified by '123' 
    
    mysql的账号操作
    mysql的账号操作

    SQL : 结构化查询语言(Structured Query Language)简称SQL(发音:/ˈes kjuː ˈel/ "S-Q-L"),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。

     SQL语言主要用于存取数据、查询数据、更新数据和管理关系数据库系统,SQL语言由IBM开发。SQL语言分为3种类型:
    
      1、DDL语句 数据库定义语言: 数据库、表、视图、索引、存储过程,例如CREATE DROP ALTER
    
      2、DML语句 数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE、查询数据SELECT
    
      3、DCL语句 数据库控制语言: 例如控制用户的访问权限GRANT、REVOKE
    

      

    数据库操作

     即操作文件夹

    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; 查看当前这个库中的表
        show 库.tables; 查看指定库中的表 改:alter table t1 modify name char(3); alter table t1 change name name1 char(2); 删:drop table t1;
      查看表结构:desc 表名;
            describle 表名;
            show create table 表名 G;
    3. 操作文件中的内容(记录) 增:insert into t1 values(1,'luffy1'),(2,'luffy2'),(3,'luffy3'); 查:select * from t1;
        select 字段名 from 表名;
        select id,name from 表名;
        select * from 表名;
    改: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 表示:约束(不能重复且不能为空);加速查找

      

  • 相关阅读:
    vue-router重写push方法,解决相同路径跳转报错
    Vue中的权限管理怎么做
    linux启动过程中建立临时页表
    用redis当作LRU缓存
    用IPV6隧道连接IPV4孤岛
    redis协议规范
    nginx的脚本引擎(二)rewrite
    nginx的脚本引擎(一)
    nginx的变量系统
    Singleton
  • 原文地址:https://www.cnblogs.com/eaoo/p/9726547.html
Copyright © 2020-2023  润新知