搜集SQL常用的操作语句 MySql常用操作SQL语句汇总

\u641c\u96c6SQL\u5e38\u7528\u7684\u64cd\u4f5c\u8bed\u53e5

SQL\u5e38\u7528\u8bed\u53e5\u4e00\u89c8
(1)\u6570\u636e\u8bb0\u5f55\u7b5b\u9009\uff1a
sql="select*from\u6570\u636e\u8868where\u5b57\u6bb5\u540d=\u5b57\u6bb5\u503corderby\u5b57\u6bb5\u540d[desc]"
sql="select*from\u6570\u636e\u8868where\u5b57\u6bb5\u540dlike'%\u5b57\u6bb5\u503c%'orderby\u5b57\u6bb5\u540d[desc]"
sql="selecttop10*from\u6570\u636e\u8868where\u5b57\u6bb5\u540dorderby\u5b57\u6bb5\u540d[desc]"
sql="select*from\u6570\u636e\u8868where\u5b57\u6bb5\u540din('\u503c1','\u503c2','\u503c3')"
sql="select*from\u6570\u636e\u8868where\u5b57\u6bb5\u540dbetween\u503c1and\u503c2"
(2)\u66f4\u65b0\u6570\u636e\u8bb0\u5f55\uff1a
sql="update\u6570\u636e\u8868set\u5b57\u6bb5\u540d=\u5b57\u6bb5\u503cwhere\u6761\u4ef6\u8868\u8fbe\u5f0f"
sql="update\u6570\u636e\u8868set\u5b57\u6bb51=\u503c1,\u5b57\u6bb52=\u503c2\u2026\u2026\u5b57\u6bb5n=\u503cnwhere\u6761\u4ef6\u8868\u8fbe\u5f0f"
(3)\u5220\u9664\u6570\u636e\u8bb0\u5f55\uff1a
sql="deletefrom\u6570\u636e\u8868where\u6761\u4ef6\u8868\u8fbe\u5f0f"
sql="deletefrom\u6570\u636e\u8868"(\u5c06\u6570\u636e\u8868\u6240\u6709\u8bb0\u5f55\u5220\u9664)
(4)\u6dfb\u52a0\u6570\u636e\u8bb0\u5f55\uff1a
sql="insertinto\u6570\u636e\u8868(\u5b57\u6bb51,\u5b57\u6bb52,\u5b57\u6bb53\u2026)values(\u503c1,\u503c2,\u503c3\u2026)"
sql="insertinto\u76ee\u6807\u6570\u636e\u8868select*from\u6e90\u6570\u636e\u8868"(\u628a\u6e90\u6570\u636e\u8868\u7684\u8bb0\u5f55\u6dfb\u52a0\u5230\u76ee\u6807\u6570\u636e\u8868)
(5)\u6570\u636e\u8bb0\u5f55\u7edf\u8ba1\u51fd\u6570\uff1a
AVG(\u5b57\u6bb5\u540d)\u5f97\u51fa\u4e00\u4e2a\u8868\u683c\u680f\u5e73\u5747\u503c
COUNT(*|\u5b57\u6bb5\u540d)\u5bf9\u6570\u636e\u884c\u6570\u7684\u7edf\u8ba1\u6216\u5bf9\u67d0\u4e00\u680f\u6709\u503c\u7684\u6570\u636e\u884c\u6570\u7edf\u8ba1
MAX(\u5b57\u6bb5\u540d)\u53d6\u5f97\u4e00\u4e2a\u8868\u683c\u680f\u6700\u5927\u7684\u503c
MIN(\u5b57\u6bb5\u540d)\u53d6\u5f97\u4e00\u4e2a\u8868\u683c\u680f\u6700\u5c0f\u7684\u503c
SUM(\u5b57\u6bb5\u540d)\u628a\u6570\u636e\u680f\u7684\u503c\u76f8\u52a0
\u5f15\u7528\u4ee5\u4e0a\u51fd\u6570\u7684\u65b9\u6cd5\uff1a
sql="selectsum(\u5b57\u6bb5\u540d)as\u522b\u540dfrom\u6570\u636e\u8868where\u6761\u4ef6\u8868\u8fbe\u5f0f"
setrs=conn.excute(sql)
\u7528rs("\u522b\u540d")\u83b7\u53d6\u7edf\u7684\u8ba1\u503c\uff0c\u5176\u5b83\u51fd\u6570\u8fd0\u7528\u540c\u4e0a\u3002
(5)\u6570\u636e\u8868\u7684\u5efa\u7acb\u548c\u5220\u9664\uff1a
CREATETABLE\u6570\u636e\u8868\u540d\u79f0(\u5b57\u6bb51\u7c7b\u578b1(\u957f\u5ea6),\u5b57\u6bb52\u7c7b\u578b2(\u957f\u5ea6)\u2026\u2026)
\u4f8b\uff1aCREATETABLEtab01
(namevarchar
(50),
datetimedefaultnow
())
DROPTABLE\u6570\u636e\u8868\u540d\u79f0(\u6c38\u4e45\u6027\u5220\u9664\u4e00\u4e2a\u6570\u636e\u8868)
4.\u8bb0\u5f55\u96c6\u5bf9\u8c61\u7684\u65b9\u6cd5\uff1a
rs.movenext\u5c06\u8bb0\u5f55\u6307\u9488\u4ece\u5f53\u524d\u7684\u4f4d\u7f6e\u5411\u4e0b\u79fb\u4e00\u884c
rs.moveprevious\u5c06\u8bb0\u5f55\u6307\u9488\u4ece\u5f53\u524d\u7684\u4f4d\u7f6e\u5411\u4e0a\u79fb\u4e00\u884c
rs.movefirst\u5c06\u8bb0\u5f55\u6307\u9488\u79fb\u5230\u6570\u636e\u8868\u7b2c\u4e00\u884c
rs.movelast\u5c06\u8bb0\u5f55\u6307\u9488\u79fb\u5230\u6570\u636e\u8868\u6700\u540e\u4e00\u884c
rs.absoluteposition=N\u5c06\u8bb0\u5f55\u6307\u9488\u79fb\u5230\u6570\u636e\u8868\u7b2cN\u884c
rs.absolutepage=N\u5c06\u8bb0\u5f55\u6307\u9488\u79fb\u5230\u7b2cN\u9875\u7684\u7b2c\u4e00\u884c
rs.pagesize=N\u8bbe\u7f6e\u6bcf\u9875\u4e3aN\u6761\u8bb0\u5f55
rs.pagecount\u6839\u636epagesize\u7684\u8bbe\u7f6e\u8fd4\u56de\u603b\u9875\u6570
rs.recordcount\u8fd4\u56de\u8bb0\u5f55\u603b\u6570
rs.bof\u8fd4\u56de\u8bb0\u5f55\u6307\u9488\u662f\u5426\u8d85\u51fa\u6570\u636e\u8868\u9996\u7aef\uff0ctrue\u8868\u793a\u662f\uff0cfalse\u4e3a\u5426
rs.eof\u8fd4\u56de\u8bb0\u5f55\u6307\u9488\u662f\u5426\u8d85\u51fa\u6570\u636e\u8868\u672b\u7aef\uff0ctrue\u8868\u793a\u662f\uff0cfalse\u4e3a\u5426
rs.delete\u5220\u9664\u5f53\u524d\u8bb0\u5f55\uff0c\u4f46\u8bb0\u5f55\u6307\u9488\u4e0d\u4f1a\u5411\u4e0b\u79fb\u52a8
rs.addnew\u6dfb\u52a0\u8bb0\u5f55\u5230\u6570\u636e\u8868\u672b\u7aef
rs.update\u66f4\u65b0\u6570\u636e\u8868\u8bb0\u5f55

