Tag: MySQL

MySQL触发器学习笔记

没有评论

2010 年 10 月 11 日 at 下午 2:14分类:MySQL

触发器,顾名思义,就是当执行某个事件的时候触发另一个事件的执行!这个触发的时间分为BEFORE和AFTER两种,分别有before insert,before update,before delete和after insert,after update,after delete这六种情况

以下的文章主要向大家讲述的是MySQL触发器的实际使用详细说明与实际案例分析,同时本文也列举了一些在MySQL触发器的实际式操作中的代码,以下就是文章的详细内容介绍,望大家借鉴。原文地址:http://database.51cto.com/art/201005/200671.htm

FOR EACH ROW 子句通知触发器每隔一行执行一次动作,而不是对整个表,在触发器中我们经常会用到NEWOLD这两个关键字,在这里我还是先解释下这两个字的意思!其中NEW是指刚刚插入到数据库的数据表中的一个域,也可以理解为对象(object)的意思。比如在一个insert触发器中我用到了NEW那他的意思就是说,要使用刚刚插入到数据表的某个值,要使用具体的某一个值的话需要这样子写:NEW.字段名(NEW.username)这样子就获取到了刚刚插入到数据表中的一个字段的值!!OLD,OLD是在delete触发器中有用的,意思是说我要删除一条数据,但是在触发器中要用到之前的那个数据,那么我就可以通过OLD来获取了!比如我删除了一条数据,里面包含一个email,现在我在触发器的内部sql中要用就可以这样子写:OLD.email!

对于INSERT语句, 只有NEW是合法的;对于DELETE语句,只有OLD才合法;而UPDATE语句可以在
和NEW以及OLD同时使用

触发器案例
1.mysql> select * from a; +——+——+——+ | id | name | age | +——+——+——+ | 1 | A1 | 10 | | 2 | A2 | 20 | +——+——+——+ mysql> select * from b; +——+——+——+ | rid | id | age | +——+——+——+ | 5 | 2 | 20 | +——+——+——+  希望在表a的age字段更新的时候能够触发表b相应的age字段也更新:
如:

1.update a set ageage=age+1 where id=2; 
相关的表变为:
1.mysql> select * from a; +——+——+——+ | id | name | age | +——+——+——+ | 1 | A1 | 10 | | 2 | A2 | 21 | +——+——+——+ mysql> select * from b; +——+——+——+ | rid | id | age | +——+——+——+ | 5 | 2 | 21 | +——+——+——+ 正确的写法

触发器代码
1.CREATE TRIGGER bbs1 AFTER UPDATE ON a FOR EACH ROW update b set age=NEW.age where id=NEW.id;  MySQL触发器
触发器的概念:“在数据库中为响应一个特殊表格中的某些事件而自动执行的程序代码。”(Wikipedia)说得简单一些,它是在一个特殊的数据库事件,如INSERT或DELETE发生时,自动激活的一段代码。触发器可方便地用于日志记录、对单个表格到其他链接式表格进行自动的“层叠式”更改、或保证对表格关系进行自动更新。

当一个新整数值增加到数据库域中时,自动更新运行的总数的代码段是一个触发器。自动记录对一个特殊数据库表格所作更改的SQL命令块也是一个触发器实例。

触发器是MySQL 5.x的新功能,随着5.x代码树新版本的出现,这一功能也逐渐得到改善。在本文中,我将简单介绍如何定义并使用触发器,查看触发器状态,并如何在使用完毕后删除触发器。我还将为你展示一个触发器在现实世界中的应用实例,并检验它对数据库记录的改变。
例子
通过简单(虽然是人为的)实例来说明是了解MySQL触发器应用的最佳办法。首先我们建立两个单域的表格。一个表格中为姓名列表(表格名:data),另一个表格中是所插入字符的字符数(表格名:chars)。我希望在data表格中定义一个触发器,每次在其中插入一个新姓名时,chars表格中运行的总数就会根据新插入记录的字符数目进行自动更新。
1.mysql> CREATE TABLE data (name VARCHAR(255)); Query OK, 0 rows affected (0.09 sec) mysql> CREATE TABLE chars (count INT(10)); Query OK, 0 rows affected (0.07 sec) mysql> INSERT INTO chars (count) VALUES (0); Query OK, 1 row affected (0.00 sec) mysql> CREATE TRIGGER t1 AFTER INSERT ON data FOR EACH ROW UPDATE chars SET countcount = count + CHAR_LENGTH(NEW.name); Query OK, 0 rows affected (0.01 sec)  
理解上面代码的关键在于CREATE TRIGGER命令,它被用来定义一个新触发器。这个命令建立一个新触发器,假定的名称为t1,每次有一个新记录插入到data表格中时,t1就被激活。
在这个触发器中有两个重要的子句:
AFTER INSERT子句表明触发器在新记录插入data表格后激活。
UPDATE chars SET count = count + CHAR_LENGTH(NEW.name)子句表示触发器激活后执行的SQL命令。在本例中,该命令表明用新插入的data.name域的字符数来更新 chars.count栏。这一信息可通过内置的MySQL函数CHAR_LENGTH()获得。
放在源表格域名前面的NEW关键字也值得注意。这个关键字表明触发器应考虑域的new值(也就是说,刚被插入到域中的值)。MySQL还支持相应的OLD前缀,可用它来指域以前的值。
你可以通过调用SHOW TRIGGER命令来检查触发器是否被激活。
1.mysql> SHOW TRIGGERS; *************************** 1. row *************************** ?Trigger: t1 ?Event: INSERT ?Table: data Statement: UPDATE chars SET countcount = count + CHAR_LENGTH(NEW.name) Timing: AFTER ?Created: NULL ql_mode: 1 row in set (0.01 sec) 
激活触发器后,开始对它进行测试。试着在data表格中插入几个记录:
1.mysql> INSERT INTO data (name) VALUES (‘Sue’), (‘Jane’); Query OK, 2 rows affected (0.00 sec) Records: 2?Duplicates: 0?Warnings: 0
然后检查chars表格看MySQL触发器是否完成它该完成的任务:

1.mysql> SELECT * FROM chars; +——-+ | count | +——-+ | 7| +——-+ 1 row in set (0.00 sec)
如你所见,data表格中的INSERT命令激活触发器,它计算插入记录的字符数,并将结果存储在chars表格中。如果你往data表格中增加另外的记录,chars.count值也会相应增加。

触发器应用完毕后,可有DROP TRIGGER命令轻松删除它。
1.mysql> DROP TRIGGER t1; Query OK, 0 rows affected (0.00 sec)
注意:理想情况下,你还需要一个倒转触发器,每当一个记录从源表格中删除时,它从字符总数中减去记录的字符数。这很容易做到,你可以把它当作练习来完成。提示:应用BEFORE DELETE ON子句是其中一种方法。

自写(已测试)

1.mysql> create trigger t2 before delete on data for each row update chars set countcount=count-char_length(old.name); Query OK, 0 rows affected (0.03 sec)
现在,我想建立一个审计记录来追踪对这个表格所做的改变。这个记录将反映表格的每项改变,并向用户说明由谁做出改变以及改变的时间。我需要建立一个新表格来存储这一信息(表格名:audit),如下所示。(列表C)

列表C
1.mysql> CREATE TABLE audit (id INT(7), balance FLOAT, user VARCHAR(50) NOT NULL, time TIMESTAMP NOT NULL); Query OK, 0 rows affected (0.09 sec) mysql> create table accounts(id int(7),label VARCHAR(45),balance float);
接下来,我将在accounts表格中定义一个MySQL触发器。(列表D)

列表D
1.mysql> CREATE TRIGGER t3 AFTER UPDATE ON accounts FOR EACH ROW INSERT INTO audit (id, balance, user, time) VALUES (OLD.id, NEW.balance, CURRENT_USER(), NOW()); Query OK, 0 rows affected (0.04 sec)
如果你已经走到这一步,就很容易理解。accounts表格每经历一次UPDATE,触发器插入(INSERT)对应记录的id、新的余额、当前时间和登录audit表格的用户的名称。

实现中的例子:用触发器审计记录

既然你了解了触发器的基本原理,让我们来看一个稍稍复杂的例子。我们常用触发器来建立一个自动“审计记录”,以记录各种用户对数据库的更改。为了解审计记录的实际应用,请看下面的表格(表格名:accounts),它列出了一个用户的三个银行账户余额。(表A)
表A
1.mysql> SELECT * FROM accounts; +—-+————+———+ | id | label| balance | +—-+————+———+ |1 | Savings #1 |500 | |2 | Current #1 |2000 | |3 | Current #2 |3500 | +—-+————+———+ 3 rows in set (0.00 sec)
然后,检查触发器是否被激活:

1.mysql> SHOW TRIGGERS ; *************************** 1. row *************************** ?Trigger: t1 ?Event: UPDATE ?Table: accounts Statement: INSERT INTO audit (id, balance, user, time) VALUES (OLD.id, NEW.balance, CURRENT_USER(), NOW()) Timing: AFTER ?Created: NULL Sql_mode: 1 row in set (0.01 sec)
再来看最后的结果(列表E):

列表E
1.mysql> UPDATE accounts SET balance = 500 WHERE id = 1; Query OK, 1 row affected (0.00 sec) Rows matched: 1?Changed: 1?Warnings: 0 mysql> UPDATE accounts SET balance = 900 WHERE id = 3; Query OK, 1 row affected (0.01 sec) Rows matched: 1?Changed: 1?Warnings: 0 mysql> UPDATE accounts SET balance = 1900 WHERE id = 1; Query OK, 1 row affected (0.00 sec) Rows matched: 1?Changed: 1?Warnings: 0 
注意,对accounts表格所作的改变已被记录到audit表格中,将来如果出现问题,我们可以方便地从中进行恢复。

1.mysql> SELECT * FROM audit; +——+———+—————-+———————+ | id| balance | user| time| +——+———+—————-+———————+ |1 |500 | root@localhost | 2006-04-22 12:52:15 | |3 |900 | root@localhost | 2006-04-22 12:53:15 | |1 |1900 | root@localhost | 2006-04-22 12:53:23 | +——+———+—————-+———————+ 3 rows in set (0.00 sec) 
如上面的例子所示,MySQL触发器是一个强大的新功能,它大大增强了RDBMS的自动化程度。自己去试验,练习吧!

MySQL存储过程学习小笔记

没有评论

2010 年 10 月 11 日 at 上午 9:27分类:MySQL

由于工作的需要!最近一段时间又开始来温习一遍MySQL的存储过程,闲话不多说,直接进入正题!

一个存储过程包括名字,参数列表,以及可以包括很多SQL语句的SQL语句集。
在这里对局部变量,异常处理,循环控制和IF条件句有新的语法定义。
下面是一个包括存储过程的实例声明:
CREATE PROCEDURE procedure1                      /* name 存储过程名*/  
(IN parameter1 INTEGER)                              /* parameters 参数*/  
BEGIN                                                                  /* start of block 语句块头*/  
   DECLARE variable1 CHAR(10);                      /* variables变量声明  */      
    IF parameter1 = 17 THEN                              /* start of IF IF条件开始*/  
        SET variable1 = ‘birds’;                                /* assignment 赋值*/  
   ELSE  
        SET variable1 = ‘beasts’;                              /* assignment 赋值*/  
   END IF;                                                                  /* end of IF IF结束*/  
    INSERT INTO table1 VALUES (variable1);/* statement SQL语句*/  
