SQL常用命令使用方法

上一篇 / 下一篇  2007-04-18 13:28:32 / 个人分类:数据库

|SQL常用命令使用方法:|

(1)数据记录筛选:

sql="select * from数据表where字段名=字段值order by字段名[desc]"

sql="select * from数据表where字段名like '%字段值%' order by字段名[desc]"

sql="select top 10 * from数据表where字段名order by字段名[desc]"

sql="select * from数据表where字段名in ('1','2','3')"

sql="select * from数据表where字段名between1 and2"

(2)更新数据记录:

sql="update数据表set字段名=字段值where条件表达式"

sql="update数据表set字段1=1,字段2=2 ……字段n=n where条件表达式"

(3)删除数据记录:

sql="delete from数据表where条件表达式"

sql="delete from数据表" (将数据表所有记录删除)

(4)添加数据记录:

2insert语句:1)带字段名2)不带字段名(即针对所有的字段,并进行赋值,值不确定为null

sql="insert into数据表(字段1,字段2,字段3 …) values (1,2,3 …)"

也可以不写上字段名:

如果加入表的所有列的数据,不用写字段名了(ID是自动排列的不用写!字符型的数据不要加引号!除非是浮点型的数据)

sql=”insert into包装values('009','恐龙',2.3,null,null)”//前提:列名或所提供值的数目与表定义必须匹配

sql="insert into目标数据表select * from源数据表" (把源数据表的记录添加到目标数据表)  //前提:列名或所提供值的数目与表定义必须匹配

(5)数据记录统计函数:

AVG(字段名)得出一个表格栏平均值

COUNT(*¦字段名)对数据行数的统计或对某一栏有值的数据行数统计

MAX(字段名)取得一个表格栏最大的值

MIN(字段名)取得一个表格栏最小的值

SUM(字段名)把数据栏的值相加

引用以上函数的方法:

sql="select sum(字段名) as别名from数据表where条件表达式"

set rs=conn.excute(sql)

rs("别名")获取统的计值,其它函数运用同上。

(5)数据表的建立和删除:

CREATE TABLE数据表名称(字段1类型1(长度),字段2类型2(长度) …… )

例:CREATE TABLE tab01(name varchar(50),datetime default now())

DROP TABLE数据表名称(永久性删除一个数据表)

//字段类型 char:数字,用于ID,比较短的名称如州,邮编,电话等char(3)

           Varchar:字符,用于文字等,varchar(20)||varchar(20) null

           Money:价格,money|money null可允许为空||money not null不允许为空

           Image:照片,image null

           Int:年份,销售数量,int

           Smallint:月份,samllint

           Datetime:日期,datetime||datetime null

另一资料,sql基本语句.

掌握SQL四条最基本的数据操作语句:InsertSelectUpdateDelete

  练掌握SQL数据库用户的宝贵财富。在本文中,我们将引导你掌握四条最基本的数据操作语句—SQL的核心功能来依次介绍比较操作符、选择断言以及三值逻辑。当你完成这些学习后,显然你已经开始算是精通SQL了。

  在我们开始之前,先使用CREATE TABLE语句来创建一个表(如图1所示)。DDL语句对数据库对象如表、列和视进行定义。它们并不对表中的行进行处理,这是因为DDL语句并不处理数据库中实际的数据。这些工作由另一类SQL语句数据操作语言(DML)语句进行处理。

  SQL中有四种基本的DML操作:INSERTSELECTUPDATEDELETE。由于这是大多数SQL用户经常用到的,我们有必要在此对它们进行一一说明。在图1中我们给出了一个名为EMPLOYEES的表。其中的每一行对应一个特定的雇员记录。请熟悉这张表,我们在后面的例子中将要用到它。

  INSERT语句

  用户可以用INSERT语句将一行记录插入到指定的一个表中。例如,要将雇员John Smith的记录插入到本例的表中,可以使用如下语句:

  INSERT INTO EMPLOYEES VALUES

  ('Smith','John','1980-06-10',

  'Los Angles',16,45000);

  通过这样的INSERT语句,系统将试着将这些值填入到相应的列中。这些列按照我们创建表时定义的顺序排列。在本例中,第一个值“Smith”将填到第一个列LAST_NAME中;第二个值“John”将填到第二列FIRST_NAME……以此类推。

  我们说过系统会试着将值填入,除了执行规则之外它还要进行类型检查。如果类型不符(如将一个字符串填入到类型为数字的列中),系统将拒绝这一次操作并返回一个错误信息。

  如果SQL拒绝了你所填入的一列值,语句中其他各列的值也不会填入。这是因为SQL提供对事务的支持。一次事务将数据库从一种一致性转移到另一种一致性。如果事务的某一部分失败,则整个事务都会失败,系统将会被恢复(或称之为回退)到此事务之前的状态。

  回到原来的INSERT的例子,请注意所有的整形十进制数都不需要用单引号引起来,而字符串和日期类型的值都要用单引号来区别。为了增加可读性而在数字间插入逗号将会引起错误。记住,在SQL中逗号是元素的分隔符。

  同样要注意输入文字值时要使用单引号。双引号用来封装限界标识符。

  对于日期类型,我们必须使用SQL标准日期格式(yyyy-mm-dd),但是在系统中可以进行定义,以接受其他的格式。当然,2000年临近,请你最好还是使用四位来表示年份。

  既然你已经理解了INSERT语句是怎样工作的了,让我们转到EMPLOYEES表中的其他部分:

  INSERT INTO EMPLOYEES VALUES

  ('Bunyan','Paul','1970-07-04',

  'Boston',12,70000);

  INSERT INTO EMPLOYEES VALUES

  ('John','Adams','1992-01-21',

  'Boston',20,100000);

  INSERT INTO EMPLOYEES VALUES

  ('Smith','Pocahontas','1976-04-06',

  'Los Angles',12,100000);

  INSERT INTO EMPLOYEES VALUES

  ('Smith','Bessie','1940-05-02',

  'Boston',5,200000);

  INSERT INTO EMPLOYEES VALUES

  ('Jones','Davy','1970-10-10',

  'Boston',8,45000);

  INSERT INTO EMPLOYEES VALUES

  ('Jones','Indiana','1992-02-01',

  'Chicago',NULL,NULL);

  在最后一项中,我们不知道Jones先生的工薪级别和年薪,所以我们输入NULL(不要引号)。NULLSQL中的一种特殊情况,我们以后将进行详细的讨论。现在我们只需认为NULL表示一种未知的值。

  有时,像我们刚才所讨论的情况,我们可能希望对某一些而不是全部的列进行赋值。除了对要省略的列输入NULL外,还可以采用另外一种INSERT语句,如下:

  INSERT INTO EMPLOYEES(

  FIRST_NAME, LAST_NAME,

  HIRE_DATE, BRANCH_OFFICE)

  VALUES(

  'Indiana','Jones',

  '1992-02-01','Indianapolis');

  这样,我们先在表名之后列出一系列列名。未列出的列中将自动填入缺省值,如果没有设置缺省值则填入NULL。请注意我们改变了列的顺序,而值的顺序要对应新的列的顺序。如果该语句中省略了FIRST_NAMELAST_NAME项(这两项规定不能为空),SQL操作将失败。

  让我们来看一看上述INSERT语句的语法图:

  INSERT INTO table

  [(column { ,column})]

  VALUES

  (columnvalue [{,columnvalue}]);

  和前一篇文章中一样,我们用方括号来表示可选项,大括号表示可以重复任意次数的项(不能在实际的SQL语句中使用这些特殊字符)。VALUE子句和可选的列名列表中必须使用圆括号。

  SELECT语句

  SELECT语句可以从一个或多个表中选取特定的行和列。因为查询和检索数据是数据库管理中最重要的功能,所以SELECT语句在SQL中是工作量最大的部分。实际上,仅仅是访问数据库来分析数据并生成报表的人可以对其他SQL语句一窍不通。

  SELECT语句的结果通常是生成另外一个表。在执行过程中系统根据用户的标准从数据库中选出匹配的行和列,并将结果放到临时的表中。在直接SQLdirect SQL)中,它将结果显示在终端的显示屏上,或者将结果送到打印机或文件中。也可以结合其他SQL语句来将结果放到一个已知名称的表中。

  SELECT语句功能强大。虽然表面上看来它只用来完成本文第一部分中提到的关系代数运算选择(或称限制),但实际上它也可以完成其他两种关系运算—“投影连接SELECT语句还可以完成聚合计算并对数据进行排序。

  SELECT语句最简单的语法如下:

  SELECT columns FROM tables;

  当我们以这种形式执行一条SELECT语句时,系统返回由所选择的列以及用户选择的表中所有指定的行组成的一个结果表。这就是实现关系投影运算的一个形式。

  让我们看一下使用图1EMPLOYEES表的一些例子(这个表是我们以后所有SELECT语句实例都要使用的。而我们在图2和图3中给出了查询的实际结果。我们将在其他的例子中使用这些结果)。

  假设你想查看雇员工作部门的列表。那下面就是你所需要编写的SQL查询:

  SELECT BRANCH_OFFICE FROM EMPLOYEES;

  以上SELECT语句的执行将产生如图2中表2所示的结果。

  由于我们在SELECT语句中只指定了一个列,所以我们的结果表中也只有一个列。注意结果表中具有重复的行,这是因为有多个雇员在同一部门工作(记住SQL从所选的所有行中将值返回)。要消除结果中的重复行,只要在SELECT语句中加上DISTINCT子句:(目的:去掉查询结果中相同的项,仅保留着一项)

  SELECT DISTINCT BRANCH_OFFICE

  FROM EMPLOYEES;

  这次查询的结果如表3所示。

  现在已经消除了重复的行,但结果并不是按照顺序排列的。如果你希望以字母表顺序将结果列出又该怎么做呢?只要使用ORDER BY子句就可以按照升序或降序来排列结果:

  SELECT DISTINCT BRANCH_OFFICE

  FROM EMPLOYEES

  ORDER BY BRANCH_OFFICE ASC;

  这一查询的结果如表4所示。请注意在ORDER BY之后是如何放置列名BRANCH _OFFICE的,这就是我们想要对其进行排序的列。为什么即使是结果表中只有一个列时我们也必须指出列名呢?这是因为我们还能够按照表中其他列进行排序,即使它们并不显示出来。列名BRANCH_ OFFICE

TAG: 数据库

 

评分:0

我来说两句

我的栏目

日历

« 2024-03-27  
     12
3456789
10111213141516
17181920212223
24252627282930
31      

我的存档

数据统计

  • 访问量: 3052
  • 日志数: 2
  • 建立时间: 2007-04-18
  • 更新时间: 2007-04-18

RSS订阅

Open Toolbar