MySQL\u7684\u5e38\u89c1\u64cd\u4f5c\u5728\u8fd9\u91cc\u5148\u505a\u4e00\u4e0b\u603b\u7ed3\uff0c\u5df2\u7ecf\u6574\u5408\u5230\u4ee3\u7801\u91cc\u9762\uff0c\u7ecf\u8fc7\u68c0\u9a8c\u65e0\u8bef\u3002
\u590d\u5236\u4ee3\u7801
\u4ee3\u7801\u5982\u4e0b:
/*\u521b\u5efa\u4e00\u4e2a\u6570\u636e\u5e93*/
create
database
xuning_test;
/*\u8bf4\u660e\u5f53\u65f6\u4f7f\u7528\u6570\u636e\u5e93\u5bf9\u8c61*/
use
xuning_test;
/*\u5411\u6570\u636e\u5e93\u4e2d\u6dfb\u52a0\u8868\u5e76\u4e14\u5b9a\u4e49\u8868\u7684\u7ed3\u6784*/
create
table
person(
id
int
not
null,
name
varchar(16)
not
null,
sex
varchar(16)
not
null,
age
int
not
null,
address
varchar(128)
not
null,
remark
varchar(512)
not
null
);
/*\u5411\u6570\u636e\u5e93\u7684\u8868\u4e2d\u63d2\u5165\u6570\u636e*/
insert
into
person
value
(1,'name_1','men',99,'beijing','This
is
a
frindsheep
boy'),
(2,'name_2','men',88,'shanghai','ok
great'),
(1,'name_3','man',77,'guangzhou','This
is
lickly'),
(1,'name_4','men',66,'beijing','This
is
a
frindsheep
boy'),
(1,'name_5','men',55,'beijing','you
dont
going
to
shool'),
(1,'name_6','man',44,'beijing','This
is
a
frindsheep
boy'),
(1,'name_7','men',33,'beijing','This
is
a
frindsheep
boy'),
(1,'name_8','man',22,'beijing',''),
(1,'name_9','men',11,'beijing','This
is
a
frindsheep
boy')
;
/*\u67e5\u8be2\u65f6\u5426\u6210\u529f\u63d2\u5165*/
select
*
from
person;
/*\u4e0b\u9762\u662f\u591a\u79cd\u67e5\u8be2\u65b9\u5f0f*/
/*\u6839\u636e\u5217\u7684\u540d\u79f0\u5c5e\u6027\u503c*/
select
name
from
person;
/*\u6dfb\u52a0\u6761\u4ef6-\u6839\u636e\u6027\u522b*/
select
name
from
person
where
sex
=
'men';
/*\u4e5f\u53ef\u4ee5\u7528\u6bd4\u8f83\u7b26\u4f5c\u4e3a\u6761\u4ef6--\u4e00\u5b9a\u9017\u53f7\u9694\u5f00*/
select
name,address
from
person
where
age
>
50;
/*\u770b\u505a\u5bf9\u8c61\u53bb\u4f7f\u7528\u6570\u636e\u5e93\u548c\u8868\u7684\u5173\u7cfb=---\u53cc\u8868\u5173\u8054--\u5bf9\u8c61\u5173\u7cfb\u4e00\u5b9a\u8981\u660e\u786e*/
select
xuning_test.person.name,
xuning_test.person.id,
xuning_test.person.age,
xuning_test.person.address
from
xuning_test.person,
test1.test_xuning
where
xuning_test.person.id
=
test1.test_xuning.id
;
/*\u4f7f\u7528\u8868\u7684\u522b\u540d\u8fdb\u884c\u67e5\u8be2*/
use
xuning_test;
select
c.name,sex
from
person
as
c
where
c.age
>
40
and
c.address='beijing';

结构化查询语言(Structured Query Language)简称SQL(发音:/ˈes kjuː ˈel/ "S-Q-L"),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。

一、插入(复制)表数据

1、INSERT INTO 语句:

(1)插入新的一行数

[sql] view plain copy;

INSERT INTO Persons VALUES ('Gates', 'Bill', 'Xuanwumen 10', 'Beijing');  

(2)在指定的列中插入数据

[sql] view plain copy;

INSERT INTO Persons (LastName, Address) VALUES ('Wilson', 'Champs-Elysees');  

2、SQL SELECT INTO 语句可用于创建表的备份复件

(1)在建表时复制所有数据

[sql] view plain copy;

create table userinfo_new as select * from userinfo;  

(2)在建表时复制部分数据

[sql] view plain copy;

create table userinfo_new1 as select id,username from userinfo;  

(3)在添加时复制所有数据

[sql] view plain copy;

insert into userinfo_new select * from userinfo;  

(4)在添加时复制部分数据

[sql] view plain copy;

insert into userinfo_new(id,username) select id,username from userinfo;  

二、修改表数据

Update 语句

(1)无条件更新

[sql] view plain copy;

update userinfo set userpwd='111',email='[email protected]';  

(2)有条件更新

[sql] view plain copy;

update userinfo set userpwd='123456' where username='xxx';  

三、删除表数据

1、DELETE 语句

(1)无条件删除

[sql] view plain copy;

dalete from userinfo;  

(2)有条件删除

[sql] view plain copy;

delete from userinfo where username='yyy';  

四、查询表数据

1、SELECT 语句:

(1)查询所有字段

[sql] view plain copy;

select * from users;  

(2)查询指定字段

[sql] view plain copy;

select username,salary from users;  

2、SELECT DISTINCT 语句

从 Company" 列中仅选取唯一不同的值,需要使用 SELECT DISTINCT 语句:

[sql] view plain copy;

SELECT DISTINCT Company FROM Orders;



SQL分类:
DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE)
DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)
DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)

首先,简要介绍基础语句:
1、创建数据库
CREATE DATABASE database-name
2、删除数据库
drop database dbname
3、备份sql server
--- 创建 备份数据的 device
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack
4、创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
5、删除新表
drop table tabname
6、增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
8、创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
9、创建视图:create view viewname as select statement
删除视图:drop view viewname
10、几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
11、说明:几个高级查询运算词
A: UNION 运算符
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
12、使用外连接
A、left outer join:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right outer join:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full outer join:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。

其次,大家来看一些不错的sql语句
1、复制表(只复制结构,源表名:a 新表名:b) (Access可用)
法一:select * into b from a where 1<>1
法二:select top 0 * into b from a

2、拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)
insert into b(a, b, c) select d,e,f from b;

3、跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用)
insert into b(a, b, c) select d,e,f from b in ‘具体数据库’ where 条件
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where..

4、子查询(表名1:a 表名2:b)
select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3)

5、显示文章、提交人和最后回复时间
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b

6、外连接查询(表名1:a 表名2:b)
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c

7、在线视图查询(表名1:a )
select * from (SELECT a,b,c FROM a) T where t.a > 1;

8、between的用法,between限制查询数据范围时包括了边界值,not between不包括
select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 数值1 and 数值2

9、in 的使用方法
select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’)

10、两张关联表,删除主表中已经在副表中没有的信息
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )

11、四表联查问题:
select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .....

12、日程安排提前五分钟提醒
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5

13、一条sql 语句搞定数据库分页
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段

14、前10条记录
select top 10 * form table1 where 范围

15、选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.)
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)

16、包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表
(select a from tableA ) except (select a from tableB) except (select a from tableC)

17、随机取出10条数据
select top 10 * from tablename order by newid()

18、随机选择记录
select newid()

19、删除重复记录
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...)

20、列出数据库里所有的表名
select name from sysobjects where type='U'

21、列出表里的所有的
select name from syscolumns where id=object_id('TableName')

22、列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。
select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0 end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type
显示结果:
type vender pcs
电脑 A 1
电脑 A 1
光盘 B 2
光盘 A 2
手机 B 3
手机 C 3

23、初始化表table1
TRUNCATE TABLE table1

24、选择从10到15的记录
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc
  
随机选择数据库记录的方法(使用Randomize函数,通过SQL语句实现)
  对存储在数据库中的数据来说,随机数特性能给出上面的效果,但它们可能太慢了些。你不能要求ASP“找个随机数”然后打印出来。实际上常见的解决方案是建立如下所示的循环:
Randomize
RNumber = Int(Rnd*499) +1
 
While Not objRec.EOF
If objRec("ID") = RNumber THEN
... 这里是执行脚本 ...
end if
objRec.MoveNext
Wend
 
  这很容易理解。首先,你取出1到500范围之内的一个随机数(假设500就是数据库内记录的总数)。然后,你遍历每一记录来测试ID 的值、检查其是否匹配RNumber。满足条件的话就执行由THEN 关键字开始的那一块代码。假如你的RNumber 等于495,那么要循环一遍数据库花的时间可就长了。虽然500这个数字看起来大了些,但相比更为稳固的企业解决方案这还是个小型数据库了,后者通常在一个数据库内就包含了成千上万条记录。这时候不就死定了?
  采用SQL,你就可以很快地找出准确的记录并且打开一个只包含该记录的recordset,如下所示:
Randomize
RNumber = Int(Rnd*499) + 1
 
SQL = "SELECT * FROM Customers WHERE ID = " & RNumber
 
set objRec = ObjConn.Execute(SQL)
Response.WriteRNumber & " = " & objRec("ID") & " " & objRec("c_email")
 
  不必写出RNumber 和ID,你只需要检查匹配情况即可。只要你对以上代码的工作满意,你自可按需操作“随机”记录。Recordset没有包含其他内容,因此你很快就能找到你需要的记录这样就大大降低了处理时间。
再谈随机数
  现在你下定决心要榨干Random 函数的最后一滴油,那么你可能会一次取出多条随机记录或者想采用一定随机范围内的记录。把上面的标准Random 示例扩展一下就可以用SQL应对上面两种情况了。
  为了取出几条随机选择的记录并存放在同一recordset内,你可以存储三个随机数,然后查询数据库获得匹配这些数字的记录:
SQL = "SELECT * FROM Customers WHERE ID = " & RNumber & " OR ID = " & RNumber2 & " OR ID = " & RNumber3
 
  假如你想选出10条记录(也许是每次页面装载时的10条链接的列表),你可以用BETWEEN 或者数学等式选出第一条记录和适当数量的递增记录。这一操作可以通过好几种方式来完成,但是 SELECT 语句只显示一种可能(这里的ID 是自动生成的号码):