END                                                                      /* end of block 语句块结束*/
  

我们要想查看当前数据库的版本,键下如下代码:

mysql> SELECT VERSION();  

现在我们需要一个分隔符,实现这个步骤的SQL语句如下
DELIMITER // 

我们创建存储过程用关键字CREATE PROCEDURE   如:

create procedure p1()

select * from count ;//

这样子我们就创建好了一个最简单的存储过程

条用存储过程用 call 关键字  例如我们要调用刚刚创建的存储过程:call p1();//就可以了!!!

创建一个存储过程获得随机数和时间

CREATE PROCEDURE p2 ()  
SELECT CURRENT_DATE, RAND() FROM count;//
  

结果如下:

+————–+—————–+  
| CURRENT_DATE | RAND() |  
+————–+—————–+  
| 2004-11-09      | 0.7822275075896 |  
+————–+—————–+  
1 row in set (0.26 sec)  
Query OK, 0 rows affected (0.26 sec) 

——————————————————————->

传入参数的例子:mysql> CREATE PROCEDURE p5(p INT) SET @x = p //  
Query OK, 0 rows affected (0.00 sec)  
mysql> CALL p5(12345)//  
Query OK, 0 rows affected (0.00 sec)  
mysql> SELECT @x//  
+——-+  
| @x        |  
+——-+  
| 12345 |  
+——-+  
1 row in set (0.00 sec)

——————————————————————->

传出参数的例子:mysql> CREATE PROCEDURE p6 (OUT p INT)  
        -> SET p = -5 //  
mysql> CALL p6(@y)//  
mysql> SELECT @y//  
+——+  
| @y      |  
+——+  
| -5      |  
+——+  

——————————————————————->

复合语句的使用:CREATE PROCEDURE p7 ()  
BEGIN  
    SET @a = 5;  
    SET @b = 5;  
    INSERT INTO t VALUES (@a);  
    SELECT s1 * @a FROM t WHERE s1 >= @b;  
END; //         

——————————————————————->

变量的使用:CREATE PROCEDURE p8 ()  
BEGIN  
   DECLARE a INT;  
   DECLARE b INT;  
    SET a = 5;  
    SET b = 5;  
    INSERT INTO t VALUES (a);  
    SELECT s1 * a FROM t WHERE s1 >= b;  
END; //     

——————————————————————->

有默认参数值的语句:CREATE PROCEDURE p10 ()  
BEGIN  
   DECLARE a, b INT DEFAULT 5;  
    INSERT INTO t VALUES (a);  
    SELECT s1 * a FROM t WHERE s1 >= b;  
END; //       

——————————————————————->    

作用域的问题:CREATE PROCEDURE p11 ()  
BEGIN  
   DECLARE x1 CHAR(5) DEFAULT ‘outer’;  
   BEGIN  
       DECLARE x1 CHAR(5) DEFAULT ‘inner’;  
        SELECT x1;  
       END;  
    SELECT x1;  
   END; //   输出:mysql> CALL p11()//  
+——-+  
| x1        |  
+——-+  
| inner |  
+——-+  
+——-+  
| x1        |  
+——-+  
| outer |  
+——-+  

——————————————————————->

包含条件的多条语句:CREATE PROCEDURE p12 (IN parameter1 INT)  
BEGIN  
   DECLARE variable1 INT;  
    SET variable1 = parameter1 + 1;  
    IF variable1 = 0 THEN  
        INSERT INTO t VALUES (17);  
   END IF;  
    IF parameter1 = 0 THEN  
       UPDATE t SET s1 = s1 + 1;  
   ELSE  
       UPDATE t SET s1 = s1 + 2;  
   END IF;  
END; // 

