分页: 27/29 第一页 上页 22 23 24 25 26 27 28 29 下页 最后页 [ 显示模式: 摘要 | 列表 ]
Oct 26

   关键字: Unicode, Character Set, 字符集, UTF-8, ANSI, ASCII, UTF-7

原文标题: The Absolute Minimum Every Software Developer Absolutely, Positively Must Know

About Unicode and Character Sets(No Excuses!)

原文链接: http://www.joelonsoftware.com/print...es/Unicode.html

作者: Joel Spolsky





ASCII 码

------------------------------------------------------------------------------------

7 位(00~7F)。 32 ~ 127 表示字符。32 是空格, 32 以下是控制字符(不可见)。

第8位没有被使用。全世界很多人同时对这个位的含义发展了不同的用处。比如 IBM PC 中的 OEM 字符集。

最后就 128 位以下的用处达成共识,制定了 ASCII 标准。

而 128 位以上的可能有不同的解释,这些不同的解释就叫做 code pages.

甚至有用于在同一台电脑上解释多种语言的 code page.



同时,在亚洲发生了更加疯狂的事情。亚洲语言的字符集通常数以千计, 8 位已经不足以表达,这通常用一种

很凌乱的,叫做 DBCS(双字节字符集,double byte character set) 的系统来解决。

这种系统中,有些字符占用 1 字节,有些 2 字节。这样一来,在字符串中向前解析很容易,而倒退却很麻烦。

程序员们被建议,不要使用 s++ 或 s-- 来前进和后退,而使用一些函数,比如 Windows 的 AnsiNext 和

AnsiPrev. 因为这些函数知道是怎么回事。



这些不同的假设(code page)在单个的机器上没有问题。而随着 Internet 的发展,字符串要从一个机器上移到

另一个机器上,这就产生了问题。于是, Unicode 出现了。



Unicode

---------------------------------------------------------------------------------------

Unicode 是一个勇敢的成就。它把在这个星球上的每一个合理的文字系统整合成了一个单一的字符集。

很多人还存在这样的误解: Unicode 仅仅是 16 位的这么简单,每个字符占 16 位,所以一共有 65536 个可能的字符。

然而,这是错误的。不过不要紧,因为这是大部分人都会犯的一个普遍的错误。



实际上,Unicode 理解字符的方式是截然不同的,而这是我们必须了解的。

到目前为止,我们都曾经认为:一个字符对应到一些在磁盘上或内存中储存的位(bits). 如: A -> 0100 0001

而在 Unicode 中, 一个字符实际上对应一种叫做 code point 的东西。

比如 A 这个字符,是抽象的(原文:platonic,柏拉图式的,理想的)一个概念。

无论是 Times New Roman 或者 Helvetica 或者其他的什么字体中,都代表同一个字符。但是它和小写的字母 a 不同。

但是在其他的语言,比如希伯莱语(Hebrew) 或者德语(German), 阿拉伯语(Arabian) 中,同一个字母的不同的字形代表的含义是否

相同,是有争议的。经过长时间的争论,这些也终于被确定了。



每一个字母表中的每一个抽象的字母,都被赋予了一个数字,比如 U+0::5. 这个叫做 code point.

U+ 表示: Unicode, 数字是 16 进制的。

你可以通过 charmap 命令来查看所有这些编码。(Windows 2000/XP 中). 或者访问 Unicode 的网站(http://www.unicode.org)

Unicode 中 code point 的数字的大小是没有限制的,而且也早就超过了 65535. 所以不是每个字符都能存储在两个字节中。

那么,一个字符串 \"Hello\", 在 Unicode 中会表示成 5 个 code points :

U+0048 U+0065 U+006C U+006C U+006F

只不过是一些数字。但我们现在还没有提到如何在磁盘或者 Email 中表示这些信息,这就是我们下面要提到的编码(Encoding) 干的事情。



Encodings (编码)

-------------------------------------------------------------------------

最初的 Unicode Encoding, 使用两个字节表示一个字符。那么 \"Hello\" 表示为:

00 48 00 65 00 6C 00 6C 00 6F

实际上,还有一种表示方式:

48 00 65 00 6C 00 6C 00 6F 00

到底高位字节在前还是低位字节在前面,是两种不同的模式。这要看特定的 CPU 在何种模式下工作的更快。 所以这两种都有。

这就有了两种不同的 Unicode 表示方式了,为了区分,人们又采用了一种奇异的方式:

在每一个 Unicode 字符串的前面,加上 FEFF (这称为 Unicode 字节顺序标志,Unicode Byte Order Mark).

如果你交换高位和低位次序,那么会加上一个 FFFE. 这样,读这个字符串的人才知道要对每两个相邻的字节进行交换。

但在最初的时候,并不是每一个 Unicode 字符串都有这个标志的。



这看起来很不错。可程序员们开始抱怨了,“看看那些零!”。因为有些是美国人,他们使用英语。而英语中很少需要使用 U+00FF 以上的

字符, 有些人无法忍受采用双倍的存储空间来存储每个字符。

基于这些原因,很多人决定忽视 Unicode, 而同时,事情变得更糟了。



然后人们制定了 UTF-8. UTF-8 是用于保存 Unicode code points 的另一套系统。

每一个 U+ 数字,在内存中占用 8 bit. 在 UTF-8 中,任何一个 0~127 的 code point 占用一个字节。

只有 128 以及更大的才占用 2, 3, 直到 6 个字节。

具体如下图所示:



16进制的最小的数 16进制的最大的数 内存中的字节序列

------------------------------------------------------------------------------

00000000 0000007F 0vvvvvvv

00000080 000007FF 110vvvvv 10vvvvvv

00000800 0000FFFF 1110vvvv 10vvvvvv 10vvvvvv

00010000 001FFFFF 11110vvv 10vvvvvv 10vvvvvv 10vvvvvv

00200000 03FFFFFF 111110vv 10vvvvvv 10vvvvvv 10vvvvvv 10vvvvvv

04000000 7FFFFFFF 1111110v 10vvvvvv 10vvvvvv 10vvvvvv 10vvvvvv 10vvvvvv



这看起来很不错,其中的英文字符和 ASCII 中一样。所以美国人根本没意识到有什么错误。只有世界上的其他国家需要使用高位的字节。

特别的,\"Hello\" 这个字符串,Unicode code point 为 U+0048 U+0065 U+006C U+006C U+006F, 会被存储为 48 65 6C 6C 6F。

和 ASCII, ANSI, 以及在这个星球上的任何一个 OEM 的字符集中表示的含义都一样。

现在,如果你需要表示重音的字符,或者希腊语,你需要使用多个字节来表示一个 code point. 但美国人不会介意这些。

(UTF-8 还有一个好处就是,老的字符串处理程序使用一个为 0 的字节来表示 null-terminator, 不会截断字符串)



到目前为止已经介绍了三种 Unicode 的表示方法:



传统的双字节表示方法, 称为 UCS-2(因为有 2 个字节) 或者 UTF-16(因为有 16 个位)

而且你还要搞清楚是高位在前的,还是高位在后的 UCS-2.



还有一种就是新的 UTF-8. 如果你的程序只使用英文的话,它仍然会工作正常。



实际上还有一堆的其他办法对 Unicode 进行编码:

有 UTF-7,这种编码方式大部分和 UTF-8 相同,但保证高位一定为 0.

所以如果你必须通过某种 Email 系统传送 Unicode,这些系统认为 7 位足够了,那使用 UTF-7 会正常。

还有 UCS-4, 储存每一个 code point 为 4 个字节。它的优点是每一个字符都保存为同样长的。但很明显,缺点是浪费太多存储空间了。



所以,现在你思考问题要把每一个字符想象成抽象的一个 unicode code point. 而它们同样可以使用任何旧的方式编码。

举例来说,你可以把 Unicode 字符串 Hello (U+0048 U+0065 U+006C U+006C U+006F) 编码(encode)为

ASCII, 或者古老的 OEM 希腊语编码,或者希柏莱 ANSI 编码,等等。而有些字符串不能显示!

也就是说,假如你要表示一个在某个编码中没有对应的 Unicode code point, 通常会显示为一个 ? 或者一个白色的小方框。



英文常用的一些编码有, Windows-1252(Windows 9x 标准 for 西欧语言)

以及 ISO-8859-1, aka Latin-1(对任何西欧语言也有效)

如果用这些编码来尝试存储俄文字符,你会得到一堆的 ?



UTF 7, 8, 16 以及 32 都有一个优点,能够正确的存储任何的 code point.



最简单,也是最重要的几个概念

====================================================================

一个字符串不指定它使用什么编码是没有意义的。

再也不要假定, “纯”文本(plain text) 是 ASCII.

没有 “纯文本” 这个东西。



如果你有一个字符串,在内存中,在文件中,或者在 Email 消息里,你必须知道它的编码是什么。否则你无法正确的解释或者显示给用户。

所有的诸如 “我的网页不能正常显示了”,或者 ”Email 消息不能正常显示了“ 之类的愚蠢问题, 都是因为, 没有告诉你到底是使用的那种编码,

UTF-8 还是 ASCII 还是 ISO 8859-1 或者 Windows 1252 ?? 那么自然无法正常的解释和显示,甚至不知道字符串该在哪里结束。



那么如何保留这样的编码标志,来表示字符串的编码? 有一些基本的办法。

比如对于 Email 来说,在表单的 header 中加上:



Content-Type:text/plain;charset=\"UTF-8\"



对于 Web 页面来说,原来的做法是, Web 服务器随着 web 页面本身一起,发送一个类似于 Content-Type 的 http header.

(不是在 HTML 里面,而是作为一个 response header 在 HTML 页之前发送)



这样做有一个问题。如果你的 Web 服务器同时有多个站点,站点由多个不同的人用不同的语言开发的程序混在一起。那么 Web 服务器将无从得知,

每一个文件是用什么编码方式写的。这样也就无法发送正确的 Content-Type header.

如果你能够在每一个 HTML 文件中记录 Content-Type 信息,那么就很方便了。可这念头似乎也很疯狂,因为你还没有知道用什么编码方式去

读取这个文件,又怎么能读出编码信息呢?

幸好,几乎每一种编码中,对 32~127 的字符都解释的相同。所以你可以在每一个 html 文件中这么写:











但是要注意, 这个 meta 标签必须放在 head 中靠前面的位置才能保证不会出问题。 因为 Web 服务器读到这里的时候,就会停止解析,

然后用读到的这个编码方式重新解析页面。



那么,作为 Web 浏览器来说,如果没有在 meta 标签中或者 http headers 中发现 Content-Type, 会怎么样呢?

IE 是这么做的:

先尝试去猜,根据特定的字节出现在各种语言的典型的编码中的频率。

如果编码设定不正常,用户可以通过 View&line;Encoding 菜单来尝试不同的编码方式。(当然,不是每个人都知道该这样做)



在 VB, COM, Windows NT/2000/XP 中,默认的字符串类型是 UCS-2(2字节)的。

在 C++ 代码中, 我们可以定义字符串为 wchar_t(wide char),同时用 wcs 系列的函数代替 str 系列的函数。

如 wcscat, wcslen, 而不是 strcat, strlen.

在 C 代码中,要创建 UCS-2 字符串的话,只要在前面加一个 "L", 如 L"Hello"



对于 Web 页面,最好统一为使用 UTF-8 编码。 这个编码已经被各种 web 浏览器支持了很多年了。
Oct 26
    这里介绍了一些 PHP IDE 工具,非常见的 Editplus 之类的,都是专门为 PHP 开发的,有兴趣都可以试
试看,找出自己用得顺手的就可以了,我推荐3个Zend Studio,DzSoft PHP Editor,Editplus,也是我现在用
的,希望对大家有帮助。

Zend Studio
  开发商: http://www.zend.com/store/products/zend-studio.php
  目前公认的最强大的PHP开发工具,这种集成软件包包括了用于编辑,调试,配置PHP程序所需要的客户及
服务器组件,软件包具有工业标准的PHP开发环境,代码完成引擎,功能齐全的调试器等 
    注册Name: ttdown.com
      注册S/N: 9E023F9D000060000069696969


NuSphere PHPEd
  http://www.nusphere.com/
  PhpED 通过无与伦比的PHP调试和压缩能力,以及一个新的NuSOAP web服务向导成为了PHP领域的领军
产品。更加强大的Project Manager使得发布站点和应用程序比以前更加容易。现在可以在线程级别对正在运行
或者开发中的程序进行测试和调校。支持 CVS 版本控制,而且,对PostgreSQL和MySQL数据库的本地支持为
PHP使用开源数据库提供了一个广泛的环境。但对中文支持不太好,汉字都当作单字节处理了。PHPED还有Linu
x版本。

PHP Coder
  http://www.phpide.de/
  PHPCoder用于快速开发和调试PHP应用程序,它很容易扩展和定制,完全能够符合开发者的个性要求.1:结合
了PHP编译器和参考文档,可以对编辑中的PHP脚本进行即时预览2:支持高亮显示HTML和PHP代码;3:自动完成
功能,可以自动完成用户自定义代码片断;4:标准函数提示;5:有专门的工程项目管理器;6:对象浏览器搜寻编辑中文
件的包含信息,自定义函数,并以树形显示.7:支持查找对称的语句标记符;8:支持高级搜索和替换;9:自带FTP功
能;10:支持运行和断点调试11:……总之,PHPCoder是一个非常实用的,功能强大的编程环境,而且它是免费的!

Ankord PHP Expert Editor
  http://www.ankord.com/phpxedit.html
  PHP Expert Editor是一个容易使用的 PHP 开发工具,它的功能照顾到初级者及专业开发人员。 PHP Ex
pert Editor 内建 http server 用作测试及除错(你也可以使用其他 http server), PHP 语法检查, FTP 功能, 
程式码样板等功能。 

DzSoft PHP Editor
  http://www.dzsoft.com/dzphp.htm
  专为 PHP 所设计的网页程序编辑软件 - DzSoft PHP Editor,具有 PHP 编辑、侦错、浏览、原始码检
视、档案浏览、可自订的原始码样本..等功能,无须架设网站主机就可以测试 PHP 指令码,是一套功能强大的 P
HP 编程软件。
  DzSoft PHP Editor和Ankord PHP Expert Editor非常相识,几乎找不到他们的主要区别,关于这两个软
件之间的具体内幕我也不太清楚!

Dev-PHP IDE
  http://devphp.sourceforge.net/
  非常好用的php编辑器,支持php-gtk,內建許多快速html表单,非常的好用,本身含繁体语言包,另附暗
地论坛的中文语言包

Master PHP
  http://www.gsoftwares.com/
  一款支持PHP, PHP3, PHTML, CSS, JS, HTML, HTM and SQL的编辑器,它允许用户编辑多种一次编辑
多种文件,允许插入,运行和最优化程序的脚本,用户可以通过工具栏定制按钮和窗体,可以导出html和rtf格
式,支持18种语言

Komodo
  http://www.activestate.com/Products/Komodo/
  Komodo支持在Windows与Linux上,Perl、Python及JavaScript等的程序语言开发,以及多种程序语言
语法不同颜色标注。这款功能强大的IDE竟然不支持中文,连中文文件名的文件都打不开!

Maguma Studio
  http://www.maguma.com/
  Maguma Studio包含了编辑和调试 PHP 程序所有必须的工具。无论您是经验丰富的开发者、或是初学者
它都适合您。带有十分完整的断点、分步等调试功能。支持以树形方式显示文件中的函数和类成员。

PhpLens
  http://phplens.com
  PhpLens是一款专为PHP开发人员准备的快速数据库开发程序。通过使用PhpLens,可以快速的设计、发
布和维护数据库驱动的网络产品。它允许你以HTML表格的形式对数据库进行浏览、编辑、创建、删除和查找。不
用写任何代码,它就允许你完成上述操作。
    
    更多的PHP IDE可以参考这篇文章:
http://www.linuxdocs.org/HOWTOs/PHP-HOWTO-9.html


Oct 10

平时对于数字与数字的判断,我是用==为判断,但是对于字符串与0的时候却不能这要,
有一些时候提交的数据有可能是字符串和数字两种,我今日遇到的问题就是这样了
关于根据论坛的等级来判断来给一个有效数值
function getdb($groupid)
{
   if($groupid==0){
   $var=100;
   }
   elseif($groupid==1){
   $var=200;
   }
   elseif($groupid=='admin'){
   $var=300;
   }
   else $var=0;
   return $var;
}
如果传过来的$groupid是数字的话当然没问题
但如果当我传过来的为admin时,返回的却是100
即把$groupid等于0为看了。
后来在手册中查到

表格 O-2. 用 == 进行松散比较



TRUEFALSE10-1"1""0""-1"NULLarray()"php"
TRUETRUEFALSETRUEFALSETRUETRUEFALSETRUEFALSEFALSETRUE
FALSEFALSETRUEFALSETRUEFALSEFALSETRUEFALSETRUETRUEFALSE
1TRUEFALSETRUEFALSEFALSETRUEFALSEFALSEFALSEFALSEFALSE
0FALSETRUEFALSETRUEFALSEFALSETRUEFALSETRUEFALSETRUE
-1TRUEFALSEFALSEFALSETRUEFALSEFALSETRUEFALSEFALSEFALSE
"1"TRUEFALSETRUEFALSEFALSETRUEFALSEFALSEFALSEFALSEFALSE
"0"FALSETRUEFALSETRUEFALSEFALSETRUEFALSEFALSEFALSEFALSE
"-1"TRUEFALSEFALSEFALSETRUEFALSEFALSETRUEFALSEFALSEFALSE
NULLFALSETRUEFALSETRUEFALSEFALSEFALSEFALSETRUETRUEFALSE
array()FALSETRUEFALSEFALSEFALSEFALSEFALSEFALSEFALSETRUEFALSE
"php"TRUEFALSEFALSETRUEFALSEFALSEFALSEFALSEFALSEFALSETRUE

其中字符串与0比较时会返回真值

Oct 8
Mysql4.1.10初级解读

※※※※※※※※※※※※※※Mysql 初级解读 (所用版本:4.1.10)※※※※※※※※※※※※※※

安装注意事项
 在安装的过程中,请记好您的密码,这是将来登录mysql的钥匙。


 =======================无==敌==分==割==线=======================

一、Mysql数据库服务器登录

 登录mysql需要切换到dos下的mysql的bin目录,进行如下操作:

 语法格式:mysql -h host_name -u user_name -p password   (本机的话-h 和host_name可省)

 ----------------------我------------割--------------------------

  My Experience:

  C:\program files\mysql\mysql server 4.1\bin>mysql -u root -p
  Enter password:******
  先输入用户名和密码登陆要求(加上-p),回车后等出现"Enter password:",再输入密码回车,这样就可以
成功登陆mysql,否则将会登陆失败。

 ----------------------我------------割--------------------------

  登陆成功后会显示如下信息:

   Welcome to the MySQL monitor.  Commands end with ; or \g.
   Your MySQL connection id is 1 to server version: 4.1.10-nt

   Type 'help;' or '\h' for help. Type '\c' to clear the buffer.

   mysql>


   标识"mysql>",当你看到这个出现在窗口的最左边的顶格时,这就是告诉你,你可以输入命令进行操作了。

            mysql> \s  查看版本信息
mysql> \q or mysql> quit  退出mysql数据库服务器
mysql> \h or mysql> help  查看帮助(其他的数据库服务器相关命令)



 =======================无==敌==分==割==线=======================


二、数据库操作

   所要注意的是,所有举例的显示结果,均为下面操作步骤按顺序进行的结果。


 ----------------------我------------割--------------------------

2.1 查询语句

2.1.1 查看Mysql数据库的版本号和服务器的当前日期
     mysql> select version(),current_date;   (操作方式一)

     mysql> select version()
         -> ,current_date;                   (操作方式二)

     ※:操作语句间用","隔开,用";"来表示操作结束,操作语句输入过程中,换行不影响操作过程。

2.1.2 查看服务器中的所有数据库
     mysql> show databases;

 ----------------------我------------割--------------------------

2.2 创建数据库

2.2.1 创建数据库(当然,数据库名"asb"不能是已经存在的)
     mysql> create database asb;

2.2.2 选用数据库,使其成为当前操作的数据库
     mysql> use asb;

     成功选中后会有如下显示:
     Database changed

     甚至可以在窗口命令登陆mysql数据库的时候直接选中要操作的数据库(当然前提是asb数据库存在)
     bin>mysql asb -u uesername -p
     Enter password:******

2.2.3 查看当前所操作的数据库名称
     mysql> select database();

     运行后结果如下:
     +------------+
     | database() |
     +------------+
     | asb        |
     +------------+
     1 row in set (0.00 sec)

 ----------------------我------------割--------------------------

2.3 创建表

2.3.1 用"create table"创建表(确认是要在当前数据库中创建,不是的话就先用'use'选中要创建表的那个数据库)

     mysql> create table emp(emp_id varchar(6)
         -> ,emp_name varchar(10)
         -> ,emp_age int
         -> ,emp-sal int
         -> ,emp_bir date
         -> ,emp_sex varchar(5)
         -> );

2.3.2 查看当前数据库中的表(可以检验上例的"emp"表是否成功建立)
     mysql> show tables;

     如果是成功将是如下显示:

       +---------------+
       | Tables_in_asb |
       +---------------+
       | emp           |
       +---------------+
       1 row in set (0.00 sec)

2.3.3 查看数据表的结构
     mysql> describe emp;

     运行后结果会如如下显示:

       +----------+-------------+------+-----+---------+-------+
       | Field    | Type        | Null | Key | Default | Extra |
       +----------+-------------+------+-----+---------+-------+
       | emp_id   | varchar(6)  | YES  |     | NULL    |       |
       | emp_name | varchar(10) | YES  |     | NULL    |       |
       | emp_age  | int(11)     | YES  |     | NULL    |       |
       | emp_sal  | int(11)     | YES  |     | NULL    |       |
       | emp_bir  | date        | YES  |     | NULL    |       |
       | emp_sex  | varchar(5)  | YES  |     | NULL    |       |
       +----------+-------------+------+-----+---------+-------+

 ----------------------我------------割--------------------------

2.4 插入数据

2.4.1 使用INSERT语句进行插入记录操作(数据库表中每一行就是一个记录,插入记录实际上就是向表中插入一行)

     格式:INSERT INTO table_name(数据表名) VALUES(值1,值2,值3...);

     在VALUES关键字后括号中的数值和字符段,必须和你所建的表所定义的字段数据类型必须一致!

     mysql> insert into emp values
         -> ('100005','啸天',27,3000,'1979-07-10','male');

     插入成功后会有如下信息显示:
     Query OK, 1 row affected (0.03 sec)


2.4.2 查看表中的数据(可以确定数据是否已经成功插入)
     mysql> select * from emp;

     成功插入后的数据显示如下:

     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天     |      27 |    3000 | 1979-07-10 | male    |
     +--------+----------+---------+---------+------------+---------+
     1 row in set (0.00 sec)

     一次性插入多行的格式:INSERT INTO table_name(数据表名) VALUES(值1,值2,值3...),(值1,值2,值3...);

     mysql> insert into emp values
         -> ('100001','红枫',29,8000,'1977-01-01','male'),
         -> ('100002','丽鹃',27,7000,'1979-12-31','fmale');

     可以查看插入后的数据结果:

     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天     |      27 |    3000 | 1979-07-10 | male    |
     | 100004 | 红枫     |      29 |    8000 | 1977-01-01 | male    |
     | 100002 | 丽鹃   |      27 |    7000 | 1979-12-31 | fmale   |
     +--------+----------+---------+---------+------------+---------+
     3 rows in set (0.00 sec)


 ----------------------我------------割--------------------------

2.5 修改数据

2.5.1 使用UPDATE语句来更新表中的数据
     mysql> update emp set emp_id=100001 where emp_name='红枫';

     修改结果显示如下:

     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天   |      27 |    3000 | 1979-07-10 | male    |
     | 100001 | 红枫     |      29 |    8000 | 1977-01-01 | male    |
     | 100002 | 丽鹃   |      27 |    7000 | 1979-12-31 | fmale   |
     +--------+----------+---------+---------+------------+---------+
     3 rows in set (0.00 sec)

     如果该语句没有后面的where限制,将会对表中所有的记录都进行修改。
     如,给全部人加薪1000,可以如下修改:
     mysql> update emp set emp_sal=emp_sal+1000;

     修改结果显示如下:

     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
     | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
     | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
     +--------+----------+---------+---------+------------+---------+
     3 rows in set (0.00 sec)

 ----------------------我------------割--------------------------

2.6 高级查询方法

2.6.1 记录查询

     查询emp表中,emp_name为啸天的全部信息
     mysql> select * from emp where emp_name='啸天';

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
     +--------+----------+---------+---------+------------+---------+
     1 row in set (0.00 sec)

     查询emp表中,emp_sal,工资在5000以上的全部信息
     mysql> select * from emp where emp_sal>5000;

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
     | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
     +--------+----------+---------+---------+------------+---------+
     2 rows in set (0.00 sec)

     查询emp表中在1978年1月1日之后出生的
     mysql> select * from emp where emp_bir>'1978-01-01';

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
     | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
     +--------+----------+---------+---------+------------+---------+
     2 rows in set (0.00 sec)

     查询emp表中在1979年12月1日之前出生,工资在5000以上的
     mysql> select * from emp where emp_bir<'1979-12-01' and emp_sal>5000;

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
     +--------+----------+---------+---------+------------+---------+
     1 row in set (0.00 sec)

2.6.2 字段查询

     CEO查看员工工资情况
     mysql> select emp_name,emp_sal from emp;

     查询结果显示如下:
     +----------+---------+
     | emp_name | emp_sal |
     +----------+---------+
     | 啸天   |    4000 |
     | 红枫     |    9000 |
     | 丽鹃   |    8000 |
     +----------+---------+
     3 rows in set (0.00 sec)

     查看1978年后出生的人的姓名、工资和性别
     mysql> select emp_name,emp_sal,emp_sex from emp where emp_bir>"1977-12-31";

     查询结果显示如下:
     +----------+---------+---------+
     | emp_name | emp_sal | emp_sex |
     +----------+---------+---------+
     | 啸天   |    4000 | male    |
     | 丽鹃   |    8000 | fmale   |
     +----------+---------+---------+
     2 rows in set (0.00 sec)

2.6.3 查询结果排序

     用ORDER BY语句对emp表中所有员工工资高低顺序查询结果(默认是从低到高——升序)
     mysql> select * from emp order by emp_sal;

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
     | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
     | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
     +--------+----------+---------+---------+------------+---------+
     3 rows in set (0.00 sec)

     用DESC关键字来进行从高到低排序——降序
     mysql> select * from emp order by emp_sal desc;

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
     | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
     | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
     +--------+----------+---------+---------+------------+---------+
     3 rows in set (0.00 sec)

2.6.4 查询结果数量的限制

     用LIMIT查看emp表中工资收入排名前两个员工的资料:
     mysql> select * from emp order by emp_sal desc limit 2;

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
     | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
     +--------+----------+---------+---------+------------+---------+
     2 rows in set (0.00 sec)

    查看工资排名第2到第3的员工资料:
    mysql> select * from emp order by emp_sal desc limit 1,2;

    查询结果显示如下:
    +--------+----------+---------+---------+------------+---------+
    | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
    +--------+----------+---------+---------+------------+---------+
    | 100002 | 丽鹃   |      27 |    8000 | 1979-12-31 | fmale   |
    | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
    +--------+----------+---------+---------+------------+---------+
    2 rows in set (0.01 sec)

    使用rand()抽样调查,随机抽取2个员工,查看其资料
    mysql> select * from emp order by rand() limit 2;

    如如下结果:(随机的)

    +--------+----------+---------+---------+------------+---------+
    | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
    +--------+----------+---------+---------+------------+---------+
    | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
    | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
    +--------+----------+---------+---------+------------+---------+
    2 rows in set (0.01 sec)

2.6.5 查询结果的字段联合和重新命名

     mysql> select concat(emp_id,"  ",emp_name) from emp;

     查询结果:
     +------------------------------+
     | concat(emp_id,"  ",emp_name) |
     +------------------------------+
     | 100005  啸天               |
     | 100001  红枫                 |
     | 100002  丽鹃               |
     +------------------------------+
     3 rows in set (0.00 sec)

     用AS关键字重新给输出结果命名标题
     mysql> select concat(emp_id,"  ",emp_name) as info from emp;

     查询结果如下显示:
     +----------------+
     | info           |
     +----------------+
     | 100005  啸天 |
     | 100001  红枫   |
     | 100002  丽鹃 |
     +----------------+
     3 rows in set (0.00 sec)

2.6.6 日期查询的相关运算

     可以通过YEAR()、MONTH()、DAYOFMONTH()函数来提取日期的组成元素

     查询7月份出生的员工资料:
     mysql> select * from emp where month(emp_bir)=7;

     查询结果显示如下:
     +--------+----------+---------+---------+------------+---------+
     | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
     +--------+----------+---------+---------+------------+---------+
     | 100005 | 啸天   |      27 |    4000 | 1979-07-10 | male    |
     +--------+----------+---------+---------+------------+---------+
     1 row in set (0.00 sec)

    可以利用英文月份来查询:
    mysql> select * from emp where monthname(emp_bir)="January";

    查询结果显示如下:
    +--------+----------+---------+---------+------------+---------+
    | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
    +--------+----------+---------+---------+------------+---------+
    | 100001 | 红枫     |      29 |    9000 | 1977-01-01 | male    |
    +--------+----------+---------+---------+------------+---------+
    1 row in set (0.00 sec)

    利用TO_DAYS()函数可以查询出职工们从出生到现在所经理的时间,单位是天数
    mysql> select to_days(current_date) - to_days(emp_bir) as livingdays from emp;

    查询后结果如下:
    +------------+
    | livingdays |
    +------------+
    |       9425 |
    |      10345 |
    |       9251 |
    +------------+
    3 rows in set (0.00 sec)

    计算从现在开始经历100天后的日期
    mysql> select date_add(now(),interval 100 day);

    查询结果如下:
    +----------------------------------+
    | date_add(now(),interval 100 day) |
    +----------------------------------+
    | 2005-08-07 13:56:58              |
    +----------------------------------+
    1 row in set (0.00 sec)

    计算从现在开始经历100天后的日期
    mysql> select date_sub(now(),interval 100 day);

    查询结果如下:
    +----------------------------------+
    | date_sub(now(),interval 100 day) |
    +----------------------------------+
    | 2005-01-19 14:00:20              |
    +----------------------------------+
    1 row in set (0.00 sec)

2.6.7 数据统计

     使用COUNT()函数计算表中的数据数目(比如emp表中的员工数目)
     mysql> select count(*) from emp;

     查询结果如下:
     +----------+
     | count(*) |
     +----------+
     |        3 |
     +----------+
     1 row in set (0.01 sec)

     统计工资上5000的数目
     mysql> select count(*) from emp where emp_sal>5000;

     查询结果如下:
     +----------+
     | count(*) |
     +----------+
     |        2 |
     +----------+
     1 row in set (0.00 sec)

     统计男女职工数目:(GROUP BY语句分类)
     mysql> select emp_sex,count(*) from emp group by emp_sex;

     查询结果如下:
     +---------+----------+
     | emp_sex | count(*) |
     +---------+----------+
     | fmale   |        1 |
     | male    |        2 |
     +---------+----------+
     2 rows in set (0.01 sec)

     使用数据统计函数(MIN(),MAX(),SUM(),AVG())
     mysql> select
         -> min(emp_sal) as min_salary,
         -> max(emp_sal) as max_salary,
         -> sum(emp_sal) as sum_salary,
         -> avg(emp_sal) as avg_salary,
         -> count(*) as employee_num
         -> from emp;

     查询结果如下:
     +------------+------------+------------+------------+--------------+
     | min_salary | max_salary | sum_salary | avg_salary | employee_num |
     +------------+------------+------------+------------+--------------+
     |       4000 |       9000 |      21000 |  7000.0000 |            3 |
     +------------+------------+------------+------------+--------------+
     1 row in set (0.00 sec)

2.6.8 从多个数据表中检索信息

     根据前面的方法,分别进行如下操作:
     1). 在数据库asb中建立一个新表dept,表中有两项元素:
         dept_id    --> varchar(6)
         dept_name  --> varchar(10)
     2). 在表emp中插入如下一行新记录:
         +--------+----------+---------+---------+------------+---------+
         | emp_id | emp_name | emp_age | emp_sal | emp_bir    | emp_sex |
         +--------+----------+---------+---------+------------+---------+
         | 100003 | 小红   |      30 |    8000 | 1976-11-11 | fmale   |
         +--------+----------+---------+---------+------------+---------+
     3). 在新表dept中,输入如下记录
         +---------+-----------+
         | dept_id | dept_name |
         +---------+-----------+
         | 100005  | MTD       |
         | 100001  | MTD       |
         | 100002  | MTD       |
         | 100003  | HR        |
         +---------+-----------+

     查询emp和dept这两个表中,员工的姓名和部门信息
     mysql> select emp.emp_name,dept.dept_name from emp,dept
         -> where emp.emp_id=dept.dept_id;

     查询结果如下:
     +----------+-----------+
     | emp_name | dept_name |
     +----------+-----------+
     | 啸天   | MTD       |
     | 红枫     | MTD       |
     | 丽鹃   | MTD       |
     | 小红   | HR        |
     +----------+-----------+
     4 rows in set (0.00 sec)

     多表查询时注意:
       1). FROM子句必须给出所查询的表的全部名称
       2). 选择字段时候注明其所属表的名称(如emp表中的emp_id要表示为emp.emp_id)
       3). 在Where子句中必须指明查询的条件(如,emp.emp_id和dept.dept_id是相同意义的元素)

 ----------------------我------------割--------------------------

