Mysql必知必会学习笔记(一)

    今天开始学习mysql,有一位老师推荐一本经典的入门书籍《MySQL必知必会》,让我把这本书通读几遍,就能对数据库有个很好的入门了。网上有文字版,感兴趣的小伙伴能够找来阅读。python

书封面长这样:mysql

 

数据库概念的简要介绍sql

数据库(database)保存有组织的数据的容器(一般是一个文件或一组文件)数据库

容易混淆的地方数据库软件与数据库:编程

数据库软件应称为DBMS(数据库管理系统)。数据库是经过DBMS建立和操纵的容器。数据库能够是保存在硬设备上的文件,但也能够不是。安全

     咱们常常经过各类数据库链接工具好比Navicat for mysql(这个好评普遍)、mysql workbench(这个是官方提供的,用不习惯)等,在编程语言里,好比python(我只会这一门),能够安装pymysql模块,调用相关方法来访问数据库。也能够经过交互界面来访问好比下面这样:scrapy

不过排版就不怎么友好了,之前在一个项目上,客户为了保证生产环境数据安全,不让安装链接工具,咱们操做数据库只能经过交互界面,头都大了。数据库设计

PS C:\Users\Administrator> mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.7.20-log MySQL Community Server (GPL)

Copyright (c) 2000, 2017, 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> show databases;
+---------------------+
| Database            |
+---------------------+
| information_schema  |
| learn_scrapy        |
| love_learning       |
| mysql               |
| mysql_bi_zhi_bi_hui |
| performance_schema  |
| sakila              |
| sys                 |
| world               |
| zabbix              |
+---------------------+
10 rows in set (0.00 sec)

mysql>

 

表(table) 某种特定类型数据的结构化清单。
存储在表中的数据是一种类型的数据或一个清单。决不该该将顾客的清单与订单的清单存储在同一个数据库表中。这样作将使之后的检索和访问很困难。应该建立两个表,每一个清单一个表。

 

数据库中的每一个表都有一个名字,用来标识本身。此名字是惟一的,这表示数据库中没有其余表具备相同的名字。编程语言

模式(schema) 关于数据库和表的布局及特性的信息。
描述表的这组信息就是所谓的模式,模式能够用来描述数据库中特定的表以及整个数据库(和其中表的关系)
列(column) 表中的一个字段。全部表都是由一个或多个列组成的。
理解列的最好办法是将数据库表想象为一个网格。网格中每一列存储着一条特定的信息。例如,在顾客表中,一个列存储着顾客编号,另外一个列存储着顾客名,而地址、城市、州以及邮政编码全都存储在各自的列中。
数据类型(datatype) 所允许的数据的类型。每一个表列都有相应的数据类型,它限制(或允许)该列中存储的数据。数据类型限制可存储在列中的数据种类(例如,防止在数值字段中录入字符值)。数据类型还帮助正确地排序数据,并在优化磁盘使用方面起重要的做用。
行(row) 表中的一个记录。主键(primary key)一一列(或一组列),其值可以惟一区分表中每一个行。

惟一标识表中每行的这个列(或这组列)称为主键。主键用来表示一个特定的行。没有主键,更新或删除表中特定行很困难,由于没有安全的方法保证只涉及相关的行。
表中的任何列均可以做为主键,只要它知足如下条件:
 任意两行都不具备相同的主键值;
 每一个行都必须具备一个主键值(主键列不容许NULL值)。

应该老是定义主键 虽然并不老是都须要主键,但大多数数据库设计人员都应保证他们建立的每一个表具备一个主键,以便于之后的数据操纵和管理。

主键一般定义在表的一列上,但这并非必需的,也能够一块儿使用多个列做为主键。在使用多列做为主键时,上述条件必须应用到构成主键的全部列,全部列值的组合必须是惟一的(但单个列的值能够不惟一)。

主键的最好习惯 除MySQL强制实施的规则外,应该坚持的几个广泛承认的最好习惯为:
 不更新主键列中的值;
 不重用主键列的值;
 不在主键列中使用可能会更改的值。(例如,若是使用一个名字做为主键以标识某个供应商,当该供应商合并和更改其名字时,必须更改这个主键。)

SQL(发音为字母S-Q-L或sequel)是结构化查询语言(Structured QueryLanguage)的缩写。SQL是一种专门用来与数据库通讯的语言
SQL有以下的优势。
 SQL不是某个特定数据库供应商专有的语言。几乎全部重要的DBMS都支持SQL,因此,学习此语言使你几乎能与全部数据库打交道。
 SQL简单易学。它的语句全都是由描述性很强的英语单词组成,并且这些单词的数目很少。
 SQL尽管看上去很简单,但它其实是一种强有力的语言,灵活使用其语言元素,能够进行很是复杂和高级的数据库操做。
相关文章
相关标签/搜索