SQL = "SELECT * FROM Customers WHERE ID BETWEEN " & RNumber & " AND " & RNumber & "+ 9"

  注意:以上代码的执行目的不是检查数据库内是否有9条并发记录。

 
随机读取若干条记录,测试过
Access语法:SELECT top 10 * From 表名 ORDER BY Rnd(id)
Sql server语法:select top n * from 表名 order by newid()
MySql语法:Select * From 表名 Order By rand() Limit n
Access左连接语法(最近开发要用左连接,Access帮助什么都没有,网上没有Access的SQL说明,只有自己测试, 现在记下以备后查)
语法:Select table1.fd1,table1,fd2,table2.fd2 From table1 left join table2 on table1.fd1,table2.fd1 where ...
使用SQL语句 用...代替过长的字符串显示
语法:
SQL数据库:select case when len(field)>10 then left(field,10)+'...' else field end as news_name,news_id from tablename
Access数据库:SELECT iif(len(field)>2,left(field,2)+'...',field) FROM tablename;
 
Conn.Execute说明
Execute方法
  该方法用于执行SQL语句。根据SQL语句执行后是否返回记录集,该方法的使用格式分为以下两种:
    1.执行SQL查询语句时,将返回查询得到的记录集。用法为:
    Set 对象变量名=连接对象.Execute("SQL 查询语言")
   Execute方法调用后,会自动创建记录集对象,并将查询结果存储在该记录对象中,通过Set方法,将记录集赋给指定的对象保存,以后对象变量就代表了该记录集对象。

    2.执行SQL的操作性语言时,没有记录集的返回。此时用法为:
    连接对象.Execute "SQL 操作性语句" [, RecordAffected][, Option]
      ·RecordAffected 为可选项,此出可放置一个变量,SQL语句执行后,所生效的记录数会自动保存到该变量中。通过访问该变量,就可知道SQL语句队多少条记录进行了操作。
      ·Option 可选项,该参数的取值通常为adCMDText,它用于告诉ADO,应该将Execute方法之后的第一个字符解释为命令文本。通过指定该参数,可使执行更高效。

