mysql---学习与总结(2)

SQL语句的两大类:

DML:比如像update,delete,操作数据本身的

DDL:比如像CREATE DROP,等操作数据对象的

CREATE DATABASE创建数据库

CREATE INDEX 创建索引

CREATE TABLE 创建表

============

表的创建:

CREATE TABLE 表名 (定义字段:列名/列定义(数据类型/数据修饰符))

如果这个table没有什么特殊意义的话,尽量做到见名知意

比如:

CREATE TABLE stus (

       ->    Name CHAR(18),

       ->    Gender CHAR(1)); 

使用DESC stus;查看我们的刚定义的表。

修改表结构操作:
语法:alter table 表名 action

action可以是如下语句;

-add 列名 建表语句 [first|after 列名]

-add primary key(列名)

-add foreign key(列名) references 表名(列名)

-alter 列名 set default 默认值

============

常见的数据类型

1.Character String Types字符串型

              CHAR: 固定长度

              VARCHAR: 浮动长度

              BINARY: 按照二进制的格式存储(严格区分大小写)

              VARBINARY: 可变程度的二进制格式存储

              TINYBLOB: 极小的二进制大对象(binary large boject)

              BLOB: 小的的二进制大对象

              MEDIUMBLOB: 中等的二进制大对象

              LONGBLOB: 超大的二进制大对象

              TINYTEXT: 极小的整篇字符

              TEXT: 存储类似于论坛发帖的那样的对象的

              MEDIUMTEXT: 中等的整篇字符

              LONGTEXT: 超大的整篇字符

              ENUM: 内置的两种特殊类型,枚举类型(选男女)

              SET: 也是枚举,不过比较方法不同

2.Binary Large Object String Type二进制型

3.Numeric Types数值型

              精确数值型:整型,表示精确值(无符号类型的范围)

                     TINYINT (255)

                     SMALLINT (65535)

                     MEDIUNINT (16777215)

                     INT (4294967295)

                     BIGINT (18446744073709551615)

              浮点型:单精度浮点型和双精度浮点型(非精确值)

                     FLOAT 4字节

                     DOUBLE 8字节

                     REAL

              Bit型:

4.Boolean Types波尔型 TINYINT(1)

              BOOLEAN

              BOOL

5.Datetime Types日期时间型

              DATE:日期(3字节) ‘1000-01-01’-‘9999-12-31’

              TIME(p):时间

              DATETIME:日期+时间(3字节) ‘1000-01-01 00:00:01’-‘9999-12-31 23:59:59’

              TIMESTAMP(p):时间戳(4字节)(做相对计时的,从XX年XX月XX日到现在的经过的秒数) ‘1970-01-01 00:00:00’- ‘2038-01-18 22:14:07’

              YEAR:年份,

                    YEAR4 (1901-2155)

                    YEAR2 (00-99),表示2011年还是11年

6.Interval Types:

            枚举型,

                    ENUM 1-65535

           集合型

                     SET 1-64

分类的简单介绍:

1.字符串类型:(具体定义成什么,要视内容的变化而定)

              固定长度的定义方式:(最多255字符)

                     CHARACTER(length)

                     CHAR(length)

              可变长度的定义方式:(定义大小一般为大小+1)(最多65535)

                     CHARAVTER VARYING(length)

                     CHAR VARYING(length)

                     VARCHAR(length)

字符串类型的修饰类型:

              NOT NULL :非空

              NULL:允许为空

              DEFAULT:给一个默认值,默认值应该加引号,在mysql里所有的默认值都必须加引号

              BINARY:

              CHARACTER SET:字符集,使用哪一种格式的字符集。

              COLLATION:定义某种特定字符集的排序方式。

SHOW CHARACTER SET:用于显示我们系统支持的所有字符集的类型。

SHOW COLLATION:查看所有的排序方式,排序方式是肯定多于字符集的,因为每一种字符集都有多种排序方式。

       BLOB:二进制大对象的特点:

    按照字母表的严格区分大小写的方式进行排序的。BLOB在定义的时候,而这些大对象的存储一般都不会在表中存储,而是在表之外的特定地方

数值型:

       精确数值型:整形,BIT等

       浮点型:FLOAT REAL DOUBLE

       整形的修饰符:

       AUTO_INCREMENT :自动增长,一个字段用于表述行的ID号的。大部分情况下,它是无符号类型的。凡是定义成这个的,必须定义成主键或者唯一键。类型不能为空

       UNSIGNED:无符号

       FLOAT的修饰符

       对于FLOAT我们可以定义整体位宽:(p),以及精度:(g,f

       char和int括号里的内容是不一样的,char后的括号表示限定多少长度,而int的括号表示到时候显示的时候显示多少位

日期时间

       日期时间的修饰符:

              NOTNULL

              NULL

              Default

       使用 SELECT CURRENT_DATE();

              SELECT CURRENT_TIME();可以查看当前系统的日期和时间

枚举型:

比如创建一个枚举型的用户表,前面有自动生成的ID号,然后对应非空的姓名,性别枚举只有男女,默认男,含年龄的表

      CREATE TABLE users (

->    ID INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,

->    Name VARCHAR(100) NOT NULL,

->    Gender ENUM(‘M’,’F’) NOT NULL DEFAULT ‘M’,

->    Age TINYINT UNSIGNED

->    );

       插入数据

       INSERT INTO users (Name,Age) values (‘Jerry’,18);

       当我们插入一个非法的数据的时候,能否插入数据,则根据Mysql的工作模式来定义了。

============

Mysql的工作模式:

       决定了我们的sql在书写语法的时候到底有多高的规范要求。当存储数据在违反规则的时候,是否能够允许插入禁区

       SHOW VARIABLES LIKE ‘%sql_mode%’;查看工作模式

       SET sql_mode=’ansi’将我们的SQL模型定义为ansi。

常用的模式有哪些呢?   

              ANSI [QUOTES]:定义字符串只能使用单引号,双引号和反引号引用表的名字等……(在传统模型下,引号什么的是不分的)

              IGNORE_SPACE:忽略内建函数的空白字符

              STRICT_ALL_TABLES:所有的非法数据都不允许插入

              STRICT_TRANS_TABLES:

              TRADITIONAL:默认格式

Mysql变量类型:

       全局变量:对每一个新建立的会话(用户连接进来)都是生效的

       会话变量:只对当前会话有效,而且登出之后就无效了。

查看变量:

       SHOW VARIABLES 查看所有变量

              SHOW GLOBAL VARIABLES:查看所有的全局变量

              SHOW SESSION VARIABLES:查看所有的会话变量

       模式匹配:

       LIKE ‘%sql_mode%’比如:

              SHOW GLOBAL VARIABLES LIKE ‘time%’:time开头的

              SHOW GLOBAL VARIABLES LIKE ‘%time%’:包含time的

              SHOW GLOBAL VARIABLES LIKE ‘%time’:time结尾的

设置变量:

       SELECT @@global.sql_mode : 设置全局变量

       SELECT @@session.sql_mode :设置会话变量

       SET sql_mod = ‘XXX’设置的是会话变量

       SET GLOBAL sql_mode = ‘XXX’ 设置全局变量

MySQL到底如何区分大小写:

       1.对于关键字:

         是不分大小写的,但是,如果你习惯小写就一定小写,习惯大写一定大写,但是默认应该都是大写的。对于后期的缓存识别非常重要。

       2.对于数据库名,表明,视图的名字

         关乎于你的操作系统,Linux上是完全区分大小写的,Windows是不分大小写的

       3.存储过程和存储函数是不区分大小写的。

       4.触发器区分大小写。

       5.别名:区分大小写。

       6.字符串:取决于你的数据类型。char是区分的,

跟数据库相关的命令:

mysql每一个数据库都一个对应的目录来存储。每一个目录,都由表来对应数据文件。数据库其实就是由表组成的数据集。

1.创建数据库:

       CREATE DATABASE XXX;

       为了避免数据库重复,可以使用

       CREATE DATABASE IF NOT EXISTS db_name; 则表示如果db_name不存在则创建

2.指定额外信息:

       指定默认字符集,和排序法则

       CREATE DATEBASE db_name CHARACTER SET char_set COLLATE collate;

3.查看一个数据库在创建的时候用什么命令来创建:

       SHOW CREATE DATABASE db_name;

4.删除数据库:

       DROP DATABASE db_name;

       DROP DATABASE IF EXISTS db_name;如果数据库存在则删除,否则报告。 

5.改变数据库属性:改变字符集合默认法则的

       ALTER DATABASE db_name COLLATE collate

       ALTER DATABASE db_name CHARACTER SET charset

表和索引:

       索引的主要作用是加快查找的,但是也有弊病,就是当数据更新的时候,索引必须重建。所以对于数据库的修改,是会降低速度的。

       键:key,constraints

       候选键:类似于ID这样的,让某一个字段来唯一的代表/标示某一行的,这样的字段或者字段的组合就叫做候选键:能够唯一标示这个表中唯一行的某一个字段或者字段的组合。比如ID号什么的。

       主键(primary key):从候选键中挑出一个,来代表这一行。主键一般会被默认定义成为mysql的索引。

       唯一键(unique key):一个字段或者多个字段组成的数据必须是唯一的,他和主键候选键的区别,他们不允许为空,但是唯一键允许为空值。

       外键(foreign key):用于在表和表之间建立关系的。而外键则是用于在两个表之间建立关系的。

为了不产生多余的冗余,比如800人同时选择了课程“马克思主义毛泽东思想邓小平理论和三个代表”则这就很多人选择了很多相同的,这就产生了很多冗余。我们可以完全重新编辑一个表,将这个表定义成1=“XXXXX”则,我们就可以在之后的定义课程中直接定义为课程1。这就是外键的定义。

       数据库的范式:数据库设计的时候数据冗余以及数据存储的约束/标准。一般分为1-5范式……常用的必须符合第三范式。

                 对于Mysql来讲,如果想支持外键,必须选择支持事务的存储引擎。

    索引应该优先创建在那些经常在SELECT语句里那些经常出现在WHERE语句中的命令的。

查看mysql的当前系统所有的支持的存储引擎:

       SHOW ENGINES;

       显示为DEFAULT的为默认的数据引擎。

       我们在创建数据库表的时候可以定义到底使用哪个数据引擎。在5.1以前的mysql中默认引擎都是MyISAM,但是当被oricla收购之后,则InnoDB变成了默认的数据引擎。

你可能感兴趣的:(mysql---学习与总结(2))