仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 623|回复: 6
打印 上一主题 下一主题

[学习教程] ASP编程:SQL 语法参考手册

[复制链接]
小妖女 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:48:35 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
缺点:安全性不是太差了,还行,只要你充分利用系统自带的工具;唯一缺点就是执行效率慢,如何进行网站优化以后,效果会比较好。参考|参考手册|语法|语法参考DB2供应了干系式材料库的查询言语SQL(StructuredQueryLanguage),是一种十分白话化、既易学又易懂的语法。此一言语几近是每一个材料库体系都必需供应的,用以暗示干系式的操纵,包括了材料的界说(DDL)和材料的处置(DML)。SQL本来拼成SEQUEL,这言语的原型以“体系R“的名字在IBM圣荷西实行室完成,经由IBM外部及其他的很多利用性及效力测试,其了局相称使人中意,并决意在体系R的手艺基本开展出来IBM的产物。而且美国国度尺度学会(ANSI)及国际尺度化构造(ISO 在1987遵守一个几近是以IBMSQL为基本的尺度干系式材料言语界说。
材料界说DDL(DataDefinitionLanguage)
材料定言语是指对材料的格局和形状下界说的言语,他是每一个材料库要创建时分时起首要面临的,举凡材料分哪些表格干系、表格内的有什麽栏位主键、表格和表格之间相互参考的干系等等,都是在入手下手的时分所必需计划好的。

建表格:
语法:
CREATETABLEtable_name(
column1DATATYPE[NOTNULL][NOTNULLPRIMARYKEY],
column2DATATYPE[NOTNULL],
...)
申明 
DATATYPE--是材料的格局,详见表。
NUTNULL--可不成以同意材料有空的(还没有有材料填进)。
PRIMARYKEY--是本表的主键。

变动表格 
ALTERTABLEtable_name
ADDCOLUMNcolumn_nameDATATYPE
申明 增添一个栏位(没有删除某个栏位的语法)
ALTERTABLEtable_name
ADDPRIMARYKEY(column_name)
申明 变动表得的界说把某个栏位设为主键
ALTERTABLEtable_name
DROPPRIMARYKEY(column_name)
申明 把主键的界说删除。

创建索引 
CREATEINDEXindex_nameONtable_name(column_name)
申明 对某个表格的栏位创建索引以增添查询时的速率

删除 
DROPtable_name
DROPindex_name

材料形状DATATYPE
SQL的材料形状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)四种形式,以下分离先容他们的语法:

增添材料:
INSERTINTOtable_name(column1,column2,...)VALUES(value1,value2,...)
申明:
1.若没有指定column体系则会按表格内的栏位按次填进材料
2.栏位的材料形状和所填进的材料必需符合
3.table_name也能够是景不雅view_name

INSERTINTOtable_name(column1,column2,...)SELECTcolumnx,columny,...FROManother_table
申明:也能够经由一个子查询(subquery)把其余表格的材料填进

查询材料:
基础查询
SELECTcolumn1,columns2,...FROMtable_name
申明:把table_name的特定栏位材料全体列出来
SELECT*
FROMtable_name
WHEREcolumn1=xxx
[ANDcolumn2>yyy][ORcolumn3zzz]
申明:
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
WHEREcolumn1IN(
SELECTcolumn1
FROMtable_name2
WHEREconditions)
申明 
1.IN後面接的是一个汇合,暗示column1存在汇合内里
2.SELECT出来的材料形状必需切合column1

其他查询
SELECT*
FROMtable_name1
WHEREcolumn1LIKEx%
申明:
1.LIKE必需和後面的x%相照应暗示以x为开首的字串
SELECT*
FROMtable_name1
WHEREcolumn1IN(xxx,yyy,..)
申明 
1.IN後面接的是一个汇合,暗示column1存在汇合内里
SELECT*
FROMtable_name1
WHEREcolumn1BETWEENxxANDyy
申明 
1.BETWEEN暗示column1的值介於xx和yy之间

变动材料:
UPDATEtable_name
SETcolumn1=xxx
WHEREconditoins
申明:
1.变动某个栏位设定其值为xxx
2.conditions是所要切合的前提、若没有WHERE则
全部table的谁人栏位城市全体被变动

删除材料:
DELETEFROMtable_name
WHEREconditions
申明:删除切合前提的材料
</p>因为现在数据库都使用标准的SQL语言对数据库进行管理,所以如果是标准SQL语言,两者基本上都可以通用的。SQLServer还有更多的扩展,可以用存储过程,数据库大小无极限限制。
柔情似水 该用户已被删除
沙发
发表于 2015-1-28 16:04:19 来自手机 | 只看该作者
我想问如何掌握学习节奏(先学什么再学什么)最好详细点?
冷月葬花魂 该用户已被删除
板凳
发表于 2015-2-13 21:01:24 | 只看该作者
运用经典的例子。并且自己可以用他来实现一些简单的系统。如果可以对他进行进一步的修改,找出你觉得可以提高性能的地方,加上自己的设计,那就更上一个层次了,也就会真正地感到有所收获。
不帅 该用户已被删除
地板
发表于 2015-3-4 01:12:03 | 只看该作者
以上是语言本身的弱点,在功能方面ASP同样存在问题,第一是功能太弱,一些底层操作只能通过组件来完成,在这点上是远远比不上PHP/JSP,其次就是缺乏完善的纠错/调试功能,这点上ASP/PHP/JSP差不多。
再现理想 该用户已被删除
5#
发表于 2015-3-11 15:22:12 | 只看该作者
代码逻辑混乱,难于管理:由于ASP是脚本语言混合html编程,所以你很难看清代码的逻辑关系,并且随着程序的复杂性增加,使得代码的管理十分困难,甚至超出一个程序员所能达到的管理能力,从而造成出错或这样那样的问题。
愤怒的大鸟 该用户已被删除
6#
发表于 2015-3-19 01:00:30 | 只看该作者
那么,ASP.Net有哪些改进呢?
深爱那片海 该用户已被删除
7#
发表于 2015-3-27 00:10:40 | 只看该作者
如何更好的使自己的东西看上去很不错等等。其实这些都不是问题的实质,我们可以在实践中不断提升自己,不断充实自己。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-9 17:22

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表