仓酷云

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

[学习教程] MSSQL网页设计SQL中心语句(十分有用的几个技能)

[复制链接]
跳转到指定楼层
楼主
发表于 2015-1-16 22:39:30 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

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

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

x
我们分析上面的两个操作,都有一个“删除数据”的过程。技能|语句_ArticleContent1_lblContent>拔出数据

向表中增加一个新纪录,你要利用SQLINSERT语句。这里有一个怎样利用这类语句的例子:

INSERTmytable(mycolumn)VALUES(‘somedata’)

这个语句把字符串’somedata’拔出表mytable的mycolumn字段中。将要被拔出数据的字段的名字在第一个括号中指定,实践的数据在第二个括号中给出。

INSERT语句的完全句法以下:

INSERT[INTO]{table_name|view_name}[(column_list)]{DEFAULTVALUES|

Values_list|select_statement}

假如一个表有多个字段,经由过程把字段名和字段值用逗号离隔,你能够向一切的字段中拔出数据。假定表mytable有三个字段first_column,second_column,和third_column。上面的INSERT语句增加了一条三个字段都有值的完全纪录:

INSERTmytable(first_column,second_column,third_column)

VALUES(‘somedata’,’somemoredata’,’yetmoredata’)

注重

你可使用INSERT语句向文本型字段中拔出数据。可是,假如你必要输出很长的字符串,你应当利用WRITETEXT语句。这部份内容对本书来讲太初级了,因而不加会商。要懂得更多的信息,请参考MicrosoftSQLSever的文档。

假如你在INSERT语句中只指定两个字段和数据会怎样呢?换句话说,你向一个表中拔出一条新纪录,但有一个字段没有供应数据。在这类情形下,有上面的四种大概:

假如该字段有一个缺省值,该值会被利用。比方,假定你拔出新纪录时没有给字段third_column供应数据,而这个字段有一个缺省值’somevalue’。在这类情形下,当新纪录创建时会拔出值’somevalue’。

假如该字段能够承受空值,并且没出缺省值,则会被拔出空值。

假如该字段不克不及承受空值,并且没出缺省值,就会呈现毛病。你会收到毛病信息:

Thecolumnintablemytablemaynotbenull.

最初,假如该字段是一个标识字段,那末它会主动发生一个新值。当你向一个有标识字段的表中拔出新纪录时,只需疏忽该字段,标识字段会给本人赋一个新值。

注重

向一个有标识字段的表中拔出新纪录后,你能够用SQL变量@@identity来会见新纪录

的标识字段的值。思索以下的SQL语句:

INSERTmytable(first_column)VALUES(‘somevalue’)

INSERTanothertable(another_first,another_second)

VALUES(@@identity,’somevalue’)

假如表mytable有一个标识字段,该字段的值会被拔出表anothertable的another_first字段。这是由于变量@@identity老是保留最初一次拔出标识字段的值。

字段another_first应当与字段first_column有不异的数据范例。可是,字段another_first不克不及是应当标识字段。Another_first字段用来保留字段first_column的值。

删除纪录

要从表中删除一个或多个纪录,必要利用SQLDELETE语句。你能够给DELETE语句供应WHERE子句。WHERE子句用来选择要删除的纪录。比方,上面的这个DELETE语句只删除字段first_column的值即是’DeleteMe’的纪录:

DELETEmytableWHEREfirst_column=’DeltetMe’

DELETE语句的完全句法以下:

DELETE[FROM]{table_name|view_name}[WHEREclause]

在SQLSELECT语句中可使用的任何前提都能够在DELECT语句的WHERE子句中利用。比方,上面的这个DELETE语句只删除那些first_column字段的值为’goodbye’或second_column字段的值为’solong’的纪录:

DELETEmytableWHEREfirst_column=’goodby’ORsecond_column=’solong’

假如你不给DELETE语句供应WHERE子句,表中的一切纪录都将被删除。你不该该有这类设法。假如你想删除应当表中的一切纪录,应利用第十章所讲的TRUNCATETABLE语句。

注重

为何要用TRUNCATETABLE语句取代DELETE语句?当你利用TRUNCATETABLE语句时,纪录的删除是不作纪录的。也就是说,这意味着TRUNCATETABLE要比DELETE快很多。

更新纪录

要修正表中已存在的一条或多笔记录,应利用SQLUPDATE语句。同DELETE语句一样,UPDATE语句可使用WHERE子句来选择更新特定的纪录。请看这个例子:

UPDATEmytableSETfirst_column=’Updated!’WHEREsecond_column=’UpdateMe!’

这个UPDATE语句更新一切second_column字段的值为’UpdateMe!’的纪录。对一切被选中的纪录,字段first_column的值被置为’Updated!’。

上面是UPDATE语句的完全句法:

UPDATE{table_name|view_name}SET[{table_name|view_name}]

{column_list|variable_list|variable_and_column_list}

[,{column_list2|variable_list2|variable_and_column_list2}…

[,{column_listN|variable_listN|variable_and_column_listN}]]

[WHEREclause]

注重

你能够对文本型字段利用UPDATE语句。可是,假如你必要更新很长的字符串,应利用UPDATETEXT语句。这部份内容对本书来讲太初级了,因而不加会商。要懂得更多的信息,请参考MicrosoftSQLSever的文档。

