zoukankan      html  css  js  c++  java
  • 8.1

     

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

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

    过去人们将数据存放在文件柜里,现在数据量庞大,已经不再适用

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

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

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

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

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

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

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

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

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

    表:student,scholl,class_list(即文件)

    数据库:live(即文件夹)

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

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

    总结:

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

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

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

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

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司。

    MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

    mysql是什么

    mysql就是一个基于socket编写的C/S架构的软件
    
    客户端软件
      mysql自带:如mysql命令,mysqldump命令等
      python模块:如pymysql
    

    数据库管理软件分类

    分两大类:
      关系型:如sqllite,db2,oracle,access,sql server,MySQL,注意:sql语句通用
      非关系型:mongodb,redis,memcache
    可以简单的理解为:
        关系型数据库需要有表结构
        非关系型数据库是key-value存储的,没有表结构

    下载安装

    1. windows

    #1、下载:MySQL Community Server 5.7.16
    http://dev.mysql.com/downloads/mysql/
    
    #2、解压
    如果想要让MySQL安装在指定目录,那么就将解压后的文件夹移动到指定目录,如:C:mysql-5.7.16-winx64
    
    #3、添加环境变量
    【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【将MySQL的bin目录路径追加到变值值中,用 ; 分割】
    
    #4、初始化
    mysqld --initialize-insecure
    
    #5、启动MySQL服务
    mysqld # 启动MySQL服务
    
    #6、启动MySQL客户端并连接MySQL服务
    mysql -u root -p # 连接MySQL服务器
    mysql for windows
    注意:--install前,必须用mysql启动命令的绝对路径
    # 制作MySQL的Windows服务,在终端执行此命令:
    "c:mysql-5.7.16-winx64inmysqld" --install
    
    # 移除MySQL的Windows服务,在终端执行此命令:
    "c:mysql-5.7.16-winx64inmysqld" --remove
    
    
    注册成服务之后,以后再启动和关闭MySQL服务时,仅需执行如下命令:
    # 启动MySQL服务
    net start mysql
    
    # 关闭MySQL服务
    net stop mysql
    auto start by restart

    2. Linux

    1. centos
    
        1. centos6.x
    
          编译安装    https://www.linuxidc.com/Linux/2016-09/135523.htm
          在线安装   http://blog.csdn.net/xinxin19881112/article/details/46873811
                   2. centos7.x
    
          https://www.cnblogs.com/bigbrotherer/p/7241845.html
      2. ubuntu
    
        apt-get install -y mysql-server  
    
                  坐等图型上题数输入mysql的root密码即可。
    
     
    View Code

    MySQL启动与查看

    1. windows

    windows平台到服务中查看即可
    View Code

    2. Linux

    # centos7.x
    [root@cmz ~]# systemctl start mariadb #启动
    [root@cmz ~]# systemctl enable mariadb #设置开机自启动
    Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
    [root@egon ~]# ps aux |grep mysqld |grep -v grep #查看进程,mysqld_safe为启动mysql的脚本文件,内部调用mysqld命令
    mysql     3329  0.0  0.0 113252  1592 ?        Ss   16:19   0:00 /bin/sh /usr/bin/mysqld_safe --basedir=/usr
    mysql     3488  0.0  2.3 839276 90380 ?        Sl   16:19   0:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mariadb/mariadb.log --pid-file=/var/run/mariadb/mariadb.pid --socket=/var/lib/mysql/mysql.sock
    [root@egon ~]# netstat -an |grep 3306 #查看端口
    tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN  
    [root@cmz ~]# ll -d /var/lib/mysql #权限不对,启动不成功,注意user和group
    drwxr-xr-x 5 mysql mysql 4096 Jul 20 16:28 /var/lib/mysql
    
    # centos6.8
    /etc/init.d/mysql start
    
    # ubuntu
    root@leco:/home/leco/桌面# /etc/init.d/mysql start  
    [ ok ] Restarting mysql (via systemctl): mysql.service.
    View Code

    登录设置密码

    初始状态下,管理员root,密码为空,默认只允许从本机登录localhost
    设置密码
    [root@cmz ~]# mysqladmin -uroot password "root"        设置初始密码 由于原密码为空,因此-p可以不用
    [root@cmz ~]# mysqladmin -uroot -p"root" password "root"        修改mysql密码,因为已经有密码了,所以必须输入原密码才能设置新密码
    
    命令格式:
    [root@cmz ~]# mysql -h192.168.5.109 -uroot -proot
    [root@cmz ~]# mysql -uroot -p
    [root@cmz ~]# mysql                    以root用户登录本机,密码为空
    
    # ubuntu 在安装的时候就输入了root的密码,所以不需要在安装后在输入密码
    View Code

     破解密码

    1. Windows下破解方式

    windows平台下,5.7版本mysql,破解密码的两种方式:
    
    方式一
    
    #1 关闭mysql
    #2 在cmd中执行:mysqld --skip-grant-tables
    #3 在cmd中执行:mysql
    #4 执行如下sql:
    update mysql.user set authentication_string=password('') where user = 'root';
    flush privileges;
    
    #5 tskill mysqld #或taskkill -f /PID 7832
    #6 重新启动mysql
    方式二
    
    #1. 关闭mysql,可以用tskill mysqld将其杀死
    #2. 在解压目录下,新建mysql配置文件my.ini
    #3. my.ini内容,指定
    [mysqld]
    skip-grant-tables
    
    #4.启动mysqld
    #5.在cmd里直接输入mysql登录,然后操作
    update mysql.user set authentication_string=password('') where user='root and host='localhost';
    
    flush privileges;
    
    #6.注释my.ini中的skip-grant-tables,然后启动myqsld,然后就可以以新密码登录了
    View Code

    2. Linux下破解方式

    linux平台下,破解密码的两种方式
    
    方法一:删除授权库mysql,重新初始化
    
    [root@cmz ~]# rm -rf /var/lib/mysql/mysql #所有授权信息全部丢失!!!
    [root@cmz ~]# systemctl restart mariadb
    [root@cmz ~]# mysql
    方法二:启动时,跳过授权库
    
    [root@cmz ~]# vim /etc/my.cnf    #mysql主配置文件
    [mysqld]
    skip-grant-table
    [root@cmz ~]# systemctl restart mariadb
    [root@cmz ~]# mysql
    MariaDB [(none)]> update mysql.user set password=password("123") where user="root" and host="localhost";
    MariaDB [(none)]> flush privileges;
    MariaDB [(none)]> q
    [root@cmz ~]# #打开/etc/my.cnf去掉skip-grant-table,然后重启
    [root@cmz ~]# systemctl restart mariadb
    [root@cmz ~]# mysql -u root -p123 #以新密码登录
    View Code

    配置文件

    #在mysql的解压目录下,新建my.ini,然后配置
    #1. 在执行mysqld命令时,下列配置会生效,即mysql服务启动时生效
    [mysqld]
    ;skip-grant-tables
    port=3306
    character_set_server=utf8
    default-storage-engine=innodb
    innodb_file_per_table=1
    
    
    #解压的目录
    basedir=E:mysql-5.7.19-winx64
    #data目录
    datadir=E:my_data #在mysqld --initialize时,就会将初始数据存入此处指定的目录,在初始化之后,启动mysql时,就会去这个目录里找数据
    
    
    
    #2. 针对客户端命令的全局配置,当mysql客户端命令执行时,下列配置生效
    [client]
    port=3306
    default-character-set=utf8
    user=root
    password=123
    
    #3. 只针对mysql这个客户端的配置,2中的是全局配置,而此处的则是只针对mysql这个命令的局部配置
    [mysql]
    ;port=3306
    ;default-character-set=utf8
    user=egon
    password=4573
    
    
    #!!!如果没有[mysql],则用户在执行mysql命令时的配置以[client]为准
    View Code

    统一字符编码

    #1. 修改配置文件
    [mysqld]
    default-character-set=utf8 
    [client]
    default-character-set=utf8 
    [mysql]
    default-character-set=utf8
    
    #mysql5.5以上:修改方式有所改动
    [mysqld]
    character-set-server=utf8
    collation-server=utf8_general_ci
    [client]
    default-character-set=utf8
    [mysql]
    default-character-set=utf8
    
    #2. 重启服务
    #3. 查看修改结果:
    s
    show variables like '%char%'
    View Code
    root@leco:/etc/mysql# cp mysql.cnf mysql.cnf.ori
    root@leco:/etc/mysql# vi mysql.cnf
    root@leco:/etc/mysql# cat mysql.cnf 
    [mysqld]
    character-set-server=utf8
    collation-server=utf8_general_ci
    [client]
    default-character-set=utf8
    [mysql]
    default-character-set=utf8
    #在文件开头添加以上配置。
    
    root@leco:/etc/mysql# /etc/init.d/mysql restart
    [ ok ] Restarting mysql (via systemctl): mysql.service.
    root@leco:/etc/mysql# mysql -uroot -p
    Enter password: 
    Welcome to the MySQL monitor.  Commands end with ; or g.
    Your MySQL connection id is 3
    Serv
    Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
    
    Oracle is a registered trademark of Oracle Corporation and/or its
    affiliates. Other names may be trademarks of their respective
    owners.
    
    Type 'help;' or 'h' for help. Type 'c' to clear the current input statement.
    
    mysql> s;
    --------------
    mysql  Ver 14.14 Distrib 5.7.21, for Linux (x86_64) using  EditLine wrapper
    
    Connection id:        3
    Current database:    
    Current user:        root@localhost
    SSL:            Not in use
    Current pager:        stdout
    Using outfile:        ''
    Using delimiter:    ;
    Server version:        5.7.21-0ubuntu0.16.04.1 (Ubuntu)
    Protocol version:    10
    Connection:        Localhost via UNIX socket
    Server characterset:    utf8
    Db     characterset:    utf8
    Client characterset:    utf8
    Conn.  characterset:    utf8
    UNIX socket:        /var/run/mysqld/mysqld.sock
    Uptime:            10 sec
    
    Threads: 1  Questions: 5  Slow queries: 0  Opens: 107  Flush tables: 1  Open tables: 26  Queries per second avg: 0.500
    --------------
    
    ERROR: 
    No query specified
    
    mysql> 
    统一编码

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

    mysql服务端软件即mysqld帮我们管理好文件夹以及文件,前提是作为使用者的我们,需要下载mysql的客户端,或者其他模块来连接到mysqld,然后使用mysql软件规定的语法格式去提交自己命令,实现对文件夹或文件的管理。该语法即sql(Structured Query Language 即结构化查询语言)

    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
            改:alter table t1 modify name char(3);
                  alter table t1 change name name1 char(2);
            删:drop table t1;
    
    
    #3. 操作文件中的内容/记录
            增:insert into t1 values(1,'cmz1'),(2,'cmz2'),(3,'cmz3');
            查:select * from t1;
            改:update t1 set name='cmz1' where id=2;
            删:delete from t1 where id=1;
    View Code
    mysql> insert t1(id,name) values(1,'cmz1');  # 插入方式1
    Query OK, 1 row affected (0.01 sec)
    
    mysql> insert into t1 values(2,'cmz2');
    Query OK, 1 row affected (0.01 sec)
    
    mysql> insert t1(id,name) values(3,'cmz3');
    Query OK, 1 row affected (0.00 sec)
    
    mysql> desc t1;
    +-------+---------+------+-----+---------+-------+
    | Field | Type    | Null | Key | Default | Extra |
    +-------+---------+------+-----+---------+-------+
    | id    | int(11) | YES  |     | NULL    |       |
    | name  | char(7) | YES  |     | NULL    |       |
    +-------+---------+------+-----+---------+-------+
    2 rows in set (0.00 sec)
    
    mysql> select * from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz1 |
    |    2 | cmz2 |
    |    3 | cmz3 |
    +------+------+
    3 rows in set (0.00 sec)
    
    mysql> 
    mysql> 
    mysql> select id,name  from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz1 |
    |    2 | cmz2 |
    |    3 | cmz3 |
    +------+------+
    3 rows in set (0.00 sec)
    
    mysql> desc t1;
    +-------+---------+------+-----+---------+-------+
    | Field | Type    | Null | Key | Default | Extra |
    +-------+---------+------+-----+---------+-------+
    | id    | int(11) | YES  |     | NULL    |       |
    | name  | char(7) | YES  |     | NULL    |       |
    +-------+---------+------+-----+---------+-------+
    2 rows in set (0.00 sec)
    
    mysql> select * from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz1 |
    |    2 | cmz2 |
    |    3 | cmz3 |
    +------+------+
    3 rows in set (0.00 sec)

    修改操作

    mysql> select id,name from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz1 |
    |    2 | cmz2 |
    |    3 | cmz3 |
    +------+------+
    3 rows in set (0.00 sec)
    
    mysql> update t1 set name='cmz' where id = 1 ; 
    Query OK, 1 row affected (0.00 sec)
    Rows matched: 1  Changed: 1  Warnings: 0
    
    mysql> select id,name from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz  |
    |    2 | cmz2 |
    |    3 | cmz3 |
    +------+------+
    3 rows in set (0.00 sec)

    删除操作

    mysql> select id,name from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz  |
    |    2 | cmz2 |
    |    3 | cmz3 |
    +------+------+
    3 rows in set (0.00 sec)
    
    mysql> delete from t1 where name='cmz3'; # 删除name=cmz3的数据
    Query OK, 1 row affected (0.01 sec)
    
    mysql> select id,name from t1; 
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz  |
    |    2 | cmz2 |
    +------+------+
    2 rows in set (0.00 sec)
    mysql> delete from t1 where id=2;  # 删除id=2的数据
    Query OK, 1 row affected (0.00 sec)
    
    mysql> select id,name from t1;
    +------+------+
    | id   | name |
    +------+------+
    |    1 | cmz  |
    +------+------+
    1 row in set (0.00 sec)
     
  • 相关阅读:
    poj 2488 DFS
    畅通工程 并查集模版
    KMP 模板
    poj 1426 DFS
    poj 2528 线段数
    poj 3468 线段数 修改区间(点)
    CVPR2012文章阅读(2)A Unified Approach to Salient Object Detection via Low Rank Matrix Recovery
    如何制定目标
    Saliency Map 最新综述
    计算机视觉模式识别重要会议杂志
  • 原文地址:https://www.cnblogs.com/caimengzhi/p/8548794.html
Copyright © 2011-2022 走看看