SQL语法大全.docx

上传人:b****6 文档编号:8111524 上传时间:2023-01-28 格式:DOCX 页数:17 大小:29.13KB
下载 相关 举报
SQL语法大全.docx_第1页
第1页 / 共17页
SQL语法大全.docx_第2页
第2页 / 共17页
SQL语法大全.docx_第3页
第3页 / 共17页
SQL语法大全.docx_第4页
第4页 / 共17页
SQL语法大全.docx_第5页
第5页 / 共17页
点击查看更多>>
下载资源
资源描述

SQL语法大全.docx

《SQL语法大全.docx》由会员分享,可在线阅读,更多相关《SQL语法大全.docx(17页珍藏版)》请在冰豆网上搜索。

SQL语法大全.docx

SQL语法大全

SQL语法大全

1.ASP与Access数据库连接:

2.ASP与SQL数据库连接:

建立记录集对象:

setrs=server.createobject("adodb.recordset")

rs.openSQL语句,conn,3,2

3.SQL常用命令使用方法:

(1)数据记录筛选:

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

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

sql="selecttop10*from数据表where字段名orderby字段名[desc]"

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

sql="select*from数据表where字段名between值1and值2"

(2)更新数据记录:

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

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

(3)删除数据记录:

sql="deletefrom数据表where条件表达式"

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

(4)添加数据记录:

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

sql="insertinto目标数据表select*from源数据表" (把源数据表的记录添加到目标数据表)

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

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

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

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

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

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

引用以上函数的方法:

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

setrs=conn.excute(sql)

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

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

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

例:

CREATETABLEtab01(namevarchar(50),datetimedefaultnow())

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

4.记录集对象的方法:

rs.movenext             将记录指针从当前的位置向下移一行

rs.moveprevious         将记录指针从当前的位置向上移一行

rs.movefirst            将记录指针移到数据表第一行

rs.movelast             将记录指针移到数据表最后一行

rs.absoluteposition=N   将记录指针移到数据表第N行

rs.absolutepage=N       将记录指针移到第N页的第一行

rs.pagesize=N           设置每页为N条记录

rs.pagecount            根据pagesize的设置返回总页数

rs.recordcount          返回记录总数

rs.bof                  返回记录指针是否超出数据表首端,true表示是,false为否

rs.eof                  返回记录指针是否超出数据表末端,true表示是,false为否

rs.delete               删除当前记录,但记录指针不会向下移动

rs.addnew               添加记录到数据表末端

rs.update               更新数据表记录

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

Recordset对象方法

Open方法

recordset.OpenSource,ActiveConnection,CursorType,LockType,Options

Source

Recordset对象可以通过Source属性来连接Command对象。

Source参数可以是一个Command对象名称、一段SQL命令、一个指定的数据表名称或是一个StoredProcedure。

假如省略这个参数,系统则采用Recordset对象的Source属性。

ActiveConnection

Recordset对象可以通过ActiveConnection属性来连接Connection对象。

这里的ActiveConnection可以是一个Connection对象或是一串包含数据库连接信息(ConnectionString)的字符串参数。

CursorType

Recordset对象Open方法的CursorType参数表示将以什么样的游标类型启动数据,包括adOpenForwardOnly、adOpenKeyset、adOpenDynamic及adOpenStatic,分述如下:

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

常数                 常数值          说明

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

adOpenForwardOnly      0        缺省值,启动一个只能向前移动的游标(ForwardOnly)。

adOpenKeyset           1        启动一个Keyset类型的游标。

adOpenDynamic          2        启动一个Dynamic类型的游标。

adOpenStatic           3        启动一个Static类型的游标。

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

以上几个游标类型将直接影响到Recordset对象所有的属性和方法,以下列表说明他们之间的区别。

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

Recordset属性    adOpenForwardOnly   adOpenKeyset   adOpenDynamic   adOpenStatic

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

AbsolutePage          不支持           不支持         可读写           可读写

AbsolutePosition      不支持           不支持         可读写           可读写

ActiveConnection      可读写           可读写         可读写           可读写

BOF                   只读             只读           只读             只读

Bookmark              不支持           不支持         可读写           可读写

CacheSize             可读写           可读写         可读写           可读写