2.7 删除表单数据

2.7.1 使用DELETE语句删除表单中的数据记录
     小红不在了哦,得删了吧
     mysql>delete from emp where emp_name='小红';

     执行成功后会如下显示:
     Query OK, 1 row affected (0.06 sec)

     省略where是删除全部表中的记录

2.7.2 使用DRO删除表
     (先随便建立一个数据库dt,并建张临时表fuck)

     mysql>drop table fuck;

2.7.3 使用DRO删除数据库
     mysql>drop database dt;

 ----------------------我------------割--------------------------

2.8 改变数据表的结构
   先建立一个新表id (内带一个属性id_name varchar(6)),输入一行数据(xgw)

2.8.1 对表重新命名
     alter table 数据表名 rename as 数据表的新名字;

     把表id改名成name
     mysql> alter table id rename as name;

2.8.2 给数据表增加一个字段
     alter table 数据表名 add 字段名称 字段类型;

     在改过名的新表name中增加一个字段(id int(6))
     mysql>alter table name add id int(6);

     增加成功后有如下显示:
     Query OK, 1 row affected (0.26 sec)
     Records: 1  Duplicates: 0  Warnings: 0

2.8.3 更改已经建立的字段类型
     alter table 数据表名 modify 字段名称 字段类型;

     把name表中id属性的类型改成10个长度的字符类型
     mysql> alter table name modify id varchar(10);


     alter talbe语句还有很多功能,具体可查阅MySQL的技术手册。

    
