跟随我在oracle学习php(17)

时间:2023-03-08 19:13:05

通用设定形式

定义一个字段的时候的类型的写法。

比如:

create  table  tab1  (f1  数据类型 );

数据类型: 类型名[(长度n)]  [unsigned]  [zerofill]

长度n: 表示的意思是该数字的“显示形式上的长度”,

unsigned:设定为“无符号”数,则此时不能存储负数,正数几乎加倍。

zerofill:填充0,是指如果一个数字的长度不够指定长度的时候,可以在左边填充0以补到该长度。

注意: 如果设置了zerofill,则自动也就表示同时具备了unsigned修饰的含义

字段属性设置

not  null: 不为空,表示该字段不能放“null”这个值。不写,则默认是可以为空

auto_increment:  设定int类型字段的值可以“自增长”,即其值无需“写入”,而会自动获得并增加

此属性必须随同 primary key  或 unique key 一起使用。

[primary] key: 设定为主键。是唯一键“加强”:也不能重复并且不能使用null,并且可以作为确定任意一行数据的“关键值”,最常见的类似:where id= 8;  或  where  user_name = ‘zhangsan’;

通常,每个表都应该有个主键,而且大多数表,喜欢使用一个id并自增长类型作为主键。

但:一个表只能设定一个主键。

unique  [key] : 设定为唯一键:表示该字段的所有行的值不可以重复(唯一性)。

default  ‘默认值’: 设定一个字段在没有插入数据的时候自动使用的值。

comment  ‘字段注释’:

create table login(

Id  int auto_increment primary key,

Name varchar(10) comment  '这是姓名',

Age char(1) default  '1'

);

索引设置

什么是索引:

索引是一个“内置表”,该表的数据是对某个真实表的某个(些)字段的数据做了“排序”之后的存储形式。

其作用是:极大提高表查找数据的速度!——其效率(速度)可以匹敌二分查找。

注意:索引在提供查找速度的同时,降低增删改的速度。

对创建(设计)表来说,建立索引是非常简单的事,形式如下:

索引类型 (字段名1,字段名2, .... ) //可以使用多个字段建立索引,但通常是一个

有以下几种索引:

普通索引:key(字段名1,字段名2, .... ):它只具有索引的基本功能——提速

唯一索引:unique  key (字段名1,字段名2, .... )

主键索引:primary  key (字段名1,字段名2, .... )

全文索引:fulltext (字段名1,字段名2, .... )

约束设置

什么叫约束:约束就是一种限定数据以符合某种要求的形式(机制)

约束主要有:

主键约束:primary  key (字段名1,字段名2, .... )

其实就是主键索引,也是主键属性。即primary  key有3个角度的理解(说法):字段属性设置为主键,或建立的主键索引,或设定一个主键约束,但他们的本质是一样

唯一约束:unique  key  (字段名1,字段名2, .... ),其实也是“3体合一”(类似primary key)

外键约束:

什么叫外键:就是设定一个表中的某个字段的值,必须“来源于”另一个表的某个主键字段的值。

语法形式:

foreign key (字段名1,字段名2, .... ) references 表名2(字段名1,字段名2, .... )

说明:

对某个(些)字段设定外键,则其相对应的其他表的对应字段需要设置为主键。

exp:

drop table user;

create table user(

Name1 varchar(10) primary key

);

drop table login;

create table login(

Id  int auto_increment primary key,

Name varchar(10) comment  '这是姓名',

Age char(1) default  '1',

Foreign key (name) references user(name1)

);

表选项

表选项就是对一个表的有关属性的设定,通常都不需要。如果不设定,则有其默认值。

有以下几个可用:

comment = ‘表的注释’;

charset = 字符编码名称; //跟数据的字符编码设定一个意思。

字符编码设定的范围及继承关系:

系统级设定:安装时确定了。

库级设定:建库时设定;

表级设定:就是这里的charset = 字符编码名称

字段级设定:作为字段属性出现。

他们都只对“字符类型”的字段有效。每一级如果没有设定,就会“继承使用”其上一级的设定。

auto_increment = 起始整数; //自增长类型值的初值,默认是1

engine = “表的存储引擎名”; //

存储引擎就是将数据存入硬盘(或其他媒介)的方式方法。通常就几个可用,默认是InnoDB

存储引擎决定一个数据表的各方面的信息:功能和性能。