CursorLocation        可读写           可读写         可读写           可读写

CursorType            可读写           可读写         可读写           可读写

EditMode              只读             只读           只读             只读

EOF                   只读             只读           只读             只读

Filter                可读写           可读写         可读写           可读写

LockType              可读写           可读写         可读写           可读写

MarshalOptions        可读写           可读写         可读写           可读写

MaxRecords            可读写           可读写         可读写           可读写

PageCount             不支持           不支持         只读             只读

PageSize              可读写           可读写         可读写           可读写

RecordCount           不支持           不支持         只读             只读

Source                可读写           可读写         可读写           可读写

State                 只读             只读           只读             只读

Status                只读             只读           只读             只读

AddNew                支持             支持           支持             支持

CancelBatch           支持             支持           支持             支持

CancelUpdate          支持             支持           支持             支持

Clone                 不支持           不支持

Close                 支持             支持           支持             支持

Delete                支持             支持           支持             支持

GetRows               支持             支持           支持             支持

Move                  不支持           支持           支持             支持

MoveFirst             支持             支持           支持             支持

MoveLast              不支持           支持           支持             支持

MoveNext              支持             支持           支持             支持

MovePrevious          不支持           支持           支持             支持

NextRecordset         支持             支持           支持             支持

Open                  支持             支持           支持             支持

Requery               支持             支持           支持             支持

Resync                不支持           不支持         支持             支持

Supports              支持             支持           支持             支持

Update                支持             支持           支持             支持

UpdateBatch           支持             支持           支持             支持

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

其中NextRecordset方法并不适用于MicrosoftAccess数据库。

LockType

Recordset对象Open方法的LockType参数表示要采用的Lock类型,如果忽略这个参数,那么系统会以Recordset对象的LockType属性为预设值。

LockType参数包含adLockReadOnly、adLockPrssimistic、adLockOptimistic及adLockBatchOptimistic等,分述如下:

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

常数                 常数值             说明

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

adLockReadOnly          1          缺省值,Recordset对象以只读方式启动,无法运行AddNew、Update及Delete等方法

adLockPrssimistic       2          当数据源正在更新时,系统会暂时锁住其他用户的动作,以保持数据一致性。

adLockOptimistic        3          当数据源正在更新时,系统并不会锁住其他用户的动作,其他用户可以对数据进行增、删、改的操作。

adLockBatchOptimistic   4          当数据源正在更新时,其他用户必须将CursorLocation属性改为adUdeClientBatch才能对数据进行增、

                                    删、改的操作。

 

DB2提供了关连式资料库的查询语言SQL(StructuredQueryLanguage),是一种非常口语化、既易学又易懂的语法。

此一语言几乎是每个资料库系统都必须提供的,用以表示关连式的操作,包含了资料的定义(DDL)以及资料的处理(DML)。

SQL原来拼成SEQUEL,这语言的原型以“系统R“的名字在IBM圣荷西实验室完成,经过IBM内部及其他的许多使用性及效率测试,其结果相当令人满意,并决定在系统R的技术基础发展出来IBM的产品。

而且美国国家标准学会(ANSI)及国际标准化组织(ISO)在1987遵循一个几乎是以IBMSQL为基础的标准关连式资料语言定义。

一、资料定义DDL(DataDefinitionLanguage)

资料定语言是指对资料的格式和形态下定义的语言,他是每个资料库要建立时候时首先要面对的,举凡资料分哪些表格关系、表格内的有什麽栏位主键、表格和表格之间互相参考的关系等等,都是在开始的时候所必须规划好的。

1、建表格:

CREATETABLEtable_name(

column1DATATYPE[NOTNULL][NOTNULLPRIMARYKEY],

column2DATATYPE[NOTNULL],

...)

说明:

 

DATATYPE--是资料的格式,详见表。

NUTNULL--可不可以允许资料有空的(尚未有资料填入)。

PRIMARYKEY--是本表的主键。

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

 

-- 作者:

belin2000

-- 发布时间:

2004-6-822:

08:

51

-- 

2、更改表格 

ALTERTABLEtable_name

ADDCOLUMNcolumn_nameDATATYPE

说明:

增加一个栏位(没有删除某个栏位的语法。

ALTERTABLEtable_name

ADDPRIMARYKEY(column_name)

说明:

更改表得的定义把某个栏位设为主键。

ALTERTABLEtable_name

DROPPRIMARYKEY(column_name)

说明:

把主键的定义删除。

3、建立索引 

CREATEINDEXindex_nameONtable_name(column_name)

说明:

对某个表格的栏位建立索引以增加查询时的速度。

4、删除 

DROPtable_name

DROPindex_name

二、的资料形态DATATYPEs

smallint

16位元的整数。

interger

32位元的整数。

decimal(p,s)

p精确值和s大小的十进位整数,精确值p是指全部有几个数(digits)大小值,s是指小数

点後有几位数。

如果没有特别指定,则系统会设为p=5;s=0。

float

32位元的实数。

double

64位元的实数。

char(n)

n长度的字串,n不能超过254。

varchar(n)

长度不固定且其最大长度为n的字串,n不能超过4000。

graphic(n)

和char(n)一样,不过其单位是两个字元double-bytes,n不能超过127。

这个形态是为

了支援两个字元长度的字体,例如中文字。

vargraphic(n)

可变长度且其最大长度为n的双字元字串,n不能超过2000。

date

包含了年份、月份、日期。

time

包含了小时、分钟、秒。

timestamp

包含了年、月、日、时、分、秒、千分之一秒。

三、资料操作DML(DataManipulationLanguage)

资料定义好之後接下来的就是资料的操作。

资料的操作不外乎增加资料(insert)、查询资料(query)、更改资料(update)、删除资料(delete)四种模式,以下分别介绍他们的语法:

1、增加资料:

INSERTINTOtable_name(column1,column2,...)

valueS(value1,value2,...)

说明:

1.若没有指定column系统则会按表格内的栏位顺序填入资料。

2.栏位的资料形态和所填入的资料必须吻合。

3.table_name也可以是景观view_name。

INSERTINTOtable_name(column1,column2,...)

SELECTcolumnx,columny,...FROManother_table

说明:

也可以经过一个子查询(subquery)把别的表格的资料填入。

2、查询资料:

基本查询

SELECTcolumn1,columns2,...

FROMtable_name

说明:

把table_name的特定栏位资料全部列出来

SELECT*

FROMtable_name

WHEREcolumn1=xxx

[ANDcolumn2>yyy][ORcolumn3<>zzz]

说明:

1.\'*\'表示全部的栏位都列出来。

2.WHERE之後是接条件式,把符合条件的资料列出来。

SELECTcolumn1,column2

FROMtable_name

ORDERBYcolumn2[DESC]

说明:

ORDERBY是指定以某个栏位做排序,[DESC]是指从大到小排列,若没有指明,则是从小到大

排列

组合查询

组合查询是指所查询得资料来源并不只有单一的表格,而是联合一个以上的

表格才能够得到结果的。

SELECT*

FROMtable1,table2

WHEREtable1.colum1=table2.column1

说明:

1.查询两个表格中其中column1值相同的资料。

2.当然两个表格相互比较的栏位,其资料形态必须相同。

3.一个复杂的查询其动用到的表格可能会很多个。

整合性的查询:

SELECTCOUNT(*)

FROMtable_name

WHEREcolumn_name=xxx

说明:

查询符合条件的资料共有几笔。

SELECTSUM(column1)

FROMtable_name

说明:

1.计算出总和,所选的栏位必须是可数的数字形态。

2.除此以外还有AVG()是计算平均、MAX()、MIN()计算最大最小值的整合性查询。

SELECTcolumn1,AVG(column2)

FROMtable_name

GROUPBYcolumn1

HAVINGAVG(column2)>xxx

说明:

1.GROUPBY:

以column1为一组计算column2的平均值必须和AVG、SUM等整合性查询的关键字

一起使用。

2.HAVING:

必须和GROUPBY一起使用作为整合性的限制。

复合性的查询

SELECT*

FROMtable_name1

WHEREEXISTS(

SELECT*

FROMtable_name2

WHEREconditions)

说明:

1.WHERE的conditions可以是另外一个的query。

2.EXISTS在此是指存在与否。

SELECT*

FROMtable_name1

WHEREc

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > PPT模板 > 节日庆典

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1