`
tomcat_oracle
  • 浏览: 316518 次
社区版块
存档分类
最新评论

MySQL编程中的6个重要的实用技巧

阅读更多

每一行命令都是用分号(;)作为结束

对于MySQL,第一件你必须牢记的是它的每一行命令都是用分号(;)作为结束的,但当一行MySQL被插入在PHP代码中时,最好把后面的分号省略掉,例如:

mysql_query("INSERT INTO tablename(first_name,last_name)VALUES('$first_name',$last_name')");

这是因为PHP也是以分号作为一行的结束的,额外的分号有时会让PHP的语法分析器搞不明白,所以还是省略掉的好。在这种情况下,虽然省略了分号,但是PHP在执行MySQL命令时会自动的帮你加上的。

采用关联数组存取查询结果

看下面的例子:

$connection=mysql_connect("localhost","albert","shhh");

mysql_select_db("winestore",$connection);

$result=mysql_query("SELECT cust_id,surname,

firstname FROM customer",$connection);

while($row=mysql_fetch_array($result))

{

echo"ID:t{$row["cust_id"]}n";

echo"Surnamet{$row["surname"]}n";

echo"First name:t{$row["firstname"]}nn";

}

函数mysql_fetch_array()把查询结果的一行放入数组,可以同时用两种方式引用,例如cust_id可以同时用下面两种方式:$row[“cust_id”]或者$row[0]。显然,前者的可读性要比后者好多了。

在多表连查中,如果两个列名字一样,最好用别名分开:

SELECT winery.name AS wname,region.name AS rname,FROM winery,region WHERE winery.region_id=region.region_id;

列名的引用为:$row[“wname”]和$row[“rname”]

在指定表名和列名的情况下,只引用列名:

SELECT winery.region_id

FROM winery

列名的引用为:$row[“region_id”]

聚集函数的引用就是引用名:

SELECT count(*)

FROM customer;

列名的引用为:$row[“count(*)”]

TEXT、DATE、和SET数据类型

MySQL数据表的字段必须有定义一个数据类型。这有大约25种选择,大部分都是直接明了的,就不多费口舌了。但有几个有必要提一下。

TEXT不是一种数据类型,虽然可能有些书上是这么说的。它实际上应该是“LONG VARCHAR”或者“MEDIUMTEXT”。

DATE数据类型的格式是YYYY-MM-DD,比如:1999-12-08。你可以很容易的用date函数来得到这种格式的当前系统时间:date(“Y-m-d”)并且,在DATA数据类型之间可以作减法,得到相差的时间天数:

$age=($current_date-$birthdate);

集合SET是一个有用的数据类型,它和枚举ENUM有点相似,只不过是SET能够保存多个值而ENUM只能保存一个值而已。而且,SET类型最多只能够有64个预定的值,而ENUM类型却能够处理最多65,535个预定义的值。而如果需要有大于64个值的集合,该怎么办呢,这时就需要定义多个集合来一起解决这个问题了。

用mysql_unbuffered_query()开发快速的脚本

这个函数能用来替换mysql_query()函数,主要的区别就是mysql_unbuffered_query()执行完查询后马上返回,不需要等待或者对数据库加锁。但是返回的行数不能用mysql_num_rows()函数来检查,因为输出的结果集大小未知。

通配符

SQL的通配符有两种:“*”和“%”。分别用在不同的情况下。例如:如果你想看到数据库的所有内容,可以像这样来查询:

SELECT*FROM dbname WHERE USER_ID LIKE'%';

这里,两个通配符都被用上了。他们表示相同的意思??都是用来匹配任何的字符串,但是他们用在不同的上下文中。“*”用来匹配字段名,而“%”用来匹配字段值。另外一个不容易引起注意的地方是“%”通配符需要和LIKE关键字一起使用。还有一个通配符,就是下划线“_”,它代表的意思和上面不同,是用来匹配任何单个的字符的。

NOT NULL和空记录

如果用户在没有填任何东西的情况下按了submit按钮,会怎样呢?如果你确实需要一个值,那么可以用客户端脚本或者服务器端脚本来进行数据验证。但是,在数据库中却是允许一些字段被空出来什么也不填。对此类纪录,MySQL将要为之执行一些事情:插入值NULL,即缺省的操作。

如果你在字段定义中为之声明了NOT NULL(在建立或者修改这个字段的时候),MySQL将把这个字段空出来什么东西也不填。对于一个ENUM枚举类型的字段,如果你为之声明了NOT NULL,MySQL将把枚举集的第一个值插入到字段中。也就是说,MySQL把枚举集的第一个值作为这个枚举类型的缺省值。

一个值为NULL的纪录和一个空纪录是有一些区别的。%通配符可以匹配空纪录,但是却不能匹配NULL纪录。在某些时候,这种区别会造成一些意想不到的后果。就我的经验而言,任何字段都应该声明为NOT NULL。这样许多的SELECT查询语句就能够正常运转了。注意在搜索NULL时,必须用“IS”关键字,而LIKE是不会正常工作的。在最后要提到的是,如果你在加入或者修改一个新的字段之前,数据库中已经有了一些记录了,这时新加入的字段在原来的纪录中的值,可能是NULL,也可能为空。这也算是MySQL的一个Bug吧,所以在这种情况下,使用SELECT查询要特别的小心。

2
10
分享到:
评论

相关推荐

    MySQL编程技巧·编程和数据库管理篇

    本书全面深入地介绍了MySQL的功能,主要内容包括MySQL、PHP、Apache、Perl等组件的安装与功能简介,mysql等一些重要系统管理工具和用户操作界面的使用,MySQL数据库系统设计的基础知识与用不同语言设计MySQL数据库的...

    嵌入式mysql编程例子

    在这个"嵌入式MySQL编程例子"中,我们将探讨如何在你的项目中有效地使用MySQL。 一、嵌入式MySQL简介 嵌入式MySQL库,也称为libmysqld,是一个轻量级的数据库引擎,可直接链接到你的应用程序中,无需单独的服务器...

    PHP+MySQL编程实例:PHP+MySQL编程实例.rar

    而"实例09"、"实例11"、"实例01"、"实例02"等可能是PHP+MySQL编程的实践案例,每个实例可能涵盖不同的功能和技巧。 在PHP+MySQL编程中,我们需要了解以下几个关键知识点: 1. PHP基础:包括变量声明、数据类型、...

    MySQL编程中的6个实用技巧

    MySQL编程中的实用技巧涵盖了许多日常操作的关键点,这些技巧能够帮助开发者更高效地与数据库进行交互。以下将详细解析这些技巧: 1. **分号作为命令结束符**:在MySQL中,每个SQL命令都必须以分号结束。但在PHP中...

    Linux环境下QT4图形界面与MySQL编程_程序源代码

    这个"Linux环境下QT4图形界面与MySQL编程_程序源代码"的资源,很可能是为了演示或教学如何在Linux系统中结合Qt4和MySQL进行应用开发。通过学习这些源代码,开发者可以了解到以下关键知识点: 1. **Qt4库的使用**:...

    《MySQL高效编程》.(王志刚,江友华 ).[PDF]

    知识点六:MySQL高效编程技巧 MySQL高效编程技巧包括: * 使用prepared statement:prepared statement可以减少SQL语句的解析时间,提高数据库性能。 * 使用存储过程:存储过程可以简化复杂的查询语句,提高数据库...

    Linux下的MySQL数据库编程

    在Linux环境下进行MySQL数据库编程是一项基础且至关重要的技能,尤其对于系统管理员和开发人员来说。MySQL是一种流行的开源关系型数据库管理系统(RDBMS),它以其高效、可靠和易用性而受到广泛赞誉。本讲义将围绕...

    关于mysql的qt编程

    在IT领域,MySQL和Qt是两个非常重要的工具。MySQL是一种广泛应用的关系型数据库管理系统,而Qt则是一个跨平台的C++图形用户界面库。本项目结合两者,实现了在ARM开发板上进行数据处理和用户界面展示的功能。以下是...

    PHP+MySQL编程实例.rar

    《PHP+MySQL编程实例》是针对Web开发领域中常用的技术组合——PHP与MySQL进行深入讲解的实践性教程。本教程旨在帮助开发者理解如何利用这两种强大的工具来构建动态、交互式的Web应用程序。 PHP(Hypertext ...

    MySQL存储过程编程教程.pdf

    MySQL存储过程编程是数据库应用开发中的一个重要环节,它可以帮助开发者将一...对于希望掌握MySQL存储过程编程的开发者而言,这本书不仅提供了理论知识,更重要的是提供了如何将这些理论应用到实际开发中的实用技巧。

    MYSQL高效编程

    综上所述,高效使用MySQL需要深入理解其工作原理,并掌握SQL优化、事务管理、索引优化、存储过程编写、内存和硬件资源协调等多个方面的知识和技巧。通过不断学习和实践,可以编写出更加高效的MySQL程序。

    Linux下的mysql数据库编程

    7. **程序接口API**:除了直接在命令行中使用SQL,开发人员还可能通过编程语言如Python、Java、C++等的MySQL API进行数据库操作。熟悉这些API的使用方法,如Python的`pymysql`库或Java的`JDBC`驱动,可以实现更复杂...

    mysql c++封装类库 方便mysql编程

    MySQL是一种广泛使用的开源关系型数据库管理系统,而C++是一种强大且灵活的编程语言,常用于构建复杂的系统。在C++中直接操作MySQL数据库可能会涉及到大量的API调用和错误处理,这使得代码变得冗长且难以维护。为了...

    C++Mysql8.0数据库跨平台编程实战.zip

    总的来说,这个课程旨在通过实践教学,让你掌握C++与MySQL8.0的整合技巧,无论是在Windows还是Ubuntu环境下,都能自如地进行数据库编程,解决实际项目中的各种挑战。通过系统学习和反复实践,你将成为一个熟练的...

    PHP+MySQL编程实例

    《PHP+MySQL编程实例》是一本深入探讨如何利用PHP与MySQL进行高效开发的书籍,主要聚焦于数据库类的实现和应用。在这个实例中,我们将会深入理解PHP与MySQL结合的强大功能,以及如何通过数据库类来简化数据操作。 ...

    mysql高效编程

    通过本文对MySQL高效编程相关知识点的详细介绍,希望能够帮助读者更好地理解和掌握MySQL的使用技巧,从而在实际项目开发中发挥出更高的性能。无论是从SQL语句优化、数据库配置调整还是系统层面的整体规划,都需要...

    计算机软件-编程源码-MySQL 精华技巧(CHM).zip

    这份"计算机软件-编程源码-MySQL 精华技巧(CHM).zip"资源包含了一系列关于MySQL的精华技巧,可能是由专家或经验丰富的开发者总结而成,旨在帮助用户提升在MySQL中的编程和管理技能。 首先,MySQL的精华技巧可能涵盖...

Global site tag (gtag.js) - Google Analytics