·BeginTrans、RollbackTrans、CommitTrans方法
  这三个方法是连接对象提供的用于事务处理的方法。BeginTrans用于开始一个事物;RollbackTrans用于回滚事务;CommitTrans用于提交所有的事务处理结果,即确认事务的处理。
  事务处理可以将一组操作视为一个整体,只有全部语句都成功执行后,事务处理才算成功;若其中有一个语句执行失败,则整个处理就算失败,并恢复到处里前的状态。
  BeginTrans和CommitTrans用于标记事务的开始和结束,在这两个之间的语句,就是作为事务处理的语句。判断事务处理是否成功,可通过连接对象的Error集合来实现,若Error集合的成员个数不为0,则说明有错误发生,事务处理失败。Error集合中的每一个Error对象,代表一个错误信息。

常用的也不只这些:

1、说明:创建数据库
CREATE DATABASE database-name
2、说明:删除数据库
drop database dbname
3、说明:备份sql server
--- 创建 备份数据的 device
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack
4、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2... from tab_old definition only
5、说明:删除新表
drop table tabname
6、说明:增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
8、说明:创建索引:create [unique] index idxname on tabname(col....)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
9、说明:创建视图:create view viewname as select statement
删除视图:drop view viewname

Oh My Lady GaGa都是些什么答案啊。哎··凡是直接贴代码的都是不负责任的回答。有万能的SQL吗?什么是操作语言自己看看吧。要用到什么再去搜索下语法就好,不会就请教。常用的我要是给你写个 select * from table 你觉得有意思吗?SQL都是根据具体的业务数据来写的。你想要什么结果,就写什么语句。1、DDL(DATA DEFINITION LANGUAGE)数据描述语言
   DDL语句不会产生还原数据,所以删除的数据也是无法恢复的
  CREATE - to create objects in the database
  ALTER - alters the structure of the database
  DROP - delete objects from the database
  TRUNCATE - remove all records from a table, including all spaces allocated for the records are removed
  COMMENT - add comments to the data dictionary
  GRANT - gives user's access privileges to database
  REVOKE - withdraw access privileges given with the GRANT command
  2、DML(DATA MANIPULATION LANGUAGE)数据操纵鱼语言
  SELECT - retrieve data from the a database
  INSERT - insert data into a table
  UPDATE - updates existing data within a table
  DELETE - deletes all records from a table, the space for the records remain
  CALL - call a PL/SQL or Java subprogram
  EXPLAIN PLAN - explain access path to data
  LOCK TABLE - control concurrency
  3、DCL(DATA CONTROL LANGUAGE)数据控制语言
  COMMIT - save work done
  SAVEPOINT - identify a point in a transaction to which you can later roll back
  ROLLBACK - restore database to original since the last COMMIT
  SET TRANSACTION - Change transaction options like what rollback segment to use

  • SQL鏁版嵁搴甯哥敤璇硶閮芥湁鍝簺?
    绛旓細鍦ㄦ垜浠紑濮嬩箣鍓,鍏堜娇鐢–REATE TABLE璇彞鏉ュ垱寤轰竴涓〃(濡傚浘1鎵绀)銆侱DL璇彞瀵规暟鎹簱瀵硅薄濡傝〃銆佸垪鍜岃杩涜瀹氫箟銆傚畠浠苟涓嶅琛ㄤ腑鐨勮杩涜澶勭悊,杩欐槸鍥犱负DDL璇彞骞朵笉澶勭悊鏁版嵁搴撲腑瀹為檯鐨勬暟鎹傝繖浜涘伐浣滅敱鍙︿竴绫SQL璇彞鈥旀暟鎹鎿嶄綔璇█(DML)璇彞杩涜澶勭悊銆 SQL涓鏈夊洓绉嶅熀鏈殑DML鎿嶄綔:INSERT,SELECT,UPDATE鍜孌ELETE銆傜敱浜庤繖鏄...
  • sql甯哥敤璇彞,甯垜褰掔撼鍑烘潵,璋㈣阿
    绛旓細SQL璇彞鍏堝墠鍐欑殑鏃跺欙紝寰堝鏄撴妸涓浜涚壒娈婄殑鐢ㄦ硶蹇樿锛屾垜鐗规鏁寸悊浜嗕竴涓SQL璇彞鎿嶄綔銆備竴銆佸熀纭 1銆佽鏄庯細鍒涘缓鏁版嵁搴 CREATE DATABASE database-name 2銆佽鏄庯細鍒犻櫎鏁版嵁搴 drop database dbname 3銆佽鏄庯細澶囦唤sql server --- 鍒涘缓 澶囦唤鏁版嵁鐨 device USE master EXEC sp_addumpdevice 'disk', 'testBack...
  • 鏁版嵁搴撲腑甯哥敤鐨剆ql璇彞鏈夊摢浜
    绛旓細name, prod_price FROMProcts WHERE vend_idIN (鈥楧LL01鈥,鈥橞RS01鈥)ORDER BY prod_name;IN鎿嶄綔绗 SELECT prod_name FROMProcts WHERE NOTvend_id = 鈥楧LL01鈥橭RDER BY prod_name;NOT 鎿嶄綔绗 SELECT prod_name FROMProcts WHEREvend_id 鈥楧LL01鈥橭RDER BY prod_name;NOT 鎿嶄綔绗 ...
  • SQL鏈鍩烘湰鐨勮鍙鏄摢浜?
    绛旓細鎺屾彙SQL鍥涙潯鏈鍩烘湰鐨勬暟鎹鎿嶄綔璇彞:Insert,Select,Update鍜孌elete銆傜粌鎺屾彙SQL鏄暟鎹簱鐢ㄦ埛鐨勫疂璐佃储 瀵屻傚湪鏈枃涓,鎴戜滑灏嗗紩瀵间綘鎺屾彙鍥涙潯鏈鍩烘湰鐨勬暟鎹搷浣滆鍙?SQL鐨鏍稿績鍔熻兘?鏉ヤ緷娆′粙缁嶆瘮杈冩搷浣滅銆侀夋嫨鏂█浠ュ強涓夊奸昏緫銆傚綋浣犲畬鎴愯繖浜涘涔犲悗,鏄剧劧浣犲凡缁忓紑濮嬬畻鏄簿閫歋QL浜嗐傚湪鎴戜滑寮濮嬩箣鍓,鍏堜娇鐢–REATE TABLE璇彞鏉ュ垱寤...
  • sql璇彞鐢ㄤ粈涔堣鍙
    绛旓細SQL璇彞:涓昏鏄敱sql 鍏抽敭瀛楀姞sql瀵硅薄鐨勫悕绉扮粍鍚堣屾垚銆甯歌鐨剆ql鎿嶄綔璇彞鏈:insert(澧) update(鏀) delete(鍒犻櫎) select(鏌) where (鏉′欢闄愬畾鍏抽敭瀛)/*渚嬶細涓嬫枃灏嗗垱寤轰竴涓熀鏈殑sql鎿嶄綔璇彞*/---鍒涘缓鏁版嵁琛╟reate table A(keyId int,name varchar(20)) go---浣跨敤insert 鏂板鏁版嵁insert into...
  • 銆愭眰銆 涓浜甯哥敤鐨凷QL 娣诲姞 鏌ヨ 淇敼璇彞
    绛旓細(1) 鏁版嵁璁板綍绛涢夛細sql="select * from 鏁版嵁琛 where 瀛楁鍚=瀛楁鍊 order by 瀛楁鍚 "sql="select * from 鏁版嵁琛 where 瀛楁鍚 like 鈥%瀛楁鍊%鈥 order by 瀛楁鍚 "sql="select top 10 * from 鏁版嵁琛 where 瀛楁鍚 order by 瀛楁鍚 "sql="select * from 鏁版嵁琛 where 瀛楁鍚 in (...
  • 甯哥敤鏍囧噯SQL璇彞..
    绛旓細select璇彞锛堟煡璇㈣鍙ワ級锛歴elect from table1, table2 where table1.id *= table2.id//鏌ヨtable1鍜宼able2 涓璱d鐩哥瓑鐨勮褰 select stockname from table2//鏌ヨ琛╰able2涓瓧娈祎ockname涓殑鍊 insert璇彞锛堟彃鍏ヨ鍙ワ級锛歩nsert into table1(Stock_name,Stock_number) value (select Stockname , Stock...
  • mysql甯哥敤璇彞
    绛旓細MySql甯哥敤鎿嶄綔SQL璇彞姹囨绘彃鍏ヨ褰曢氳繃insert into杩涜锛孲QL璇彞鏍煎紡涓猴細渚嬪锛屽悜琛╯tuinfo鎻掑叆涓鏉¤褰曪紝SQL璇彞涓猴細娉ㄦ剰锛氫笂鏂规槸涓鏉QL璇彞锛屼负浜嗗彲璇绘ф崲琛岋紝璁颁綇涓鏉QL璇彞榛樿浠ュ垎鍙风粨灏俱侻ySQL鐨勫父瑙佹搷浣鍦ㄨ繖閲屽厛鍋氫竴涓嬫荤粨锛屽凡缁忔暣鍚堝埌浠g爜閲岄潰锛岀粡杩囨楠屾棤璇傝绠楀勾鏁 濡傛灉鎮ㄦ兂閫氳繃鐢熸棩鏉ヨ绠楄繖涓...
  • SQL鏁版嵁搴 鍩烘湰鐨勬搷浣滆鍙(澧炪佸垹銆佹敼銆佹煡)
    绛旓細渚嬪瓙 create table useInfo --鍒涘缓鐢ㄦ埛琛 (useId int identity(1,1) priamry key not null, --鐢ㄦ埛Id,璁句负涓婚敭锛屾爣璇嗗垪锛屼笉涓虹┖銆倁seName varchar(10) not null ,--鐢ㄦ埛鍚嶇О锛屼笉涓虹┖ useSex char(2) not null --鐢ㄦ埛鎬у埆锛屼笉涓虹┖ )go --鎵瑰鐞 insert into useInfo(useName,useSex) ...
  • sql鏌ヨ璇彞澶у叏
    绛旓細涓銆 绠鍗曟煡璇 绠鍗曠殑Transact-SQL鏌ヨ鍙寘鎷夋嫨鍒楄〃銆丗ROM瀛愬彞鍜學HERE瀛愬彞銆傚畠浠垎鍒鏄庢墍鏌ヨ鍒椼佹煡璇㈢殑琛ㄦ垨瑙嗗浘銆佷互鍙婃悳绱㈡潯浠剁瓑銆 渚嬪,涓嬮潰鐨勮鍙鏌ヨtesttable琛ㄤ腑濮撳悕涓"寮犱笁"鐨刵ickname瀛楁鍜宔mail瀛楁銆 SELECT nickname,email FROM testtable WHERE name='寮犱笁' (涓) 閫夋嫨鍒楄〃 閫夋嫨鍒楄〃(select_list)鎸囧嚭鎵...
  • 扩展阅读:写sql必备100条 ... sql server2019 ... select查询语句大全 ... sql server基本语句 ... 数据库语句大全 ... mysql多表联查sql语句 ... 多表联查语句怎么写 ... sql create ... sql入门语句大全 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网