创建数据库
CREATE DATABASE 语法用于创建一个数据库。
语法:
CREATE DATABASE db_name
PHP MySQL 函数库中,mysql_query() 函数用于向 MySQL 发送并执行 SQL 语句。关于 mysql_query() 函数更详细信息请参看《MySQL mysql_query》。
创建一个名为 testdb 的数据库:
<?php $conn = @mysql_connect("localhost","root","root1234"); if (!$conn){ die("连接数据库失败:" . mysql_error()); } if (@mysql_query("CREATE DATABASE testdb",$conn)){ echo "创建数据库成功!"; } else { echo "创建数据库失败:" . mysql_error(); } ?>
提示
- 创建数据库需要有对应的用户权限,如root用户
- 在实际的虚拟主机空间中,虚拟主机商通常已经创建好了对应的数据库,故上述例子不一定运行成功
选择数据库
要对数据库或表执行操作时,需要选择一个数据库。mysql_select_db() 用于选择一个数据库,如果成功,则该函数返回 true,如果失败则返回 false。
语法:
bool mysql_select_db( string db_name [, resource connection] )
参数 | 说明 |
---|---|
db_name | 要选择的数据库名 |
connection | 可选,连接数据库标识资源,如果不指定则使用上一连接 |
具体使用见下面创建数据表例子。
创建数据表
创建数据表 SQL 语法如下:
CREATE TABLE table_name ( column1 data_type, column2 data_type, column3 data_type, ....... )
上述语法中,column为字段名,后面为数据类型。
创建一个名为 user 的表:
<?php $conn = @mysql_connect("localhost","root","root1234"); if (!$conn){ die("连接数据库失败:" . mysql_error()); } //选择数据库 mysql_select_db("test", $conn); //创建数据表 SQL $sql = "CREATE TABLE user ( uid mediumint(8), username varchar(20), password char(32), email varchar(40), regdate int(10) )"; if(!mysql_query($sql,$conn)){ echo "创建数据表失败:". mysql_error(); } else { echo "创建数据表成功!"; } ?>
在该例子中,分为 3 个执行步骤:
- 创建一个数据库链接
- 使用 mysql_select_db() 函数选择容纳该表的数据库
- 使用 mysql_query() 函数创建数据表
在该例子中创建的表有4个字段,并指定了对应的数据对象类型。
建表原则
一般来说,创建数据表有如下注意事项:
- 原始记录数据与表的对应关系
- 表名和字段名应遵循命名语法且应该明确含义
- 指定字段的数据类型
- 指定字段的其他如是否非空、是否有默认值等属性
- 定义表的属性如主外键、约束、索引等
- 与其他表的关系
限于篇幅且为控制教程难易度,在此不展开过多讨论。
提示
这个建表样例只是为了演示基本的建表语法,并不完善。实际生产当中,我们还需要给表和字段指定更多的属性。