假如你不供应WHERE子句,表中的一切纪录都将被更新。偶然这是有效的。比方,假如你想把表titles中的一切书的代价更加,你可使用以下的UPDATE语句:

你也能够同时更新多个字段。比方,上面的UPDATE语句同时更新first_column,second_column,和third_column这三个字段:

UPDATEmytableSETfirst_column=’Updated!’

Second_column=’Updated!’

Third_column=’Updated!’

WHEREfirst_column=’UpdateMe1’

技能

SQL疏忽语句中过剩的空格。你能够把SQL语句写成任何你最简单读的格局。

用SELECT创立纪录和表

你大概已注重到,INSERT语句与DELETE语句和UPDATE语句有一点分歧,它一次只操纵一个纪录。但是,有一个办法可使INSERT语句一次增加多个纪录。要作到这一点,你必要把INSERT语句与SELECT语句分离起来,象如许:

INSERTmytable(first_column,second_column)

SELECTanother_first,another_second

FROManothertable

WHEREanother_first=’CopyMe!’

这个语句从anothertable拷贝纪录到mytable.只要表anothertable中字段another_first的值为’CopyMe!’的纪录才被拷贝。

当为一个表中的纪录创建备份时,这类情势的INSERT语句长短常有效的。在删除一个表中的纪录之前,你能够先用这类办法把它们拷贝到另外一个表中。

假如你必要拷贝全部表,你可使用SELECTINTO语句。比方,上面的语句创立了一个名为newtable的新表,该表包括表mytable的一切数据:

SELECT*INTOnewtableFROMmytable

你也能够指定只要特定的字段被用来创立这个新表。要做到这一点,只需在字段列表中指定你想要拷贝的字段。别的,你可使用WHERE子句来限定拷贝到新表中的纪录。上面的例子只拷贝字段second_columnd的值即是’CopyMe!’的纪录的first_column字段。

SELECTfirst_columnINTOnewtable

FROMmytable

WHEREsecond_column=’CopyMe!’

利用SQL修正已创建的表是很坚苦的。比方,假如你向一个表中增加了一个字段,没有简单的举措往复除它。别的,假如你不当心把一个字段的数据范例给错了,你将没有举措改动它。可是,利用本节中报告的SQL语句,你能够绕过这两个成绩。

比方,假定你想从一个表中删除一个字段。利用SELECTINTO语句,你能够创立该表的一个拷贝,但不包括要删除的字段。这使你既删除该字段,又保存了不想删除的数据。

假如你想改动一个字段的数据范例,你能够创立一个包括准确数据范例字段的新表。创立好该表后,你就能够分离利用UPDATE语句和SELECT语句,把本来表中的一切数据拷贝到新表中。经由过程这类办法,你既能够修正表的布局,又能保留原本的数据。mysql使用内部操作字符集gbk来进行操作,即执行"SELECT*FROMtestWHEREname=xxxor1=1/*LIMIT1";从而注入成功
小女巫 该用户已被删除
9#
发表于 2015-3-24 15:52:25 | 只看该作者
having子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having条件显示特定的组,也可以使用多个分组标准进行分组。
第二个灵魂 该用户已被删除
8#
发表于 2015-3-17 17:21:03 | 只看该作者
现在是在考虑:如果写到服务器端,我一下搞他个10个存储过程导过去,那久之服务器不就成垃圾箱了吗?即便优化了我的中间层.
再见西城 该用户已被删除
7#
发表于 2015-3-11 01:07:55 | 只看该作者
原理很简单,对要求长时间计算某一时间点的报表生成和防用户操作错误很有帮助。但是比起Oracle10g的闪回技术还是细粒度不够。可惜!
莫相离 该用户已被删除
6#
发表于 2015-3-1 23:22:58 | 只看该作者
groupby子句可以将查询结果分组,并返回行的汇总信息Oracle按照groupby子句中指定的表达式的值分组查询结果。
蒙在股里 该用户已被删除
5#
发表于 2015-2-11 06:57:16 | 只看该作者
如果是将来做数据库的开发设计,就应该详细学习T-SQL的各种细节,包括T-SQL的程序设计、存储过程、触发器以及具体使用某个开发语言来访问数据库。
地板
 楼主| 发表于 2015-2-5 06:43:09 | 只看该作者
我是新手,正在学习数据库和操作系统,深感理论的泛广,唯有一步一步来,但是又感觉时间不够,收集了很多资料却总是没能认真的看完,希望有一个讨论板块,大家共同解决,共同分享,共同努力
深爱那片海 该用户已被删除
板凳
发表于 2015-1-27 10:35:56 | 只看该作者
相信各位对数据库和怎么样学习数据库都有一些经验和看法,也会有人走了一些弯路总结出自己的经验来,希望大家能把各自的看法和经验拿出来分享,给别人一份帮助,给自己一份快乐
灵魂腐蚀 该用户已被删除
沙发
发表于 2015-1-19 20:46:15 | 只看该作者
以前的DTS轻盈简单。但是现在的SSIS虽然功能强大了很多,但是总是让人感觉太麻烦。看看论坛中询问SSIS的贴子就知道。做的功能太强大了,往往会有很多用户不会用了
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-12-31 23:18

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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