——————————————————————->
case指令:CREATE PROCEDURE p13 (IN parameter1 INT)  
BEGIN  
   DECLARE variable1 INT;  
    SET variable1 = parameter1 + 1;  
   CASE variable1  
       WHEN 0 THEN INSERT INTO t VALUES (17);  
       WHEN 1 THEN INSERT INTO t VALUES (18);  
       ELSE INSERT INTO t VALUES (19);  
   END CASE;  
END; //  

——————————————————————->

WHILE … END WHILE循环语句:CREATE PROCEDURE p14 ()  
BEGIN  
   DECLARE v INT;  
    SET v = 0;  
   WHILE v < 5 DO  
        INSERT INTO t VALUES (v);  
        SET v = v + 1;  
   END WHILE;  
END; //  

——————————————————————->

REPEAT … END REPEAT指令:CREATE PROCEDURE p15 ()  
BEGIN  
   DECLARE v INT;  
    SET v = 0;  
   REPEAT  
        INSERT INTO t VALUES (v);  
        SET v = v + 1;  
       UNTIL v >= 5  
   END REPEAT;  
END; //

——————————————————————->

LOOP … END LOOP   指令: CREATE PROCEDURE p16 ()  
BEGIN  
   DECLARE v INT;  
    SET v = 0;  
    loop_label: LOOP  
        INSERT INTO t VALUES (v);  
        SET v = v + 1;  
        IF v >= 5 THEN  
            LEAVE loop_label;  
       END IF;  
   END LOOP;  
END; //  

MySQL常用函数

没有评论

2010 年 09 月 18 日 at 下午 9:12分类:MySQL

1、mysql_connect()-建立数据库连接
格式:
resource mysql_connect([string hostname [:port] [:/path/to/socket] [, string username] [, string password]])
例:
$conn = @mysql_connect(“localhost”, “username”, “password”) or die(“不能连接到Mysql Server”);
说明:使用该连接必须显示的关闭连接

2、mysql_pconnect()-建立数据库连接
格式:
resource mysql_pconnect([string hostname [:port] [:/path/to/socket] [, string username] [, string password]])
例:
$conn = @mysql_pconnect(“localhost”, “username”, “password”) or dir(“不能连接到Mysql Server”);
说明:使用该连接函数不需要显示的关闭连接,它相当于使用了连接池

3、mysql_close()-关闭数据库连接
例:
$conn = @mysql_connect(“localhost”, “username”, “password”) or die(“不能连接到Mysql Server”);
@mysql_select_db(“MyDatabase”) or die(“不能选择这个数据库,或数据库不存在”);
echo “你已经连接到MyDatabase数据库”;
mysql_close();

4、mysql_select_db()-选择数据库
格式:
boolean mysql_select_db(string db_name [, resource link_id])
例:
$conn = @mysql_connect(“localhost”, “username”, “password”) or die(“不能连接到Mysql Server”);
@mysql_select_db(“MyDatabase”) or die(“不能选择这个数据库,或数据库不存在”);

5、mysql_query()-查询MySQL
格式:
resource mysql_query (string query, [resource link_id])
例:
$linkId = @mysql_connect(“localhost”, “username”, “password”) or die(“不能连接到Mysql Server”);
@mysql_select_db(“MyDatabase”) or die(“不能选择这个数据库,或者数据库不存在”);
$query = “select * from MyTable”;
$result = mysql_query($query);
mysql_close();
说明:若SQL查询执行成功,则返回资源标识符,失败时返回FALSE。若执行更新成功,则返回TRUE,否则返回FALSE

6、mysql_db_query()-查询MySQL
格式:
resource mysql_db_query(string database, string query [, resource link_id])
例:
$linkId = @mysql_connect(“localhost”, “username”, “password”) or die(“不能连接到MysqlServer”);
$query = “select * from MyTable”;
$result = mysql_db_query(“MyDatabase”, $query);
mysql_close();
说明:为了使代码清晰,不推荐使用这个函数调用