(the questions,call me anytime! E-mail:tt981@netease.com)

   ※※※※※※※※※※※※※※Mysql 初级解读 (所用版本:4.1.10)※※※※※※※※※※※※※※
CopyRight By FengLin , 2005-4-29
Oct 5

1.WMLHTML有何不同?


  答:WML将文件分割成一套容易定义的用户交互操作单元,而每个交互操作单元被称为一个卡,用户通过在一个或多个这样的卡之间来回导航来实现对
Internet的接入。针对手机电话通信的特点,WML提供了一套数量更小的标记标签集,这使它比HTML更适合于移动通讯产品中使用。使用WAPTM
网关,所有的WML内容都可以通过HTTP1. 1来进行Internet接入,这样,传统的Web服务器、工具和技术都可以继续使用。


2.WAP论坛(WAPFORUM)是什麽?
  答:WAP论坛是一个拥有200多个成员的行业协会,它致力于开发用于数字移动电话和其他无线终端设备的全球性标准。WAP论坛的主要目标是确保无线行业各公司的产品的互相相容持续发展。WAP论坛的成员拥有90%以上的全球手机市场。


3.通过手机拨号上网跟手机上网有何分别?
  答:目前市场上有一类手机,商家称为"能上网"。其实它只能与笔记本电脑通过
