以mysql_query()函数作为教程的基础前提,我们先来看一下mysql_query()的用法:
mysql_query()函数
PHP MySQL 函数库中,mysql_query() 函数用于向 MySQL 发送并执行 SQL 语句。
对于没有数据返回结果集的 SQL ,如 UPDATE、DELETE 等在执行成功时返回 TRUE,出错时返回 FALSE;对于 SELECT,SHOW,EXPLAIN 或 DESCRIBE 语句返回一个资源标识符,如果查询执行不正确则返回 FALSE。
语法:
1
|
resource mysql_query( string query [, resource connection ] )
|
参数说明:
提示
如果没有打开的连接,本函数会尝试无参数调用 mysql_connect() 函数来建立一个连接
对于返回数据集的查询,就算返回结果为0(即没有符合查询条件的记录),返回的仍然是资源标示符而不是 FALSE
例子1:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
<php
$conn = @mysql_connect( "localhost" , "root" , "root123" );
if (! $conn ){
die ( "连接数据库失败:" . mysql_error());
}
mysql_select_db( "test" , $conn );
$result = mysql_query( "SELECT * WHERE 1=1" )
or die ( "无效查询: " . mysql_error());
?>
该例子查询语句在 SQL 语法上有错误,因此 mysql_query() 执行失败并返回 FALSE 。
例子2:
<php
$conn = @mysql_connect( "localhost" , "root" , "root123" );
if (! $conn ){
die ( "连接数据库失败:" . mysql_error());
}
mysql_select_db( "test" , $conn );
mysql_query( "set names 'gbk'" ); //为避免中文乱码做入库编码转换
$password = md5( "123456" ); //原始密码 12345 经过加密后得到加密后密码
$regdate = time(); //得到时间戳
$sql = "INSERT INTO user(username, password, email, regdate)VALUES( '小王' , '$password' ,
'12345@163.com' , $regdate )";
if (!mysql_query( $sql , $conn )){
echo "添加数据失败:" .mysql_error();
} else {
echo "添加数据成功!" ;
}
?>
|
该例子向 user 表写入数据,成功返回 TRUE ,否则返回 FALSE(用 ! 符号判断)。
Create Database 创建数据库
创建数据库
CREATE DATABASE 语法用于创建一个数据库。
语法:
1
|
CREATE DATABASE db_name
|
PHP MySQL 函数库中,mysql_query() 函数用于向 MySQL 发送并执行 SQL 语句。
创建一个名为 testdb 的数据库:
1
2
3
4
5
6
7
8
9
10
11
|
<?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。
语法:
1
|
bool mysql_select_db( string db_name [, resource connection ] )
|
参数说明:
具体使用见下面创建数据表例子。
创建数据表
创建数据表 SQL 语法如下:
1
2
3
4
5
6
7
|
CREATE TABLE table_name
(
column1 data_type,
column2 data_type,
column3 data_type,
.......
)
|
上述语法中,column为字段名,后面为数据类型。
创建一个名为 user 的表:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
<?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个字段,并指定了对应的数据对象类型。
建表原则
一般来说,创建数据表有如下注意事项:
原始记录数据与表的对应关系
表名和字段名应遵循命名语法且应该明确含义
指定字段的数据类型
指定字段的其他如是否非空、是否有默认值等属性
定义表的属性如主外键、约束、索引等
与其他表的关系
限于篇幅且为控制教程难易度,在此不展开过多讨论。
提示
这个建表样例只是为了演示基本的建表语法,并不完善。实际生产当中,我们还需要给表和字段指定更多的属性。