**目录**
* [1 建立表格](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#1__3)
* [1.1 表格属性](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#11__25)
* [1.2 字串字段属性](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#12__63)
* [1.3 数值字段属性](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#13__73)
* [1.4 通用字段属性](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#14__81)
* [1.5 TIMESTAMP字段型态与默认值](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#15_TIMESTAMP_119)
* [1.6 使用其它表格建立一个新表格](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#16__157)
* [1.7 建立暂存表格](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#17__198)
* [2 修改表格](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#2__211)
* [2.1 增加字段](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#21__217)
* [2.2 修改字段](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#22__241)
* [2.3 删除字段](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#23__255)
* [2.4 修改表格名称](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#24__265)
* [3 删除表格](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#3__275)
* [4 索引介绍](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#4__283)
* [5 建立索引](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#5__313)
* [5.1 在建立表格的时候建立索引](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#51__317)
* [5.2 在修改表格的时候建立索引](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#52__357)
* [5.3 使用“CREATE INDEX”建立索引](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#53_CREATE_INDEX_367)
* [6 索引的名称](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#6__385)
* [7 删除索引](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#7__399)
* [8 数值字段型态与AUTO\_INCREMENT](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#8_AUTO_INCREMENT_417)
* [9 查询表格与索引资讯](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#9__481)
* [9.1 表格相关资讯](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#91__485)
* [9.2 索引相关资讯](https://www.kancloud.cn/thinkphp/mysql-tutorial/36443#92__522)
# 1 建立表格
在建立好数据库以后,就可以根据储存资料的需求,使用SQL叙述建立所有需要的表格(table)。建立表格的设定非常多,以建立“world.city”表格来说,它的叙述会像这样:
[](http://box.kancloud.cn/2015-09-15_55f7e96e360eb.png)
根据不同的需求,建立表格的语法有好几种,下列是建立表格基本的语法:
[](http://box.kancloud.cn/2015-09-15_55f7e96f0dfb2.png)
MySQL规定一个表格中至少要有一个字段,在设定表格中的字段时,至少要明确的决定字段的名称与型态,其它的字段设定都是选择性的,如果有一个以上字段,要使用逗号隔开:
[](http://box.kancloud.cn/2015-09-15_55f7e96f50f47.png)
使用需要的资料型态,就可以建立一个可以储存亲友通讯录的表格:
[](http://box.kancloud.cn/2015-09-15_55f7e975143ff.png)
建立表格的时候可以使用“IF NOT EXISTS”选项,预防发生表格已存在的错误:
[](http://box.kancloud.cn/2015-09-15_55f7e97619ce9.png)
## 1.1 表格属性
建立表格的时候也可以为表格加入需要的表格属性(table attributes)设定,这里会先讨论关于储存引擎、字符集和collation的属性设定。如果你在建立表格的时侯,没有指定这些属性,MySQL会使用服务器默认的储存引擎作为表格的储存引擎,字符集与collation会使用数据库默认的设定。
你可以针对表格的需求,设定它使用的储存引擎、字符集与collation:
[](http://box.kancloud.cn/2015-09-15_55f7e97696d08.png)
下列的叙述在建立“addressbook”表格的时候,使用“ENGINE”、“CHARCTER SET”和“COLLATE”设定表格自己使用的储存引擎、字符集与collation:
[](http://box.kancloud.cn/2015-09-15_55f7e976dfaf5.png)
注:根据语法的说明,“CHARCTER SET”也可以使用比较简短的“CHARSET”;另外在设定时都可以省略“=”。
MySQL数据库服务器支援许多不同应用的储存引擎,你可以使用“SHOW ENGINES”查询:
[](http://box.kancloud.cn/2015-09-15_55f7e97769f6a.png)
在建立表格的时候,如果没有使用“ENGINE”设定储存引擎,那就会使用MySQL数据库服务器默认的储存引擎。你可以使用下列的方式修改MySQL数据库服务器默认的储存引擎设定:
* 修改设定档:MySQL数据库服务器在启动时会读取一个名称为“my.ini”的设定档,档案中有许多启动数据库服务器时需要的资讯。其中就包含默认的储存引擎设定,你可以修改这个设定后再重新启动数据库服务器,让新的设定生效:
[](http://box.kancloud.cn/2015-09-15_55f7e9782a5ca.png)
* 设定储存引擎:你也可以使用“SET”叙述设定默认的储存引擎:
[](http://box.kancloud.cn/2015-09-15_55f7e97854eab.png)
在建立表格时指定字符集与collation会有一些不同的组合。如果只有指定字符集,MySQL会使用你指定字符集的默认collation:
[](http://box.kancloud.cn/2015-09-15_55f7e98d6cb22.png)
如果只有使用“COLLATE”指定collation,MySQL会使用你指定collation所属的字符集:
[](http://box.kancloud.cn/2015-09-15_55f7e997cd707.png)
注:建立表格的时候,不管你有没有指定,表格都会有字符集与collation的设定。在这个表格中的“非二进位制、non-binary”字串型态字段,还有“ENUM”与“SET”型态字段,都会使用表格默认的字符集与collation。
## 1.2 字串字段属性
如果一个字段的型态是字串的话,你还可以依照需求加入字串型态的字段属性(column attributes)。“非二进位制、non-binary”字串可以额外设定字符集与collation:
[](http://box.kancloud.cn/2015-09-15_55f7e99865dcb.png)
每一个表格都会有一个默认的字符集与collation设定,如果没有指定字段的字符集与collation,就会使用默认的设定:
[](http://box.kancloud.cn/2015-09-15_55f7e998a970e.png)
## 1.3 数值字段属性
数值型态字段专用的属性设定有“UNSIGNED”、“ZEROFILL”与“AUTO\_INCREMENT”:
[](http://box.kancloud.cn/2015-09-15_55f7e998f236f.png)
注:数值型态字段设定为“UNSIGNED”与“ZEROFILL”的效果在“第八章、表格与索引、建立表格、数值字段属性”中已经讨论过;而“AUTO\_INCREMENT”的设定与索引有关,所以在这一章后面索引的部份一起讨论。
## 1.4 通用字段属性
除了字串与数值两种字段专用的字段属性设定外,还有许多可以用在所有型态的字段属性:
[](http://box.kancloud.cn/2015-09-15_55f7e999d8a69.png)
“NOT NULL”字段属性可以用来禁止某个字段储存“NULL”值,一般来说,“NULL”值用来表示一个字段的资料是“不确定”、“未知”或“没有”。不过有一些字段并不能出现“NULL”值,不然就会成为一笔很奇怪的纪录了:
[](http://box.kancloud.cn/2015-09-15_55f7e99b09fa4.png)
使用“NULL”或“NOT NULL”设定字段属性后,在查询表格字段资讯时,是在“Null”字段用“YES”或“NO”来表示:
[](http://box.kancloud.cn/2015-09-15_55f7e9a5620f5.png)
如果一个表格中,有设定为“NOT NULL”的字段,那就要注意你在新增或修改纪录时指定的资料,不能够违反这些规则:
[](http://box.kancloud.cn/2015-09-15_55f7e9a7717fd.png)
使用“DEFAULT”关键字可以设定字段的默认值,你可以自己指定任何想要的默认值,在新增或修改资料的时候都有可能会使用到字段的默认值。要特别注意的是MySQL限制你的默认值只能是“一个明确的值”,也就是默认值的设定不可以使用任何函式或运算式。
如果你没有为字段使用“DEFAULT”关键字设定默认值,而且也没有设定为“NOT NULL”,MySQL会自动为你加入默认值的设定:
[](http://box.kancloud.cn/2015-09-15_55f7e9a977758.png)
以通讯录表格来说,如果纪录的地址大部份都是“Taipei”的话,你可以为“address”字段设定一个默认值:
[](http://box.kancloud.cn/2015-09-15_55f7e9a9d5111.png)
使用“DEFAULT”关键字加入默认值的设定以后,就可以在新增或修改资料的时候使用:
默认值的设定要注意下列的规则:
* “BLOB”与“TEXT”字段型态不可以使用\[DEFAULT\]关键字指定默认值,其它的字段型态都可以
* 不能与其它的字段设定造成冲突。例如一个设定为“NOT NULL”的字段,却使用“DEFAULT NULL”设定默认值为“NULL”
* 指定的默认值要符合字段型态。例如“DATE”型态字段使用“DEFAULT ‘Hello!’”指定默认值
注:“UNIQUE KEY”与“PRIMARY KEY”在这一章后面索引的部份一起讨论。
## 1.5 TIMESTAMP字段型态与默认值
“TIMESTAMP”字段是日期时间资料的一种,它除了具有“时区、timezone”的特性外,也可以搭配“DEFAULT”和“ON UPDATE”来完成一些比较特殊的需求:
[](http://box.kancloud.cn/2015-09-15_55f7e9aaa6eea.png)
在表格中使用“TIMESTAMP”型态的字段时,如果你没有设定它们的字段属性,MySQL会自动帮你在第一个“TIMESTAMP”字段加入“NOT NULL”、“DEFAULT”和“ON UPDATE”三个字段属性的设定。
* “NOT NULL”不允许你储存“NULL”值
* “DEFAULT CURRENT\_TIMESTAMP”设定默认值为目前的日期时间。在所有字段型态中,只有“TIMESTAMP”可以使用“CURRENT\_TIMESTAMP”指定默认值;其它的字段型态,在指定默认值只能是“一个明确的值”
* “ON UPDATE”可以指定在修改纪录的时候,MySQL自动帮你填入的资料
其它没有设定字段属性的“TIMESTAMP”字段,MySQL会帮你加入“NOT NULL”与“DEFAULT”两个字段属性。
“DEFAULT CURRENT\_TIMESTAMP”字段属性的效果,在你新增纪录的时候就可以看得出来了:
[](http://box.kancloud.cn/2015-09-15_55f7e9ab1fe9f.png)
而“ON UPDATE CURRENT\_TIMESTAMP”字段属性,会在修改纪录的时候产生效果:
[](http://box.kancloud.cn/2015-09-15_55f7e9abeae78.png)
“TIMESTAMP”字段型态很适合用来记录资料新增或修改的日期与时间。可是如果在同一笔纪录中,要使用一个字段记录新增资料的日期与时间,而使用另一个字段记录修改资料的日期与时间。为了应付这样的需求,你应该会使用下列的字段定义:
[](http://box.kancloud.cn/2015-09-15_55f7e9acd19e8.png)
在一个表格中,MySQL限制“CURRENT\_TIMESTAMP”只能在一个字段出现,所以当有这样的需求出现时,你必须使用MySQL提供给你的特殊设定方式来解决:
[](http://box.kancloud.cn/2015-09-15_55f7e9ae46448.png)
建立好这样的表格以后,看起来虽然怪怪的,不过当你指定“created”字段的值为“NULL”的时候,MySQL会自动为你填入目前的日期与时间:
[](http://box.kancloud.cn/2015-09-15_55f7e9aea8acf.png)
后续在修改资料的时候,就只会在“updated”字段填入目前的日期与时间:
[](http://box.kancloud.cn/2015-09-15_55f7e9af56271.png)
## 1.6 使用其它表格建立一个新表格
在数据库中建立需要的表格,通常是使用上列讨论的方式,根据自己的需求,建立一个新的表格来储存需要保存的资料;在一些比较特别的情况,你可能会使用一个现有的表格来建立新的表格,这样的需求可以使用下列的语法:
[](http://box.kancloud.cn/2015-09-15_55f7e9afe74b6.png)
以“world”数据库中的“city”来说,下列的查询叙述可以传回台湾的城市与人口数:
[](http://box.kancloud.cn/2015-09-15_55f7e9b07a901.png)
如果你想要建立一个新表格,这个表格中的资料就是上列查询的结果,就可以使用这种建立表格的语法:
[](http://box.kancloud.cn/2015-09-15_55f7e9b103012.png)
使用这种语法建立的新表格,可以省略字段定义的工作,新表格会使用原有表格的字段名称与定义,而且在查询叙述中传回的资料,会直接新增到新建立的表格中:
[](http://box.kancloud.cn/2015-09-15_55f7e9b2f2a9f.png)
你也可以在建立新表格的时候,使用字段定义来设定新表格的字段型态与其它属性:
[](http://box.kancloud.cn/2015-09-15_55f7e9bda4e7a.png)
如果需要的话,也可以加入查询叙述中没有的字段:
[](http://box.kancloud.cn/2015-09-15_55f7e9be389b4.png)
使用这种语法建立表格时有下列几个重点:
* MySQL使用查询结果的字段名称与型态来建立新的表格
* 如果没有指定储存引擎、字符集或collation的话,建立的新表格使用数据库默认的储存引擎、字符集与collation
* 查询表格中,字段的索引与“AUTO\_INCREMENT”设定都会被忽略
如果只需要借用一个已经存在的表格字段定义,可是并不需要纪录资料的话,你可以使用下列的语法来建立新表格:
[](http://box.kancloud.cn/2015-09-15_55f7e9beb1a3b.png)
使用这种语法建立的新表格,并不会新增纪录到新表格中,可是包含索引与“AUTO\_INCREMENT”设定都会套用在新表格,除了下列两个例外:
* 使用“MyISAM”储存引擎时,你可以在建立表格的时候使用“DATA DIRECTORY”与“INDEX DIRECTORY”指定资料与索引档案的资料夹位置;建立的新表格会忽略这些设定,而使用数据库默认的资料夹
* 字段的“FOREIGN KEY”与表格的“REFERENCES”属性设定都会被忽略
## 1.7 建立暂存表格
上列讨论的建立表格方式,都可以在建立表格的时候,依照需要加入“TEMPORARY”关键字,指定这个新建立的表格为“用户端暂时存在”的表格:
[](http://box.kancloud.cn/2015-09-15_55f7e9bf3fbbd.png)
“TEMPORARY”表格有下列重点:
* “TEMPORARY”表格是每一个用户端专属的表格,用户端离线后,MySQL就会自动删除这些表格
* 因为“TEMPORARY”表格是用户端专属的表格,其它用户端不能使用,所以不同的用户端,使用同样名称建立“TEMPORARY”表格也没有关系
* “TEMPORARY”表格名称可以跟数据库中的表格名称一样,不过在“TEMPORARY”表格存在的时候,数据库中的表格会被隐藏起来
* 可以使用“ALTER TABLE”修改“TEMPORARY”表格名称,不可以使用“RENAME TABLE”修改“TEMPORARY”表格名称
# 2 修改表格
使用“CREATE TABLE”叙述建立表格以后,如果发现某个字段或设定打错,或是在使用一阵子以后,发觉表格中有一些设定不太对。在这些情况下,你可以使用“ALTER TABLE”叙述来修改一个表格的结构:
[](http://box.kancloud.cn/2015-09-15_55f7e9bf6a030.png)
## 2.1 增加字段
你可以使用下列的修改定义增加一个本来没有的字段:
[](http://box.kancloud.cn/2015-09-15_55f7e9bfb77d8.png)
如果你在增加字段的时候,没有指定新增字段的位置,MySQL会把这个字段放在最后一个:
[](http://box.kancloud.cn/2015-09-15_55f7e9bfebdf3.png)
你可以搭配使用“FIRST”关键字,把新增的字段放在第一个:
[](http://box.kancloud.cn/2015-09-15_55f7e9c069f0a.png)
或是使用“AFTER”关键字,指定新增的字段要放在哪一个字段后面:
[](http://box.kancloud.cn/2015-09-15_55f7e9c126aa3.png)
如果需要增加多个字段的话,也可以使用下列的语法一次把需要新增的字段,全部加到表格中;不过这种语法加入的新字段,都会放在最后面的位置:
[](http://box.kancloud.cn/2015-09-15_55f7e9c1cd399.png)
注:“ALTER TABLE”叙述也可以用来增加索引,在这一章后面索引的部份一起讨论。
## 2.2 修改字段
如果需要修改字段的名称、型态、大小范围或其它字段属性,你可以使用下列两种修改定义来执行修改的工作。“CHANGE”可以修改字段的名称与定义,“MODIFY”只能修改字段的定义,不能修改字段名称:
[](http://box.kancloud.cn/2015-09-15_55f7e9c28a4d6.png)
以下列使用“CHANGE”关键字修改表格的叙述来说,它将“one”字段的名称修改为“changecolumn”,型态从“INT”修改为“BIGINT”,而且把修改后的字段位置放在“two”字段后面:
[](http://box.kancloud.cn/2015-09-15_55f7e9e0eb944.png)
下列使用“MODIFY”关键字修改表格的叙述,它将“two”字段的型态从“INT”修改为“BIGINT”,而且把修改后的字段位置放在“three”字段后面:
[](http://box.kancloud.cn/2015-09-15_55f7e9e189a4a.png)
## 2.3 删除字段
如果要删除一个表格中不需要的字段,可以使用下列的修改定义:
[](http://box.kancloud.cn/2015-09-15_55f7e9ece038d.png)
下列格的叙述会删除“two”字段:
[](http://box.kancloud.cn/2015-09-15_55f7e9f71f1dd.png)
## 2.4 修改表格名称
如果需要修改表格的名称,你可以使用下列两种叙述,包含在“ALTER TABLE”叙述中使用修改表格名称的修改定义;或是使用“RENAME TABLE”叙述:
[](http://box.kancloud.cn/2015-09-15_55f7e9f7af503.png)
下列两个叙述都可以把“mytable”表格名称修改为“mynewtable”:
[](http://box.kancloud.cn/2015-09-15_55f7e9f86275c.png)
# 3 删除表格
你可以使用下列的叙述删除一个不需要的表格:
[](http://box.kancloud.cn/2015-09-15_55f7e9f90fb7d.png)
注:使用“DROP TABLE”叙述执行删除表格的工作时,MySQL并不会再次跟你确认是否真的要删除,而是真的就直接删除了,表格储存的纪录资料当然也不见了。
# 4 索引介绍
数据库与表格是MySQL数据库的基本元件,依照需求建立好的数据库与表格后,就可以使用它们来为你保存资料。一个设计良好的数据库,不论是资料的正确性,还有后续的维护与查询都比较不会发生问题。除了好好规划与建立数据库与表格外,你还可以利用“索引、index”预防你的资料出现问题,尤其是表格储存非常大量的纪录时,建立适当的索引,可以增加查询与维护资料的效率。
以“MyISAM”储存引擎来说,资料表的储存的纪录资料,是储存在电脑中的一个档案:
[](http://box.kancloud.cn/2015-09-15_55f7e9f986e02.png)
当你执行一个像这样的查询叙述时:
[](http://box.kancloud.cn/2015-09-15_55f7e9f9e2355.png)
数据库要找到你需要查询或维护的纪录,如果没有索引帮助的话,就会从头开始一边读取,一边判断是否有符合条件的资料。你可以为表格建立索引来改善这种比较没有效率的方式:
[](http://box.kancloud.cn/2015-09-15_55f7e9faa4155.png)
建立城市名称的索引档以后,同样执行下列的查询叙述,MySQL会自动使用索引来快速找到你需要的资料:
[](http://box.kancloud.cn/2015-09-15_55f7ea053b854.png)
注:索引同样可以增加删除或修改的效率。
索引分为主索引键(primary key)、唯一索引(unique index)与非唯一索引(non-unique index)三种。
主索引键的应用很常见,而且一个表格通常会有一个,而且只能有一个。在一个表格中,设定为主索引键的字段值不可以重复,而且不可以储存“NULL”值。因为这样的限制,所以很适合使用在类似编码、代号或身份证字号这类字段。
唯一索引也称为“不可重复索引”,在一个表格中,设定为唯一索引的字段值不可以重复,但是可以储存“NULL”值。这种索引适合用在类似员工资料表格中储存电子邮件帐号的字段,因为员工不一定有电子邮件帐号,所以允许储存“NULL”值,可以每一个员工的电子邮件帐号都不可以重复。
上列两种索引都可以预防储存的资料发生重复的问题,也可以增加查询与维护资料的效率。非唯一索引就只是用来增加查询与维护资料效率的索引。设定为非唯一索引的字段值可以重复,也可以储存“NULL”值。
# 5 建立索引
MySQL提供许多不同的方式让你建立需要的索引。通常在规划一个数据库的时候,会把表格所需要的索引一并规划好,在这样的情况下,你可以把建立索引的定义,加在“CREATE TABLE”叙述中,建立表格的时候就一起把索引建立好;不过也有可能在使用表格一阵子以后,才发觉有建立索引的需求,在这样的情况下,你可以使用“ALTER TABLE”或“CREATE INDEX”建立需要的索引。
## 5.1 在建立表格的时候建立索引
在建立表格的叙述中,你会定义出许多表格所需要的字段,在字段的定义中,除了名称、型态与属性,还可以加入“唯一索引”与“主索引键”的定义:
[](http://box.kancloud.cn/2015-09-15_55f7ea106abb5.png)
以下列这个建立储存联络簿的表格来说,你可以使用这样的语法在“id”字段后面加入“PRIMARY KEY”,指定“id”字段为主索引键,这表示“id”字段的值不可以重复,而且不可以储存“NULL”值;另外在“email”字段加入“UNIQUE KEY”,指定“email”字段为唯一索引,这表示“email”字段的值不可以重复:
[](http://box.kancloud.cn/2015-09-15_55f7ea10dc464.png)
下列是另外一种在“CREATE TABLE”叙述中建立索引的语法:
[](http://box.kancloud.cn/2015-09-15_55f7ea2047a64.png)
同样以建立储存联络簿的表格来说,下列两种建立索引语法的效果是一样的:
[](http://box.kancloud.cn/2015-09-15_55f7ea21091ed.png)
如果你要建立一般索引(可以重复的索引),或是要建立包含多个字段的索引时,就一定要把建立索引的定义加在所有字段定义后面:
[](http://box.kancloud.cn/2015-09-15_55f7ea21a0879.png)
在建立索引的时候,你可以指定某一个字段为建立索引的字段,不过有时候你只想要为一个字串型态字段的部份资料建立索引,或是指定建立的索引资料,是要依照由小到大,还是由大到小排列。有这样的需求时,你可以依照下列的语法来指定:
[](http://box.kancloud.cn/2015-09-15_55f7ea2286e33.png)
以建立联络簿的表格来说,为地址资料“address”字段建立索引的时候,如果你希望建立地址前五个字符的索引资料,而且依照由大到小的顺序。下列的叙述就可以建立这样的索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea232ed70.png)
注:只有“CHAR”、“VARCHAR”、“BINARY”与“VARBINARY”型态的字段可以指定制作索引的长度。“ASC”或“DESC”可以使用在任何型态的字段。
如果一个表格使用的储存引擎是“MEMORY”的话,建立索引的时候还可以额外指定索引使用的“算法、algorithm”。使用其它储存引擎的表格,MySQL会忽略这个设定。索引使用的算法有“BTREE”与“HASH”两种,你可以使用下列的语法来指定索引使用的算法:
[](http://box.kancloud.cn/2015-09-15_55f7ea28d2db9.png)
默认的“HASH”算法适合用在主索引键和唯一索引,这种算法在搜寻不能重复的资料时,效率会比较好;而“BTREE”算法适合用在可以允许重复资料的一般索引,在搜寻上会比“HASH”有更好的效率。
注:“FULLTEXT”索引只能用在“CHAR”、“VARCHAR”与“TEXT”型态的字段,而且表格使用的储存引擎必须是“MyISAM”。“SPATIAL”索引是“SPATIAL”型态字段专用的,而且表格使用的储存引擎必须是“MyISAM”。这两种索引不会在这里讨论。
## 5.2 在修改表格的时候建立索引
如果你想要为一个已经存在的表格建立索引的话,你可以在修改表格“ALTER TABLE”中建立索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea2eb0db8.png)
以下列的范例来说,在建立联络簿表格时没有建立索引,你可以使用“ALTER TABLE”叙述建立需要的索引,不过一个“ALTER TABLE”叙述只能建立一个索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea354b0f0.png)
## 5.3 使用“CREATE INDEX”建立索引
需要为一个已经存在的表格建立索引,除了使用“ALTER TABLE”叙述建立索引外,还可以使用“CREATE INDEX”叙述建立唯一索引与一般索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea363c177.png)
使用“CREATE INDEX”叙述只能建立唯一索引与一般索引,你还是要使用“ALTER TABLE”叙述建立主索引键:
[](http://box.kancloud.cn/2015-09-15_55f7ea354b0f0.png)
为一个已经存在的表格建立索引时,要特别注意主索引键与唯一索引这两种索引。如果这个表格没有任何纪录资料的话,那就不会有问题;可是如果表格中已经有纪录了,而且你想要建立一个主索引键时,有可能会发生下列的错误:
[](http://box.kancloud.cn/2015-09-15_55f7ea3c14d37.png)
为一个已经存在、而且已经有纪录的表格建立唯一索引时,也有可能会发生下列的错误:
[](http://box.kancloud.cn/2015-09-15_55f7ea3ca1c31.png)
# 6 索引的名称
在“CREATE TABLE”或是“ALTER TABLE”叙述中建立索引的话,你可以为建立的索引取一个名称:
[](http://box.kancloud.cn/2015-09-15_55f7ea3ce4c97.png)
如果你在使用上列的语法建立索引的时候没有指定索引名称,MySQL会帮你取一个,索引的名称就是字段名称,如果是多个字段的索引,就会使用第一个字段当作索引名称。
使用“CREATE INDEX”建立索引的时候,就一定要指定一个索引名称:
[](http://box.kancloud.cn/2015-09-15_55f7ea3da6ea8.png)
注:在一般的操作中,你并不会用到索引名称;不过在删除索引的时候就会用到。
# 7 删除索引
如果一个已经建立好的索引已经不需要了,为了节省储存的空间,你可以使用下列的语法删除索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea3ddb46f.png)
下列的叙述使用修改表格“ALTER TABLE”叙述删除不需要的索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea3e4a71a.png)
你也可以使用下列的“DROP INDEX”叙述删除不需要的索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea43a7a7e.png)
使用“ALTER TABLE”叙述可以一次删除多个索引,“DROP INDEX”叙述一次只能删除一个索引:
[](http://box.kancloud.cn/2015-09-15_55f7ea442b13b.png)
# 8 数值字段型态与AUTO\_INCREMENT
在数据库的应用中,很常会遇到为纪录“编流水号”的需求,如果资料表中的每一笔纪录都需要一个递增的数值编号,你可以选择整数型态的字段后,再使用“AUTO\_INCREMENT”字段属性:
[](http://box.kancloud.cn/2015-09-15_55f7ea446528c.png)
如果一个公司想要储存员工开会的资料,你可以在建立开会资料表格的时候,为这个表格定义一个储存开会编号的字段,这个字段需要自动递增,而且会为它建立主索引键:
[](http://box.kancloud.cn/2015-09-15_55f7ea44e0c67.png)
建立开会资料表格以后,另外建立一个储存参加会议的员工资料表格:
[](http://box.kancloud.cn/2015-09-15_55f7ea4a75fcf.png)
设定为“AUTO\_INCREMENT”的整数字段,在新增资料的时候可以不用指定数值,MySQL会为你自动编制一个流水号并储存在纪录中;而接着要新增参加这次开会的员工资料到“participate”表格时,你需要用到MySQL刚才会为你在“meeting”表格中自动编制的流水号,这样的需求可以使用“LAST\_INSERT\_ID()”函式来取得:
[](http://box.kancloud.cn/2015-09-15_55f7ea4bd83ed.png)
新增这些开会与参加会议的员工资料后,就可以使用结合查询来查询开会资料了:
[](http://box.kancloud.cn/2015-09-15_55f7ea4c90188.png)
在新增资料时,要让MySQL为你自动编制一个流水号,并储存到纪录中的方式有下列几种:
[](http://box.kancloud.cn/2015-09-15_55f7ea4d8ac4e.png)
MySQL是一个可以让多人同时使用的数据库,使用“LAST\_INSERT\_ID()”函式来取得自动编制的流水号数值,并不会因为不同的用户端同时使用而造成混乱:
[](http://box.kancloud.cn/2015-09-15_55f7ea4df3e59.png)
“AUTO\_INCREMENT”字段的一般用法通常是用来储存从“1”开始的流水号,每一笔新增的纪录都会自动加一成为新的编号。可是如果在新增纪录的时候,自己指定“AUTO\_INCREMENT”字段一个数值,就会造成下列的情况:
[](http://box.kancloud.cn/2015-09-15_55f7ea4e8ba96.png)
“AUTO\_INCREMENT”字段在你删除纪录以后,也不会帮你重新使用已经用过的编号:
[](http://box.kancloud.cn/2015-09-15_55f7ea4f1e5fc.png)
注:使用“TRUNCATE TABLE”叙述删除包含“AUTO\_INCREMENT”字段表格的所有纪录,编号会重新从头开始。
不要指定值,或是指定“NULL”值给“AUTO\_INCREMENT”字段,都可以让MySQL为你自动编制一个流水号,并储存到纪录中,这两种也是比较好的方式;另外指定“AUTO\_INCREMENT”字段值为“0”的方式也可以,不过会因为MySQL数据库服务器的环境设定而有不同的效果:
[](http://box.kancloud.cn/2015-09-15_55f7ea4fa60c4.png)
如果你需要编制的流水号范围是非常大的,你应该选择“AUTO\_INCREMENT”字段的型态为“BIGINT”;MySQL另外提供一个“SERIAL”关键字,让你在定义这种字段时可以比较方便一些:
[](http://box.kancloud.cn/2015-09-15_55f7ea5023fd5.png)
使用“MyISAM”储存引擎的表格,可以使用下列这种比较特殊的“AUTO\_INCREMENT”字段:
[](http://box.kancloud.cn/2015-09-15_55f7ea50a0f90.png)
这样的设定同样是请MySQL为你自动编制流水号,不过因为“AUTO\_INCREMENT”字段包含在主索引键中,编制流水号的动作会不太一样:
[](http://box.kancloud.cn/2015-09-15_55f7ea560c753.png)
注:在上列的范例中,是把“empno,location,counter”设定为主索引键;如果设定为唯一索引的话,也会有一样的效果;设定为一般索引的话,会造成错误。
使用“AUTO\_INCREMENT”字段属性有下列几个重点:
* 一个表格只能有一个“AUTO\_INCREMENT”字段,而且要为它建立一个索引,而且通常是建立主索引键或唯一索引,这样可以防止重复的编号;不过MySQL也允许你建立可重复的索引
* 只有整数型态才可以使用“AUTO\_INCREMENT”字段属性,你可以根据编号大小的需求,选择使用“TINYINT”、“SMALLINT”、“MEDIUMINT”、“INT”或“BIGINT”,而且因为只会使用到正数,所以你可以加入“UNSIGNED”来增加编号的范围
* 如果编号已经到字段型态的最大范围,例如一个“SMALLINT”型态,而且是指定为“UNSIGNED”的“AUTO\_INCREMENT”字段,编号已经到“65535”了,如果再执行新增的叙述,就会造成“Duplicate entry ’65535′ for key ‘字段名称’”的错误
# 9 查询表格与索引资讯
一个数据库在建立许多表格与索引以后,不论是程式开发或是数据库管理人员,都会有查询表格与索引相关资料的需求。例如查询一个表格中有哪些字段,还有字段的型态与属性的设定;也可能需要查询某一个表格建立了哪些索引与设定的资讯。
## 9.1 表格相关资讯
想要知道一个数据库中有哪一些表格,可以执行下列的叙述:
[](http://box.kancloud.cn/2015-09-15_55f7ea56d7854.png)
这个叙述可以使用“字串样式”设定表格名称的条件:
[](http://box.kancloud.cn/2015-09-15_55f7ea5c43f56.png)
MySQL数据库在启动以后,会有一个很特别的数据库,名称是“information\_schema”,这个数据库通常会称为“系统资讯数据库”。这个数据库中有一个表格叫作“TABLES”,它储存所有MySQL数据库中的表格相关资讯,“TABLES”表格有下列主要的字段:
| 字段名称 | 型态 | 说明 |
| --- | --- | --- |
| TABLE\_SCHEMA | varchar(64) | 数据库名称 |
| TABLE\_NAME | varchar(64) | 表格名称 |
| ENGINE | varchar(64) | 使用的储存引擎名称 |
| TABLE\_ROWS | bigint(21) unsigned | 纪录数量 |
| AUTO\_INCREMENT | bigint(21) unsigned | 如果包含“AUTO\_INCREMENT”字段的话,这个字段会储存下一个编号 |
| TABLE\_COLLATION | varchar(32) | 表格使用的collation |
执行下列的查询叙述就可以查询表格详细的资讯:
[](http://box.kancloud.cn/2015-09-15_55f7ea5cb0146.png)
MySQL也提供下列的叙述让你查询一个表格的定义:
[](http://box.kancloud.cn/2015-09-15_55f7ea5d3e7e3.png)
下列的叙述可以查询建立表格的“CREATE TABLE”叙述:
[](http://box.kancloud.cn/2015-09-15_55f7ea6290068.png)
回传的“Create Table”字段的内容就是一个建立表格的叙述:
[](http://box.kancloud.cn/2015-09-15_55f7ea63022c4.png)
## 9.2 索引相关资讯
MySQL提供“SHOW INDEX”叙述查询一个表格的索引详细资讯,下列是执行这个叙述以后,传回的主要字段资料:
| 字段名称 | 说明 |
| --- | --- |
| Table | 表格名称 |
| Non\_unique | “0”表示不可重复;“1”可以重复 |
| Key\_name | 索引名称 |
| Seq\_in\_index | 单一字段的索引为“1”;多个字段的索引表示建立索引的字段顺序 |
| Column\_name | 索引字段名称 |
| Sub\_part | 如果是指定长度的索引,这里会显示长度;不是的话显示“NULL” |
| Null | 是否允许“NULL”值 |
| Index\_type | 索引种类,“BTREE”或“HASH” |
你可以在“SHOW INDEX FROM”后面指定一个表格名称,执行以后就可以查询这个表格所有的索引资讯:
[](http://box.kancloud.cn/2015-09-15_55f7ea6393f9d.png)
- 空白目录
- 常用功能
- PHP中常用的header头部定义
- 压缩包下载1
- 压缩包下载2
- 文件下载
- php常用加密函数总结
- url请求参数加解密
- PHP操作大全
- 指定月份的第某个月
- PHP 数组和字符串互相转换实现方法
- php字符串截取的简单方法
- php 根据子分类循环获取其父级分类
- PHP文件操作功能函数大全
- PHP常用到的功能函数
- 自定义php常用函数110个
- 自定义PHP常用功能函数
- 开发中常用自定义小功能函数
- PHP判断远程文件是否存在
- PHP写文件函数
- PHP生成GUID的函数
- PHP常用正则表达式汇总
- php字符串压缩
- PHP无限分组
- PHP简单 对象(object) 与 数组(array) 的转换
- PHP数组常用函数
- PHP调式测试函数
- PHP常用字符串的操作函数
- mysql 常用内置函数
- PHP通用请求函数CURL封装
- 裁剪图片PHP代码
- PDO操作MYSQL封装类
- 10个实用的PHP代码片段
- 获取访问者IP地址
- PHP实现发红包程序
- PHP把文本转换成图片
- curl重写php file_get_contents
- PHP生成一个随机字符串
- PHP读文件和写文件
- PHP根据key 给二维数组分组
- php中curl模拟post提交多维数组
- 33个超级有用必须要收藏的PHP代码样例
- PHP防XSS 防SQL注入的代码
- php常用数组array函数实例总结
- 用PHP遍历目录下的全部文件
- GBK2UTF8
- php函数类库
- 一、php一些常用的校验
- 1.1、校验是否为空(null/空串)1
- 1.2、校验是否为纯数字1
- 1.3、校验是否为纯数字(正则)1
- 1.4、检验手机号1
- 1.5、校验邮箱格式1
- 1.6、检查密码长度是否符合规定1
- 二、手机类型访问判断
- 三、字符集文件转换
- 3.1、utf8转gbk
- 3.2、gbk转utf8
- 3.3、繁体转简体
- 3.4、简体转繁体
- 3.5、unicode转utf8
- 3.6、utf8转unicode
- 3.7、Ascii转拼音
- 3.8、gbk转拼音
- 3.9、数组 utf8转gbk
- 3.10、数组 gbk转utf8
- 3.11、json 处理gbk转码utf-8问题( json_encode转换数组,值为null)
- 3.12、Unicode解码
- 四、文档目录操作
- 4.1、转化 \ 为 /
- 4.2、创建目录
- 4.3、拷贝目录及下面所有文件
- 4.4、转换目录下面的所有文件编码格式
- 4.5、列出目录下所有文件
- 4.6、设置目录下面的所有文件的访问和修改时间
- 4.7、目录列表
- 4.8、删除目录及目录下面的所有文件
- 4.9、取得文件扩展
- 4.10、查询字符是否存在于某字符串
- 4.11、获取文件目录列表
- 4.12、删除一个路径下的所有文件夹和文件的方法
- 4.13、文件下载
- 五、session与cookie
- 5.1、设置session
- 5.2、读取session
- 5.3、清除session
- 六、CURL操作
- 6.1、发起get请求
- 6.2、发起post请求
- 6.3、curl获取跳转后的网址的url
- 6.4、curl判断远程图片是否加防盗链
- 6.5、curl获取301页面的内容
- 6.6、curl判断文件是否存在(404)
- 6.7、php的curl封装类
- 七、日期、时间与字节转换
- 7.1、转换字节数为其他单位(Gb、Mb等)
- 7.2、时间转换(将秒转换为时间)
- 7.3、将秒转换成 天-时分秒
- 7.4、时间转换(将时分秒转换为秒)
- 7.5、计算两个时间相差的天
- 7.6、获取文件大小并格式化
- 7.7、返回13位时间戳
- 7.8、返回与当前时间的差距,如1分钟前,2小时前,5月前等
- 7.8、PHP中DateTime的常用方法
- 八、对象、数组、字符串、转义等
- 8.1、将数组转换为对象
- 8.2、将对象转换为数组
- 8.3、将字符串转换为数组
- 8.4、将数组转换为字符串
- 8.5、将文本格式成适合js输出的字符串
- 8.6、返回经addslashes(转义)处理过的字符串或数组
- 8.7、返回经stripslashes(删除反斜杠)处理过的字符串或数组
- 8.8、返回经htmlspecialchars(字符转html)处理过的字符串或数组
- 8.9、安全过滤函数
- 8.10、xss过滤函数
- 8.11、过滤ASCII码从0-28的控制字符
- 8.12、格式化文本域内容
- 8.13、将文本格式成适合js输出的字符串
- 8.14、转义 javascript 代码标记
- 8.15、数组转码
- 8.16、php用逗号格式化数字
- 8.17、数组去重
- 8.18、字符串去重
- 8.19、数组排序
- 九、加密扩展
- 9.1、简单的字符串加密、解密函数
- 9.2、简单的加密解密类
- 9.3、简单对称加密算法2
- 9.4、常用对称加密算法(DES/AES)类
- 9.5、3des加密解密类-三重数据加密算法
- 十、随机数、获取请求ip等
- 10.1、产生随机字符串
- 10.2、获取请求ip
- 10.3、生成一定范围内的随机数字
- 10.4、生成不重复的随机数
- 10.5、生成一定数量的随机数,并且不重复
- 10.6、生成32位随机数
- 10.7、生成9位随机数字(可以做qq用)
- 十一、其他
- 11.1、php对html页面压缩函数
- 11.2、构建层级(树状)数组、
- 11.3、获取内容中的图片
- 11.4、生成sql语句,如果传入$in_cloumn 生成格式为 IN('a', 'b', 'c')
- 11.5、打印各种类型的数据,调试程序时使用。
- 11.6、URL重定向
- 11.7、替换html代码里的所有图片的url,新增url
- 11.8、去除html里的p标签
- 11.9、去除字符串中所有html代码(格式化代码html)
- 11.10、将number_format的输出转换为php数字
- 11.7、内容里批量替换图片的url地址为自己的地址
- 十二、类库
- 1、php 5.6.3PHP封装的数据库模型Model类完整示例【基于PDO】
- 2、Curl类库
- 3、php PDO数据库类库
- 4、获取网站title
- 字符串配置转数组
- 数组助手类1
- 获取随机字符串
- 获取头像存储路径
- 单位转换函数
- 获取字符串长度
- 获取中文字符拼音首字母
- 获取当前页面URL地址
- 获取n天前的时间戳
- 获取n天前0点的时间戳
- 获取ip地址所在的区域
- 邮箱验证
- PHP常用函数总结(160多个)
- PHP判断输入数据是否合法常用的类
- 无限极分类
- php ajax实现分页功能
- 代码
- html
- sendAjax.js
- data.js
- page.js
- page.css
- php基础
- 字符串
- 字符串1
- 字符串常用函数
- 数组
- 数组简介
- 数组的定义
- 数组的操作
- 1 数组的计算
- 2 for循环遍历索引数组
- 3 foreach遍历关联数组
- 4 list、each函数遍历数组
- 5 常用操作数组函数
- 数组的常用函数
- 时间
- PHP的日期和时间
- 1 获取时期时间信息函数
- 2 日期验证函数
- 3 获取本地化时间戳函数
- 4 程序执行时间检测
- 文件操作
- 文件处理系统
- 1 读取文件
- 2 创建和修改文件内容
- 3 创建临时文件
- 4 移动、拷贝和删除文件
- 5 检测文件属性函数
- 6 文件常用函数和常量
- 7 文件锁处机制
- 8 目录处理函数
- 9 文件权限设置
- 10文件路径函数
- 11 小小文件留言本
- 12 修改配置文件的实例
- 流程控制
- 流程控制结构
- if条件结构流程
- 1 if语句
- 2 嵌套if...else...elseif结构
- 3 if语句多种嵌套
- 分支结构switch语句的使用
- 循环语句的使用
- 1 while循环
- 2 do...while循环的区别
- 3 for循环控制语句
- 4 goto语法
- 5 declare 语法
- 函数
- PHP函数
- 自定义函数
- 自定义函数高级调用
- 1 回调函数
- 2 变量函数
- 3 匿名函数
- 4 内部函数
- 5 变量作用域
- 6 参数的引用
- 7 递归函数
- 8 静态变量
- 使用系统内置函数
- 文件包含函数
- 数学常用函数
- 正则
- PHP正则表达式
- 1 正则表达示的定界符
- 2 正则表达示中的原子
- 3 正则表示中的元字符
- 4 正则达达示中的模式修正符
- 5 写正则的诀窍和常用正则
- 6 用正则写一个UBB文本编辑器
- 常用正则
- 错误处理
- 1 禁止显示错误
- 2 错误报告级别
- 3 错误记录日志
- 4 自定义错误处理函数
- 错误及异常处理机制、错误日志
- 过滤器
- 表达式
- PHP基本语法
- PHP基本语法(一)
- PHP基本语法(二)
- GD库图像处理
- 文件上传和下载
- PHP文件上传
- 1 文件上传需要注意php.ini文件
- 2 文件上传的步骤
- 3 文件上传表单注意事项
- 4 按照数组和步骤完成文件上传
- 5 多文件上传
- 6 文件上传进度处理
- PHP图像处理
- 1 学习前的准备工作
- 2 用图片处理函数画一张图
- 3 生成验证码
- 4 图像缩放和裁剪技术
- 5 图片水印处理
- 常量和变量
- 1 用常量限制用户跳过某些文件
- .2 可变变量
- 3 外部变量
- 4 环境变量
- 5 变量引用
- PHP表达式与运算符
- 1 算术运算
- 2 赋值运算
- 3 自加、自减运算
- 4 比较运算
- 5 逻辑运算
- 6 位运算
- 7 运算符优先级
- 8 三元运算符和其它运算符
- 会话管理和控制
- 1 Cookie概述
- 2PHP中的Cookie
- 3 session概述
- 4 PHP中使用session
- 5 SESSION应用实例
- 会话技术(cookie session)
- 会话技术 session场景使用介绍!
- PHP.in中session和cookie的配置说明
- 通过cURL来做小偷程序
- 1 curl的使用步骤
- 2 自定义get方法抓取网页
- 3 使用post发送数据
- PHP基础数据类型及运算符介绍
- 数据类型
- 1 整型就是整数
- 2 布尔就是易经的知识
- 3 字符串
- 4 浮点型
- 5 重要:if和else语法
- 6 NULL类型
- 7对象以后会学
- 8 数组会有单纯的一个章节
- 9 资源类型
- 10 眼前了解回调类型即可
- 11 查看和判断数据类型
- 12 数据类型的自动转换和强制转换
- PHP版本
- php自动加载
- xml的介绍
- openssl的介绍
- php文件管理
- 数据库Mysql
- 数据库之MySQL(概述)
- PHP数据库编程
- 数据库编程(2)
- SQL常见的可优化点
- Mysql设计与优化专题
- mysql的最佳索引攻略
- 详解慢查询
- ER图,数据建模与数据字典
- 数据中设计中的范式与反范式
- 字段类型与合理的选择字段类型
- 表的垂直拆分和水平拆分
- 21分钟 MySQL 入门教程
- 一、MySQL的相关概念介绍
- 二、Windows下MySQL的配置
- 三、MySQL脚本的基本组成
- 四、MySQL中的数据类型
- 五、使用MySQL数据库
- 六、操作MySQL数据库
- 七、创建后的修改
- 八、附录
- 3天入门MySQL
- 前言1
- 01. 数据库的用途和概念
- 02. 娱乐化讲解表关系
- 03. mysql 数据库安装
- 04. 数据语句操作类型
- 05. 连接数据库
- 06. 数据库结构定义语句
- 6.2 数据表操作
- 6.1 数据库操作
- 6.3 数据字段操作
- 07. 类型、字符集、引擎和索引
- 7.1 数据类型
- 7.2 字符集
- 7.3 表引擎
- 7.4 索引
- 08. 增删改查
- 12.8.1 插入记录
- 12.8.2 查询记录
- 12.8.3 多表联合查询
- 12.8.4 更新记录
- 12.8.5 删除记录
- 09. DCL语句
- 10. 常用工具简介
- 附录1 . 学习MySQL常用的英文单词
- MySQL 超新手入门
- (1) 重新开始
- (2) 数据库概论和 MySQL 安装
- (3) SELECT 基础查询
- (4) 运算式和函数
- (5) JOIN 和 UNION 查询
- (6) CRUD 和资料维护
- (7) 字符集和数据库
- (8) 存储引擎和数据类型
- (9) 表格和索引
- (10) 子查询
- (11) 视图
- (12) 预处理语句
- (13) 存储过程入门
- (14) 存储过程的变量和流程
- (15) 存储过程进阶
- (16) 触发器
- (17) 资料库资讯
- (18) 错误处理和查询
- (19) 导入和导出数据
- (20) 性能
- php常用类
- 面向对象
- 面向对象(OOP)编程完全教程
- 1.什么是面向对象
- 2.什么是类,什么是对象,类和对象这间的关系
- 3.什么是面向对象编程呢
- 4.如何抽象出一个类
- 5.如何实例化对象
- 6.如何去使用对象中的成员
- 7.特殊的引用this的使用
- 8.构造方法__construct()与析构方法__destruct()
- 9.封装性(var与public,protected,private的关系)
- 10.__set(),__get(),__isset(),__unset()四个方法的应用
- 11.类的继承
- 12.重载新的方法(parent::)
- 13.访问类型(public,protected,private)
- 14.final关键字的应用
- 15.static和const关键字的使用(self::)
- 16.__toString()方法
- 17.克隆对象__clone()方法
- 18.__call()处理调用错误
- 19.抽象方法和抽象类(abstract)
- 20.PHP5接口技术(interface)
- 21.多态的应用
- 22.把对象串行化serialize()方法,__sleep()方法,__wakeup()方法
- 23.自动加载类 __autoload()函数
- PHPer进阶
- 单例模式
- 工厂方法模式
- 适配器模式
- 建造者模式(通过选择mysql,mongo数据库链接类型做说明)
- 委托模式
- 对象基础实践
- 深入了解面向对象高级特性
- 抽象类和接口类的实际作用
- PHP解决问题进化论(整理笔记)
- PHP7新特性整理介绍篇
- php-fpm 与 Nginx优化总结
- Centos+Nginx+PHP7.0编译安装(和PHP5.6老版本共存)
- PHP7:Mongodb API使用
- PHP之include/require深入了解
- PHP内核了解:生命周期及运行模式
- 面向对象总结
- 基础概念
- 什么是类
- 什么是对象
- 静态属性
- 三大特征
- 封装
- 继承
- 多态
- 9个常用的魔术方法
- __construct
- __destruct
- __call
- __get
- __set
- __sleep
- __toString
- __clone
- __autoload
- 抽象类
- 对象接口
- 面向对象设计模式
- 前言
- (一),单例模式
- (二),Builder模式
- (三),原型模式
- (四),工厂方法模式
- (五),策略模式
- (六),状态模式
- (七),观察者模式
- (八),责任链模式
- (九),适配器模式
- (十),代理模式
- (十一),装饰模式
- (十二),外观模式
- (十三),解释器模式
- PHP开发第一步,PHP5.6 + MySQL5.5 + Apache2.4环境搭建
- 面向对象1
- 类和对象
- 面向对象高级
- php编程总结
- PHP学习笔记
- MySQL学习笔记
- php基础知识
- javascript
- javascript DOM总结
- JavaScript (JS) 函数补充 (含arguments、eval()、四种调用模式)
- JavaScript (JS) 面向对象编程 浅析 (含对象、函数原型链、闭包解析)
- JavaScript (JS)基础:BOM 浅析 (含window对象相关基本方法、属性解析)
- JavaScript (JS)基础:DOM 浅析 (含数组Array、字符串String基本方法解析)
- JavaScript (JS)基础:ECMAScript 浅析 (含Math基本方法解析)
- js功能函数
- 一、js一些常用的校验
- 1.1、校验是否为空(null/空串)
- 1.2、校验是否为纯数字
- 1.3、校验是否为纯数字(正则)
- 1.4、检验手机号
- 1.5、验证座机号
- 1.6、校验ip
- 1.7、检验url地址
- 1.8、检验身份证
- 1.9、检验邮箱
- 1.10、检验日期
- 1.11、检验金额
- 1.12、检验否是汉字
- 1.13、校验数字的表达式
- 1.14、校验字符的表达式
- 1.15、特殊需求表达式
- 1.16、检测密码强度
- 二、手机类型判断
- 三、返回字符串长度,汉子计数为2
- 四、获取url中的参数
- 五、js 绑定事件 适用于任何浏览器的元素绑定
- 六、获得当前浏览器JS的版本
- 七、获取当前点击事件的Object对象
- 八、字符串截取方法
- 九、JS 弹出新窗口全屏
- 十、全选/全不选
- 十一、js 判断浏览器
- 十二、JS判断两个日期大小
- 十三、移除事件
- 十四、回车提交
- 十五、JS 执行计时器
- 十六、JS 写Cookie
- 十七、JS 读Cookie
- 十八、Ajax 请求
- 十九、JS StringBuilder 用法
- 二十、JS 加载到顶部LoadJS
- 二十一、清空 LoadJS 加载到顶部的js引用
- 二十二、JS 替换非法字符
- 二十三、按Ctrl + Entert 直接提交表单
- 二十四、获取当前时间
- 二十五、Js 去掉空格方法
- 二十六、js 动态移除 head 里的 js 引用
- 二十七、整个URL 点击事件 加在URL里的onclick里
- 二十八、判断浏览器使用的是哪个 JS 版本
- 二十九、加入收藏夹
- 三十、动态加载 CSS 样式文件
- 三十一、返回脚本内容
- 三十二、清除脚本内容
- 三十三、返回按ID检索的元素对象
- 三十四、显示元素 待验证
- 三十五、与insertBefore方法(已存在)对应的insertAfter方法
- 三十六、光标停在文字的后面,文本框获得焦点时调用
- 三十七、检验URL链接是否有效
- 三十八、格式化CSS样式代码
- 三十九、压缩CSS样式代码
- 四十、 获取当前路径
- 四十一、ip 转 整型
- 四十二、整型解析为IP地址
- 四十三、删除cookies
- 四十四、判断是否以某个字符串结束
- 四十五、判断是否以某个字符串开头
- 四十六、根据样式名称检索元素对象
- 四十七、 获取移动设备初始化大小
- 四十八、 获取移动设备最大化大小
- 四十九、获取移动设备屏幕宽度
- 五十、获取页面scrollLeft
- 六十、获取页面宽度
- 六十一、获取页面scrollTop
- 六十二、获取页面可视高度
- 六十三、判断数组元素是否重复
- 六十四、生成随机数
- 六十五、数组去重
- 六十六、深度拷贝对象
- 六十七、全部替换replaceAll
- 六十八、阻止冒泡
- 六十九、返回顶部
- 七十、jsonp跨域请求
- 七十一、到某一个时间的倒计时
- 七十二、清除对象中值为空的属性
- 七十三、获取文件后缀名的方法
- 七十四、判断一个对象是不是数组类型
- 七十五、冒泡排序
- 七十六、实现一个最简单的模板引擎
- 七十七、数组最大值最小值
- 七十八、数组求和,平均值
- 七十九、从数组中随机获取元素
- 八十、返回对应元素在数组中的下标
- 八十一、返回数组(字符串)一个元素出现的次数
- 八十二、得到n1-n2下标的数组,即返回数组下标arr[n1]到数组arr[n2]的值
- 八十三、筛选数组,这里所做的就只是删除相应的数组
- 八十四、去除字符串空格
- 八十五、字母大小写切换
- 八十六、字符串循环复制,前面的要循环的字符串,后面的要循环的次数
- 八十七、字符串替换,这里的要替换的字符串必须是连续的
- 八十九、将时间戳转换成日期格式
- 九十、检验字符串是否超过某个值,超出出现省略号
- 九十一、随机码,这里的参数count必须是 2 ~ 36 之间的整数
- 九十二、查找字符串中某字符出现的次数
- 九十三、JS插入排序
- 九十四、获取前num天的日期
- 九十五、js实时计算rem,宽度大于1920px时1rem=100px
- 九十六、原生JS获取鼠标XY轴的值
- 九十七、转成XML对象
- 九十八、Js身份证验证函数
- 九十九、格式化数字串
- 一百、原生Ajax 请求
- 一百零一、两条直角边算角度
- 一百零二、禁止readonly和disabled的input退格键返回上一页
- 一百零三、生成随机字母字符串
- 一百零四、float偏移处理
- 一百零五、根据月份获取起止时间戳
- 一百零六、工具函数对象书写例子,可自己扩展
- 一百零七、js字符串压缩算法与解压
- 一百零八、指定数组元素排序(正序倒序)
- 一百零九、js所有的内置方法
- JavaScript 常用函数总结
- js常用函数整理
- JavaScript基础
- javaScript基础&DOM(一)
- javaScript基础&DOM(二)
- JavaScript语法基础1
- javascript数组对象
- javascript字符串函数
- jquery、javascript实现(get、post两种方式)跨域解决方法
- php MVC原理
- php基础知识(语法与原理)
- PHP编程经验
- 第一章 代码风格
- 第二章 代码注释
- 第三章 目录结构
- 第四章 文件管理
- 第五章 代码整理
- 第六章 路径和路由
- 第七章 实用表格
- 第八章 实用开发软件
- 第九章 技术提升心得
- 第十章 实用插件搭配
- 第十一章 常用设计模式
- PHP编码规范文档
- PHP加快执行效率的写法规范
- VUE避坑指南
- 从零开始学Vue
- Vue-cli
- PHP工具类
- 数组助手类
- 通用助手类
- 时间助手类
- 图像
- 拼音助手类
- 字符串助手类
- 验证助手类
- 时间类封装
- 数据库链式调用封装
- curl 封装 / 发送文件 / 远程下载到服务器
- php Captcha 驗證碼類
- php 替换敏感字符串
- php返回数据格式化类
- php XML文件解释类
- php CSS Update Class
- PHPMailer - PHP email transport class
- PHP 遍历文件夹及文件类及处理类
- 自动登入google play下载app report
- php click captcha 验证码类
- php 获取页面中的指定内容类
- php 支持断点续传的文件下载类
- php 缩略图生成类,支持imagemagick及gd库两种处理
- php 根据url自动生成缩略图
- php 过滤html标记属性类
- php HTTP请求类,支持GET,POST,Multipart/form-data
- php Cookies 操作类
- php 密码生成类
- php main 与 iframe 相互通讯类(同域/跨域)
- php 根据url自动生成缩略图,并处理高并发问题
- php Timer 页面运行时间监测类
- php 双向队列类
- php 导出CSV抽象类
- php zip文件内容比较类
- php 获取/设置用户访问页面语言类
- php 获取Youtube某个User所有Video信息
- php 字符编码转换类,支持ANSI、Unicode、Unicode big endian、UTF-8、UTF-8+Bom 互相转换
- php 版本处理类
- TP5
- 验证器
- 内置规则
- tp5数据库操作
- 数据添加或更新
- 静态增删改查 / 关联操作
- 日志操作
- 路由
- taglib-自制标签
- migrations 数据库迁移
- TP3.2
- 数据库操作
- 发送邮箱
- Tp6
- Redis
- 字符串 / 列表 / Hash / Set / Zet / 基数统计算法
- 队列 /订阅发布 php实例
- 事务 / bitmap 位图 / 地理位置
- 备份与恢复 / 性能测试
- 设置密码 / 模糊查询
- 性能优化
- php+redis实现高并发模拟下单、秒杀、抢购操作
- Redis 的简单介绍
- Redis 最常见的问题
- 扩展thinkphp5的redis类方法
- php for redis
- 前言11
- 字符串11
- 集合
- 有序集合
- 列表
- 哈希
- key操作
- Redis 基础教程
- 简介
- 递增
- 过期
- 列表1
- 集合1
- 可排序集合
- 哈希表
- Redis学习文档
- 序言
- 简介1
- Window 下安装
- 执行
- Linux 下安装
- 数据类型1
- String
- Hash
- List
- Set
- zset
- 区别和详解
- 命令
- Keys
- flushall
- del
- ping
- 设置密码
- 实例
- PHP+Redis 实例【一】点赞 + 热度
- Thinkphp+Redis
- 数据队列
- 字符串111
- 列表11
- 集合11
- 哈希1
- 有序集合1
- 添加redis函数助手
- 基础知识
- Redis的7个应用场景
- 深入解析Redis中常见的应用场景
- MongoDB和Redis的区别
- 相关书籍
- 函数整理
- redis知识总结
- redis学习文档
- 常用命令
- 运维常用命令
- 通用操作相关命令
- 字符串相关命令
- 链表list相关命令
- 集合set相关命令
- 有序集合相关指令
- 哈希hash
- 事务
- 订阅和发布
- rdb快照持久化
- aof日志持久化
- redis集群 主从配置
- sentinel监视
- key的设计
- Redis实践技巧
- 前言111
- 第1章 keys键操作
- 第2章 string类型
- 第3章 list类型
- 第4章 set类型
- 第5章 sort set排序类型
- 第6章 hash类型
- 第7章 redis备份
- 第8章 主从复制
- 第9章 设置密码
- 第10章 事务
- 第11章 php操作redis
- Redis常见7种使用场景(PHP实战)
- redis
- jQuery学习总结
- jquery总结2
- Git
- php微信接口开发
- php微信接口开发(卷一)
- 开发心得
- 申请微信测试号
- 打通服务器与微信之间的通信
- 接受微信发送的信息
- 回复微信发送的信息
- 微信回复单图文消息
- 微信回复多图文消息
- curl用法小测试
- 获取access_token
- 获取微信的media_id
- 微信回复图片消息
- 关注自动回复
- 微信生成自定义菜单
- 【实战】后台管理自定义菜单
- 1.页面数据提交并展示
- 2.组装一、二级菜单
- 3.完成简略自定义菜单
- 【实战】thinkphp框架开发微信接口
- 1.相关东西下载地址
- 2.配置thinkphp3.2.3
- 3.微信回复文本消息
- 4.微信获取个人基本信息
- php微信接口开发(卷二)
- 网页授权获取用户基本信息
- 1.输出回调地址
- 2.获取用户信息页面
- 3.数据写入数据库
- 用户分组接口的使用
- 1.对上节代码的优化处理
- 2.获取所有用户组
- 3.创建一个分组
- 4.查询指定用户的分组
- 群发消息的接口的使用
- 1.创建新控制器
- 2.预览群发消息接口
- 3.群发消息
- 生成带参数的二维码
- 长连接转短连接
- 微信js-SDK的引入
- 1.获取jsapi_ticket
- 2.判断当前客户端版本是否支持指定JS接口
- 图像接口的使用
- 扫一扫二维码接口
- php微信接口开发(卷三)
- 微信公众号
- 1.前提条件
- 2.微信公众平台需要做的设置
- 微信支付商户平台
- 1.操作证书
- 2.配置密钥
- 3.配置支付授权目录
- 公众号支付(Jsapi支付)
- 1.SDK与demo下载
- 2.测试DEMO
- 3.将支付接口更为真实公众号信息
- 微信商城
- 1.tp3+bootstrap使用实战
- 2.图片上传实战
- 3.商城后台实战
- 4.购买商城实战
- 5.下订单后使用微信支付
- 小程序基础
- 简介12
- 接入指南
- 开发者工具的使用
- 代码审核与发布
- 小程序申请微信认证
- 小程序申请微信支付
- 小程序绑定微信开放平台帐号
- app.json配置
- 配置demo
- pages
- window
- tabBar
- networkTimeout
- debug
- page.json
- API
- 发起网络请求
- 网络请求提交表单
- 引入
- WeUI