数据线相连,使笔记本电脑通过手机拨号上网。这种手机自身并不具备浏览互联网功能,只是一部能拨号上网的移动电话而已。在构造上它只是比普通手机多一个数
据传输口或红外接口。因此严格说起来,它其实只能"通过手机上网",而算不上"能上网(浏览互联网)的手机"。


4.WAPTMWML之间的关系是什麽?
  答:WAP利用数据压缩技术与窄带环境相适应。WML(无线标识语言)是用于产生WAP内容的,它充分利用小屏幕的特点,且可单手进行操作。WAP内容既可以是一两行文本,也可以是全屏图表。


5.如果想参加WAPTM技术开发园地,应该怎办?
  答:请浏览爱立信WAP开发者园地网站:
  http://www.ericsson.com/developerszone/index.asp(英文 )
  您可获得最新行业信息,爱立信WAP产品简介,及下载常用开发工具,如WAP伺服器等。


6.爱立信跟WAPTM科技研发有甚麽紧密的关系?
  答:爱立信是WAP科技最初的研发者,具备了成熟并完整的WAP科技发展技术,由系统,垂询及移动装置一应俱全,现已拥有超过四百个垂询顾问,协助WAP解决方案的发展,并已向电话商提供超过二十个WAP系统。


7.为什么我放在apache服务器上的WML文件不能被打开?
  答:在apache上设置WAP Server需要设置以下参数才可以被WAP终端访问。
  增加类型text/vnd.wap.wml wml
  增加类型text/vnd.wap.wmlscript wmls
  增加类型image/vnd.wap.wbmp wbmp
  增加类型application/vnd.wap.wmlc wmlc
  增加类型application/vnd.wap.wmlscriptc wmlsc


8.deck的文件极限是多大?
  答:deck文件的极限是1397 bytes,假如文件中有中文,文件应该控制在1.2K以内。


9.我们能否使用java applets来增强WAP服务?
  答:WML不支持java applets,但是将来的java将加载到无线设备的CPU和内存上。


10.WML是否支持cookies?
  答:今天的WML尚不支持cookies。


11.我想在页面中提供电话号码的链接,让用户直接通过链接来拨号,请问这种功能如何实现?
  答:当前还不可能通过WML链接去拨号,这一功能会在新版的WAP中实现。


12.如何申请免费的wap网关代理?如何设置?
  答:不用申请。例如在诺基亚7110里有一个设置项:"IP地址", 直接在上面填上WAP网关的IP即可,如Ericsson的网关IP为:195.58.110.201。


分页: 27/29 第一页 上页 22 23 24 25 26 27 28 29 下页 最后页 [ 显示模式: 摘要 | 列表 ]