7、mysql_result()-获取和显示数据
格式:
mixed mysql_result (resource result_set, int row [, mixed field])
例:
$query = “select id, name from MyTable order by name”;
$result = mysql_query($query);
for($count=0;$count<=mysql_numrows($result);$count++)
{
$c_id = mysql_result($result, 0, “id”);
$c_name = mysql_result($result, 0, “name”);
echo $c_id,$c_name;
}
说明:最简单、也是效率最低的数据获取函数

8、mysql_fetch_row()-获取和显示数据
格式:
array mysql_fetch_row (resource result_set)
例:
$query = “select id, name from MyTable order by name”;
$result = mysql_query($query);
while (list($id, $name) = mysql_fetch_row($result)) {
echo(“Name: $name ($id) <br />”);
}
说明:函数从result_set中获取整个数据行,将值放在一个索引数组中。通常会结使list()函数使用

9、mysql_fetch_array()-获取和显示数据
格式:
array mysql_fetch_array (resource result_set [, int result_type])
例:
$query = “select id, name from MyTable order by name”;
$result = mysql_query($query);
while($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
$id = $row["id"];
$name = $row["name"];
echo “Name: $name ($id) <br />”;
}
又例:
$query = “select id, name from MyTable order by name”;
$result = mysql_query($query);
while($row = mysql_fetch_array($result, MYSQL_NUM)) {
$id = $row[0];
$name = $row[1];
echo “Name: $name ($id) <br />”;
}
说明:
result_type的值有:
MYSQL_ASSOC: 字段名表示键,字段内容为值
MYSQL_NUM: 数值索引数组,操作与mysql_fetch_ros()函数一样
MYSQL_BOTH: 即作为关联数组又作为数值索引数组返回。result_type的默认值。

10、mysql_fetch_assoc()-获取和显示数据
格式:
array mysql_fetch_assoc (resource result_set)
相当于调用 mysql_fetch_array(resource, MYSQL_ASSOC);

11、mysql_fetch_object()-获取和显示数据
格式:
object mysql_fetch_object(resource result_set)
例:
$query = “select id, name from MyTable order by name”;
while ($row = mysql_fetch_object($result)) {
$id = $row->id;
$name = $row->name;
echo “Name: $name ($id) <br />”;
}
说明:返回一个对象,在操作上与mysql_fetch_array()相同

12、mysql_num_rows()-所选择的记录的个数
格式:
int mysql_num_rows(resource result_set)
例:
query = “select id, name from MyTable where id > 65″;
$result = mysql_query($query);
echo “有”.mysql_num_rows($result).”条记录的ID大于65″;
说明:只在确定select查询所获取的记录数时才有用。

13、mysql_affected_rows()-受Insert,update,delete影响的记录的个数
格式:
int mysql_affected_rows([resource link_id])
例:
$query = “update MyTable set name=’CheneyFu’ where id>=5″;
$result = mysql_query($query);
echo “ID大于等于5的名称被更新了的记录数:”.mysql_affected_rows();
说明:该函数获取受INSERT,UPDATE或DELETE更新语句影响的行数

14、mysql_list_dbs()-获取数据库列表信息
格式:
resource mysql_list_dbs([resource link_id])
例:
mysql_connect(“localhost”, “username”, “password”);
$dbs = mysql_list_dbs();
echo “Databases: <br />”;
while (list($db) = mysql_fetch_rows($dbs)) {
echo “$db <br />”;
}
说明:显示所有数据库名称

15、mysql_db_name()-获取数据库名
格式:
string mysql_db_name(resource result_set, integer index)
说明:该函数获取在mysql_list_dbs()所返回result_set中位于指定index索引的数据库名

16、mysql_list_tables()-获取数据库表列表
格式:
resource mysql_list_tables(string database [, resource link_id])
例:
mysql_connect(“localhost”, “username”, “password”);
$tables = mysql_list_tables(“MyDatabase”);
while (list($table) = mysql_fetch_row($tables)) {
echo “$table <br />”;
}
说明:该函数获取database中所有表的表名

