MySQL中数据表操作详解(2)

作者:佚名 来源:cnfan.net 时间:2008-12-29 13:50:00 

用CREATE TABLE 语句创建数据表

用 CREATE TABLE 语句创建表。此语句的完整语法是相当复杂的,因为存在那么多的可选子句,但在实际中此语句的应用相当简单。如我们在第 1 章中使用的所有 CREATE TABLE 语句都不那么复杂。

有意思的是,大多数复杂东西都是一些子句,这些子句MySQL在分析后扔掉。参阅附录 1 可以看到这些复杂的东西。

1、CREATE TABLE 语句的基本语法

CREATE TABLE tbl_name(create_definition,...) [TYPE =table_type]

create_definition: col_name type [NOT NULL | NULL]

[DEFAULT default_value] [AUTO_INCREMENT][PRIMARY KEY]

在MySQL3.22或以后版本中,表名可以被指定为db_name.tbl_name,不管有没有当前的数据库都可以。

例如,创建一个访问者留言表:

shell> mysql –u root –p

mysql> create database mytest;

mysql> CREATE TABLE guestbook

-> (

-> visitor VARCHAR(40),

-> comments TEXT,

-> entrydate DATETIME

->);

如果一切正常,祝贺你,你已经建立了你的第一个表!

你所创建的表名为guestbook,你可以使用这个表来存储来字你站点访问者的信息。你是用REEATE TABLE语句创建的这个表,这个语句有两部分:第一部份指定表的名子;第二部份是括在括号中的各字段的名称和属性,相互之间用逗号隔开。

表guestbook有三个字段:visitor,comments 和entrydate。visitor字段存储访问者的名字,comments字段存储访问者对你站点的意见,entrydate字段存储访问者访问你站点的日期和时间。

注意每个字段名后面都跟有一个专门的表达式。例如,字段名comments后面跟有表达式TEXT。这个表达式指定了字段的数据类型。数据类型决定了一个字段可以存储什么样的数据。因为字段comments包含文本信息,其数据类型定义为文本型。

2、如何指定表的类型

你也可以在创建表时指定表的类型,如果不指定表的类型,在3.22及以前版本中缺省为ISAM表,在3.23版本中缺省为MyISAM表。你应该尽量使用MyISAM表。指定表的类型经常用于创建一个HEAP表:

mysql> CREATE TABLE fast(id int,articles TEXT) TYPE=HEAP;

3、隐含的列说明的改变

在某些情况下,MySQL隐含地改变在一个CREATE TABLE语句给出的一个列说明。(这也可能在ALTER TABLE。) 长度小于4的VARCHAR被改变为CHAR。如果在一个表中的任何列有可变长度,结果是整个行是变长的。因此, 如果一张表包含任何变长的列(VARCHAR、TEXT或BLOB),所有大于3个字符的CHAR列被改变为VARCHAR列。这在任何方面都不影响你如何使用列;在MySQL中,VARCHAR只是存储字符的一个不同方法。MySQL实施这种改变,是因为它节省空间并且使表操作更快捷。

TIMESTAMP的显示尺寸必须是偶数且在2 ~ 14的范围内。如果你指定0显示尺寸或比14大,尺寸被强制为14。从1~13范围内的奇数值尺寸被强制为下一个更大的偶数。

你不能在一个TIMESTAMP列里面存储一个文字NULL;将它设为NULL将设置为当前的日期和时间。因为TIMESTAMP列表现就是这样,NULL和NOT NULL属性不以一般的方式运用并且如果你指定他们,将被忽略。DESCRIBE tbl_name总是报告该TIMESTAMP列可能赋予了NULL值。

如果你想要知道MySQL是否使用了除你指定的以外的一种列类型,在创建或改变你的表之后,发出一个DESCRIBE tbl_name语句即可。

标签:
0
投稿

猜你喜欢

  • git验证线上的版本是否符合预期

    2023-03-04 16:24:09
  • asp网上购物车实例代码

    2007-10-03 13:43:00
  • dataframe 按条件替换某一列中的值方法

    2021-06-16 00:23:33
  • python memory_profiler库生成器和迭代器内存占用的时间分析

    2023-01-06 21:25:02
  • python创建学生成绩管理系统

    2023-08-09 04:19:38
  • 如何使用Python优雅的合并两个字典Dict

    2023-10-12 22:50:36
  • Asp 返回引用类型函数代码

    2011-03-10 10:44:00
  • python条件和循环的使用方法

    2021-12-16 22:27:59
  • asp DateDiff实现文字在特定时间后消失

    2011-03-11 11:11:00
  • python代码实现五子棋游戏

    2021-04-18 01:20:48
  • Python+OpenCV六种实时图像处理详细讲解

    2022-06-14 10:47:27
  • Python的地形三维可视化Matplotlib和gdal使用实例

    2021-05-26 13:35:30
  • 完美解决Python2操作中文名文件乱码的问题

    2022-12-12 11:29:46
  • Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法

    2024-01-15 11:47:34
  • python通过线程实现定时器timer的方法

    2023-04-28 17:49:28
  • php使用curl获取https请求的方法

    2023-11-17 11:46:49
  • yii框架中的Url生产问题小结

    2023-07-20 14:08:45
  • MySQL事件与触发器专题精炼

    2024-01-22 09:08:21
  • Python 利用邮件系统完成远程控制电脑的实现(关机、重启等)

    2023-12-23 19:32:54
  • python相似模块用例

    2023-02-05 12:04:09
  • asp之家 网络编程 m.aspxhome.com