• MySQL数据库——基础


    一、数据库

      数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据。

      关系型数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。

      我们也可以将数据存储在文件中,但是在文件中读写数据速度相对较慢。所以,现在我们使用关系型数据库管理系统(RDBMS)来存储和管理的大数据量。

      RDBMS即关系数据库管理系统(Relational Database Management System)的特点:
        1.数据以表格的形式出现(就像一个Excel表格)
        2.每行为各种记录名称
        3.每列为记录名称所对应的数据域
        4.许多的行和列组成一张表单table
        5.若干的表单组成database

    二、RDBMS 术语 

    在我们开始学习MySQL 数据库前,让我们先了解下RDBMS的一些术语:  

    • 数据库: 数据库是一些关联表的集合。.
    • 数据表: 表是数据的矩阵。在一个数据库中的表看起来像一个简单的电子表格。
    • 列: 一列(数据元素) 包含了相同的数据, 例如邮政编码的数据。
    • 行:一行(=元组,或记录)是一组相关的数据,例如一条用户订阅的数据。
    • 冗余:存储两倍数据,冗余可以使系统速度更快。(表的规范化程度越高,表与表之间的关系就越多;查询时可能经常需要在多个表之间进行连接查询;而进行连接操作会降低查询速度。例如,学生的信息存储在student表中,院系信息存储在department表中。通过student表中的dept_id字段与department表建立关联关系。如果要查询一个学生所在系的名称,必须从student表中查找学生所在院系的编号(dept_id),然后根据这个编号去department查找系的名称。如果经常需要进行这个操作时,连接查询会浪费很多的时间。因此可以在student表中增加一个冗余字段dept_name,该字段用来存储学生所在院系的名称。这样就不用每次都进行连接操作了。)
    • 主键:主键是唯一的。一个数据表中只能包含一个主键。你可以使用主键来查询数据。
    • 外键:外键用于关联两个表。
    • 复合键:复合键(组合键)将多个列作为一个索引键,一般用于复合索引。
    • 索引:使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构。类似于书籍的目录。
    • 参照完整性: 参照的完整性要求关系中不允许引用不存在的实体。与实体完整性是关系模型必须满足的完整性约束条件,目的是保证数据的一致性。 

    三、MySQL数据库

      MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。  

    • Mysql是开源的,所以你不需要支付额外的费用。
    • Mysql支持大型的数据库。可以处理拥有上千万条记录的大型数据库。
    • MySQL使用标准的SQL数据语言形式。
    • Mysql可以允许于多个系统上,并且支持多种语言。这些编程语言包括C、C++、Python、Java、Perl、PHP、Eiffel、Ruby和Tcl等。
    • Mysql对PHP有很好的支持,PHP是目前最流行的Web开发语言。
    • MySQL支持大型数据库,支持5000万条记录的数据仓库,32位系统表文件最大可支持4GB,64位系统支持最大的表文件为8TB。
    • Mysql是可以定制的,采用了GPL协议,你可以修改源码来开发自己的Mysql系统。

    四、Windows 安装 MySQL

      https://jingyan.baidu.com/album/cd4c2979033a17756f6e6047.html?picindex=1

    五、Mysql安装后需要做的——密码  

      Mysql安装成功后,默认的root用户密码为空,你可以使用以下命令来创建root用户的密码:

    1
    [root@host]# mysqladmin -u root password "new_password";

       现在你可以通过以下命令来连接到Mysql服务器:

    1
    2
    [root@host]# mysql -u root -p
    Enter password:*******

      注意:在输入密码时,密码是不会显示了,你正确输入即可。

      修改密码:http://blog.csdn.net/th_num/article/details/71402801

    六、MySQL用户操作

    1、创建用户:在root用户下创建,命令:

    CREATE USER 'username'@'host' IDENTIFIED BY 'password';

    说明:

    • username:你将创建的用户名
    • host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符%
    • password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器

    例子:

    CREATE USER 'dog'@'localhost' IDENTIFIED BY '123456';
    CREATE USER 'pig'@'192.168.1.101_' IDENDIFIED BY '123456';
    CREATE USER 'pig'@'%' IDENTIFIED BY '123456';
    CREATE USER 'pig'@'%' IDENTIFIED BY '';
    CREATE USER 'pig'@'%';

    2、授权

    命令:

    GRANT privileges ON databasename.tablename TO 'username'@'host'

    说明:

    • privileges:用户的操作权限,如SELECTINSERTUPDATE等,如果要授予所的权限则使用ALL
    • databasename:数据库名
    • tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*

    例子:

    GRANT SELECT, INSERT ON test.user TO 'pig'@'%';
    GRANT ALL ON *.* TO 'pig'@'%';
    GRANT ALL ON maindataplus.* TO 'pig'@'%';

    注意:

    用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:

    GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;

    显示用户权限: 

    show grants for user 

    3、设置与更改用户密码

    命令:

    SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');

    如果是当前登陆用户用:

    SET PASSWORD = PASSWORD("newpassword");

    例子:

    SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");

    4、撤销用户权限

    命令:

    REVOKE privilege ON databasename.tablename FROM 'username'@'host';

    说明:

    privilege, databasename, tablename:同授权部分

    例子:

    REVOKE SELECT ON *.* FROM 'pig'@'%';

    注意:

    假如你在给用户'pig'@'%'授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO 'pig'@'%',则在使用REVOKE SELECT ON *.* FROM 'pig'@'%';命令并不能撤销该用户对test数据库中user表的SELECT 操作。相反,如果授权使用的是GRANT SELECT ON *.* TO 'pig'@'%';REVOKE SELECT ON test.user FROM 'pig'@'%';命令也不能撤销该用户对test数据库中user表的Select权限。

    具体信息可以用命令SHOW GRANTS FOR 'pig'@'%'; 查看。

    5、删除用户

    命令:

    DROP USER 'username'@'host';

    七、管理MySQL的命令

    以下列出了使用Mysql数据库过程中常用的命令:

    • SHOW DATABASES: 列出 MySQL 数据库管理系统的数据库列表。

    • USE 数据库名 :选择要操作的Mysql数据库,使用该命令后所有Mysql命令都只针对该数据库。

    • SHOW TABLES: #显示指定数据库的所有表,使用该命令前需要使用 use命令来选择要操作的数据库。

    • SHOW COLUMNS FROM 数据表: #显示数据表的属性,属性类型,主键信息 ,是否为 NULL,默认值等其他信息。

    • desc tablename :显示表结构。
    • create database testdb charset "utf8"; #创建一个叫testdb的数据库,且让其支持中文 。

    • drop database testdb; #删除数据库。

    • SHOW INDEX FROM 数据表:显示数据表的详细索引信息,包括PRIMARY KEY(主键)。 

    八、datebase操作

    1、创建数据库 

    create database testdb charset "utf8"; #创建一个叫testdb的数据库,且让其支持中文 。

    2、查看数据库支持字符集

    show create databaase name 

    3、删除数据库

    drop database name
  • 相关阅读:
    修改SQL数据库中表字段类型时,报“一个或多个对象访问此列”错误的解决方法
    C# 正则表达式类 Match类和Group类
    JS流程控制语句 退出循环break 在while、for、do...while、while循环中使用break语句退出当前循环,直接执行后面的代码。
    JS流程控制语句 重复重复(for循环)语句结构: for(初始化变量;循环条件;循环迭代) { 循环语句 }
    JS流程控制语句 反反复复(while循环) 和for循环有相同功能的还有while循环, while循环重复执行一段代码,直到某个条件不再满足。
    JS流程控制语句 多重判断满足你各种需求 要在多组语句中选择一组来执行,使用if..else嵌套语句。
    JS流程控制语句 多种选择(Switch语句) 当有很多种选项的时候,switch比if else使用更方便。
    JS流程控制语句 做判断(if语句)if语句是基于条件成立才执行相应代码时使用的语句。语法:if(条件) { 条件成立时执行代码}
    JS流程控制语句 二选一 (if...else语句) 语法: if(条件) { 条件成立时执行的代码} else {条件不成立时执行的代码}
    JS数组 编程练习 使用Javascript语言,把以下数组 在页面显示如下图所示的图案
  • 原文地址:https://www.cnblogs.com/yz9110/p/8571349.html
Copyright © 2020-2023  润新知