17、mysql_tablename()-获取某个数据库表名
格式:
string mysql_tablename(resource result_set, integer index)
例:
mysql_connect(“localhost”, “username”, “password”);
$tables = mysql_list_tables(“MyDatabase”);
$count = -1;
while (++$count < mysql_numrows($tables)) {
echo mysql_tablename($tables, $count).”<br />”;
}
说明:该函数获取mysql_list_tables()所返回result_set中位于指定index索引的表名

18、mysql_fetch_field()-获取字段信息
格式:
object mysql_fetch_field(resource result [, int field_offset])
例:
mysql_connect(“localhost”, “username”, “password”);
mysql_select_db(“MyDatabase”);
$query = “select * from MyTable”;
$result = mysql_query($query);
$counts = mysql_num_fields($result);
for($count = 0; $count < $counts; $count++) {
$field = mysql_fetch_field($result, $count);
echo “<p>$field->name $field->type ($field->max_length) </p>”;
}
说明:
返回的对象共有12个对象属性:
name: 字段名
table: 字段所在的表
max_length:字段的最大长度
not_null: 如果字段不能为null,则为1,否则0
primary_key: 如果字段为主键,则为1,否则0
unique_key: 如果字段是唯一键,则为1, 否则0
multiple_key: 如果字段为非唯一,则为1,否则0
numeric: 如果字段为数值则为1,否则0
blob: 如果字段为BLOB则为1,否则为0
type: 字段的数据类型
unsigned: 如果字段为无符号数则为1,否则为0
zerofill: 如果字段为“零填充”则为1, 否则为0

19、mysql_num_fields()-获取查询的字段个数
格式:
integer mysql_num_fields(resource result_set)
例:
$query = “select id,name from MyTable order by name”;
$result = mysql_query($query);
echo “这个查询的字段数是:”.mysql_num_fields($result).”<br />”;

20、mysql_list_fields()-获取指定表的所有字段的字段名
格式:
resource mysql_list_fields (string database_name, string table_name [, resource link_id])
例:
$fields =mysql_list_fields(“MyDatabase”, “MyTable”);
echo “数据库MyDatabase中表MyTable的字段数: “.mysql_num_fields($fields).”<br />”;

21、mysql_field_flags()-获取指定的字段选项
格式:
string mysql_field_flags (resource result_set, integer field_offset)
例:
$query = “select id, name from MyTable order by name”;
$result = mysql_query($query);
$row=mysql_fetch_wor($row);

22、mysql_field_len()-获取指定的字段的最大长度
格式:
integer mysql_field_len (resource result_set, integer field_offset)
例:
$query = “select name from MyTable”;
$result = mysql_query($query);
$row = mysql_fetch_row($result);
echo mysql_field_len($result, 0).”<br />”;
说明:
如果mysql_field_len($reseult, 0) = 16777215
那么numer_format(mysql_field_len($result))等于16,777,215

23、mysql_field_name()-获取字段名
格式:
string mysql_field_name (resource result_set, int field_offset)
例:
$query = “select id as PKID, name from MyTable order by name”;
$result = mysql_query($query);
$row = mysql_fetch_row($result);
echo mysql_field_name($result, 0); // Result: PKID

24、mysql_field_type()-获取字段类型
格式:
string mysql_field_type (resource result_set, int field_offset)
例:
$query = “select id, name from MyTable order by name”;
$result = mysql_query($query);
$row = mysql_fetch_row($result);
echo mysql_field_type($result, 0); // Result: int

25、mysql_field_table()-获取字段所在表名
格式:
string mysql_field_table (resource result_set, int field_offset)
例:
$query = “select id as PKID, name from MyTable order by name”;
$result = mysql_query($query);
$row = mysql_fetch_row($result);
echo mysql_field_table($result, 0); // Result: MyTable