📄 0008.htm
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0045)http://www.mypcera.com/softxue/7/sql/0008.htm -->
<HTML><HEAD>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<STYLE>BODY {
FONT-SIZE: 9pt; FONT-FAMILY: 宋体
}
TABLE {
FONT-SIZE: 9pt; FONT-FAMILY: 宋体
}
A {
TEXT-DECORATION: none
}
A:hover {
COLOR: red; TEXT-DECORATION: underline
}
.1 {
BACKGROUND-COLOR: rgb(245,245,245)
}
</STYLE>
<SCRIPT src="0008.files/1.js"></SCRIPT>
<META content="MSHTML 6.00.2800.1106" name=GENERATOR></HEAD>
<BODY>
<P align=center></A>
<P align=center><BIG><STRONG>SQL数据操作基础(中级) 8</STRONG></BIG></P>
<DIV align=right>---摘自《ChinaASP网络》</DIV>
<P><SPAN class=f><SPAN class=smallFont><SPAN class=smallFont><SPAN
class=smallFont>更新记录<BR><BR>要修改表中已经存在的一条或多条记录,应使用SQL
UPDATE语句。同DELETE语句一样,UPDATE语句可以使用WHERE子句来选择更新特定的记录。请看这个例子:<BR><BR>UPDATE mytable
SET first_column=’Updated!’ WHERE second_column=’Update Me!’<BR><BR>这个UPDATE
语句更新所有second_column字段的值为’Update
Me!’的记录。对所有被选中的记录,字段first_column的值被置为’Updated!’。<BR><BR>下面是UPDATE语句的完整句法:<BR><BR>UPDATE
{table_name|view_name} SET
[{table_name|view_name}]<BR><BR>{column_list|variable_list|variable_and_column_list}<BR><BR>[,{column_list2|variable_list2|variable_and_column_list2}…<BR><BR>[,{column_listN|variable_listN|variable_and_column_listN}]]<BR><BR>[WHERE
clause]<BR><BR>注意:<BR><BR>你可以对文本型字段使用UPDATE语句。但是,如果你需要更新很长的字符串,应使用UPDATETEXT语句。这部分内容对本书来说太高级了,因此不加讨论。要了解更多的信息,请参考Microsoft
SQL Sever
的文档。<BR><BR>如果你不提供WHERE子句,表中的所有记录都将被更新。有时这是有用的。例如,如果你想把表titles中的所有书的价格加倍,你可以使用如下的UPDATE
语句:<BR><BR>你也可以同时更新多个字段。例如,下面的UPDATE语句同时更新first_column,second_column,和third_column这三个字段:<BR><BR>UPDATE
mytable SET
first_column=’Updated!’<BR><BR>Second_column=’Updated!’<BR><BR>Third_column=’Updated!’<BR><BR>WHERE
first_column=’Update
Me1’<BR><BR>技巧:<BR><BR>SQL忽略语句中多余的空格。你可以把SQL语句写成任何你最容易读的格式。<BR><BR> <BR><BR>用SELECT
创建记录和表<BR><BR>你也许已经注意到,INSERT
语句与DELETE语句和UPDATE语句有一点不同,它一次只操作一个记录。然而,有一个方法可以使INSERT
语句一次添加多个记录。要作到这一点,你需要把INSERT 语句与SELECT 语句结合起来,象这样:<BR><BR>INSERT mytable
(first_column,second_column)<BR><BR>SELECT
another_first,another_second<BR><BR>FROM anothertable<BR><BR>WHERE
another_first=’Copy
Me!’<BR><BR>这个语句从anothertable拷贝记录到mytable.只有表anothertable中字段another_first的值为’Copy
Me!’的记录才被拷贝。<BR><BR>当为一个表中的记录建立备份时,这种形式的INSERT
语句是非常有用的。在删除一个表中的记录之前,你可以先用这种方法把它们拷贝到另一个表中。<BR><BR>如果你需要拷贝整个表,你可以使用SELECT INTO
语句。例如,下面的语句创建了一个名为newtable的新表,该表包含表mytable的所有数据:<BR><BR>SELECT * INTO newtable
FROM
mytable<BR><BR>你也可以指定只有特定的字段被用来创建这个新表。要做到这一点,只需在字段列表中指定你想要拷贝的字段。另外,你可以使用WHERE
子句来限制拷贝到新表中的记录。下面的例子只拷贝字段second_columnd的值等于’Copy
Me!’的记录的first_column字段。<BR><BR>SELECT first_column INTO newtable<BR><BR>FROM
mytable<BR><BR>WHERE second_column=’Copy
Me!’<BR><BR>使用SQL修改已经建立的表是很困难的。例如,如果你向一个表中添加了一个字段,没有容易的办法来去除它。另外,如果你不小心把一个字段的数据类型给错了,你将没有办法改变它。但是,使用本节中讲述的SQL语句,你可以绕过这两个问题。<BR><BR>例如,假设你想从一个表中删除一个字段。使用SELECT
INTO
语句,你可以创建该表的一个拷贝,但不包含要删除的字段。这使你既删除了该字段,又保留了不想删除的数据。<BR><BR>如果你想改变一个字段的数据类型,你可以创建一个包含正确数据类型字段的新表。创建好该表后,你就可以结合使用UPDATE语句和SELECT
语句,把原来表中的所有数据拷贝到新表中。通过这种方法,你既可以修改表的结构,又能保存原有的数据。<BR><BR>集合函数<BR><BR>到现在为止,你只学习了如何根据特定的条件从表中取出一条或多条记录。但是,假如你想对一个表中的记录进行数据统计。例如,如果你想统计存储在表中的一次民意测验的投票结果。或者你想知道一个访问者在你的站点上平均花费了多少时间。要对表中的任何类型的数据进行统计,都需要使用集合函数。<BR><BR>Microsoft
SQL
支持五种类型的集合函数。你可以统计记录数目,平均值,最小值,最大值,或者求和。当你使用一个集合函数时,它只返回一个数,该数值代表这几个统计值之一。<BR><BR>注意:<BR><BR>要在你的ASP网页中使用集合函数的返回值,你需要给该值起一个名字。要作到这一点,你可以在SELECT语句中,在集合函数后面紧跟一个字段名,如下例所示:<BR><BR>SELECT
AVG(vote) ‘the_average’ FROM opinion<BR><BR>在这个例子中,vote的平均值被命名为
the_average。现在你可以在你的ASP网页的数据库方法中使用这个名字。<BR><BR>统计字段值的数目<BR><BR>函数COUNT()也许是最有用的集合函数。你可以用这个函数来统计一个表中有多少条记录。这里有一个例子:<BR><BR>SELECT
COUNT(au_lname) FROM authors<BR><BR>这个例子计算表authors中名字(last
name)的数目。如果相同的名字出现了不止一次,该名字将会被计算多次。如果你想知道名字为某个特定值的作者有多少个,你可以使用WHERE子句,如下例所示:<BR><BR>SELECT
COUNT(au_lname) FROM authors WHERE
au_lname=’Ringer’<BR><BR>这个例子返回名字为’Ringer’的作者的数目。如果这个名字在表authors中出现了两次,则次函数的返回值是2。<BR><BR>假如你想知道有不同名字的作者的数目。你可以通过使用关键字DISTINCT来得到该数目。如下例所示:<BR><BR>SELECT
COUNT(DISTINCT au_lname) FROM
authors<BR><BR>如果名字’Ringer’出现了不止一次,它将只被计算一次。关键字DISTINCT
决定了只有互不相同的值才被计算。<BR><BR>通常,当你使用COUNT()时,字段中的空值将被忽略。一般来说,这正是你所希望的。但是,如果你仅仅想知道表中记录的数目,那么你需要计算表中所有的记录─不管它是否包含空值。下面是一个如何做到这一点的例子:<BR><BR>SELECT
COUNT(*) FROM
authors<BR><BR>注意函数COUNT()没有指定任何字段。这个语句计算表中所有记录所数目,包括有空值的记录。因此,你不需要指定要被计算的特定字段。<BR><BR>函数COUNT()在很多不同情况下是有用的。例如,假设有一个表保存了对你站点的质量进行民意调查的结果。这个表有一个名为vote的字段,该字段的值要么是0,要么是1。0表示反对票,1表示赞成票。要确定赞成票的数量,你可以所有下面的SELECT
语句:<BR><BR>SELECT COUNT(vote) FROM opinion_table WHERE
vote=1<BR><BR>计算字段的平均值<BR><BR>使用函数COUNT(),你可以统计一个字段中有多少个值。但有时你需要计算这些值的平均值。使用函数AVG(),你可以返回一个字段中所有值的平均值。<BR><BR>假如你对你的站点进行一次较为复杂的民意调查。访问者可以在1到10之间投票,表示他们喜欢你站点的程度。你把投票结果保存在名为vote的INT型字段中。要计算你的用户投票的平均值,你需要使用函数AVG():<BR><BR>SELECT
AVG(vote) FROM
opinion<BR><BR>这个SELECT语句的返回值代表用户对你站点的平均喜欢程度。函数AVG()只能对数值型字段使用。这个函数在计算平均值时也忽略空值。<BR><BR>计算字段值的和<BR><BR>假设你的站点被用来出售卡片,已经运行了两个月,是该计算赚了多少钱的时候了。假设有一个名为orders的表用来记录所有访问者的定购信息。要计算所有定购量的总和,你可以使用函数SUM():<BR><BR>SELECT
SUM(purchase_amount) FROM
orders<BR><BR>函数SUM()的返回值代表字段purchase_amount中所有值的平均值。字段purchase_amount的数据类型也许是MONEY型,但你也可以对其它数值型字段使用函数SUM()。<BR><BR>返回最大值或最小值<BR><BR>再一次假设你有一个表用来保存对你的站点进行民意调查的结果。访问者可以选择从1到10
的值来表示他们对你站点的评价。如果你想知道访问者对你站点的最高评价,你可以使用如下的语句:<BR><BR>SELECT MAX(vote) FROM
opinion<BR><BR>你也许希望有人对你的站点给予了很高的评价。通过函数MAX(),你可以知道一个数值型字段的所有值中的最大值。如果有人对你的站点投了数字10,函数MAX()将返回该值。<BR><BR>另一方面,假如你想知道访问者对你站点的的最低评价,你可以使用函数MIN(),如下例所示:<BR><BR>SELECT
MIN(vote) FROM
opinion<BR><BR>函数MIN()返回一个字段的所有值中的最小值。如果字段是空的,函数MIN()返回空值。<BR><BR>其它常用的SQL表达式,函数,和过程<BR><BR>这一节将介绍一些其它的SQL技术。你将学习如何从表中取出数据,其某个字段的值处在一定的范围,你还将学习如何把字段值从一种类型转换成另一种类型,如何操作字符串和日期时间数据。最后,你将学会一个发送邮件的简单方法。<BR><BR>通过匹配一定范围的值来取出数据<BR><BR>假设你有一个表用来保存对你的站点进行民意调查的结果。现在你想向所有对你的站点的评价在7到10之间的访问者发送书面的感谢信。要得到这些人的名字,你可以使用如下的SELECT
语句:<BR><BR>SELECT username FROM opinion WHERE vote>6 and
vote<11<BR><BR>这个SELECT 语句会实现你的要求。你使用下面的SELECT 语句也可以得到同样的结果:<BR><BR>SELECT
username FROM opinion WHERE vote BETWEEN 7 AND 10<BR><BR>这个SELECT
语句与上一个语句是等价的。使用哪一种语句是编程风格的问题,但你会发现使用表达式BETWEEN
的语句更易读。<BR><BR>现在假设你只想取出对你的站点投了1或者10的访问者的名字。要从表opinion中取出这些名字,你可以使用如下的SELECT
语句:<BR><BR>SELECT username FROM opinion WHERE vote=1 or
vote.<BR><BR>这个SELECT语句会返回正确的结果,没有理由不使用它。但是,存在一种等价的方式。使用如下的SELECT可以得到相同的结果:<BR><BR>SELECT
username FROM opinion WHERE vote IN (1,10)<BR><BR>注意表达式IN 的使用。这个SELECT
语句只取出vote的值等于括号中的值之一的记录。<BR><BR>你也可以使用IN来匹配字符数据。例如,假设你只想取出Bill Gates或President
Clinton的投票值。你可以使用如下的SELECT 语句:<BR><BR>SELECT vote FROM opinion WHERE username IN
(‘Bill Gates’,’President
Clinton’)<BR><BR>最后,你可以在使用BETWEEN或IN的同时使用表达式NOT。例如,要取出那些投票值不在7到10之间的人的名字,你可以使用如下的SELECT
语句:<BR><BR>SELECT username FROM opinion WHERE vote NOT BETWEEN 7 and
10<BR><BR>要选取那些某个字段的值不在一列值之中的记录,你可以同时使用NOT 和IN,如下例所示:<BR><BR>SELECT vote FROM
opinion <BR><BR>WHERE username NOT IN (‘Bill Gates’,’President
Clinton’)<BR><BR>你不是必须在SQL语句中使用BETWEEN或IN,但是,要使你的查询更接近自然语言,这两个表达式是有帮助的。</SPAN>
</TABLE>
<P align=center>
<SCRIPT src="0008.files/2.js"></SCRIPT>
</A></P></SPAN></SPAN></SPAN></BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -