MySQL的最基本的SQL语法/语句
DDL-数据定义语言(创建,修改,删除,声明)
DML-数据操纵语言(选择,删除,更新,插入)
DCL-数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
首先,简要介绍基础语句:
1 ,说明:创建数据库
创建数据库数据库名称
2,说明:删除数据库
drop database dbname
3,说明:备份sql server
---创建备份数据的设备
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],..)
根据已经有的表创建新表:
一个:创建表tab_old像tab_old(使用旧表创建新表)
B:创建表tab_new作为选择COL1,COL2 ...仅从tab_old定义
5,说明:删除新表
删除表TABNAME
6,说明:增加一个列
更改表tabname add column col类
注:列增加后将不能删除.DB2中列加上后数据类型也不能更改,唯一能改变的是增加VARCHAR类型
的长度。
如图7所示,说明:添加主键: ALTER TABLE TABNAME添加主键(COL)
说明:删除主键:ALTER TABLE TABNAME下降主键(COL)
8,说明:创建索引:创建[独特]索引idxname上tabname(col ....)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建
.9,说明:创建视图:create view viewname as select语句
删除视图:drop view viewname
10,说明:几何简单的基本的sql语句
选择:select * from table1其中范围
插入:insert into table1(field1,field2)values(value1,value2)
删除:从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
求和:从table1中选择sum(field1)作为sumvalue
平均:从table1中 选择avg(field1)作为avgvalue
最大:从table1中 选择max(field1)作为最大值
最小:从table1中 选择min(field1)作为minvalue
11,说明:几个高级查询运算词
A:UNION运算符
UNION运算符通过组合其他两个结果表(例如TABLE1和TABLE2)并消去表中任何重复行而派生
出一个结果表。当所有随着UNION一起使用时(即UNION ALL),不消除重复行两种情况下,派。
生表的每一行不是来自TABLE1就是来自
TABLE2。B:除非运算符
EXCEPT运算符通过包括所有在TABLE1中但不在TABLE2中的行并消除所有重复行而派生出一个
结果表。当所有随着EXCEPT一起使用时(除了ALL),不消重复复行
。C:INTERSECT运算符
INTERSECT运算符通过只包括TABLE1和TABLE2中都有行的消除并重复所有行而派生出一个查询查询查询查询结果
表当ALL随INTERSE CT一起使用(INTERSECT ALL),不消重复复行。
注:使用运算词的几个查询结果行 必须是一致的
0.12,说明:使用外连接
A,左外连接:
左外连接(左连接):结果集几连连表的匹配行,也包括左连接表的所有行
.sql:从外部连接选择aa,ab,ac,bc,bd,bf b aa = bc
B:右外连接:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行
。C:全外连接:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有 记录
0.13,说明:复制表复制结构,源表名:a新表名:b)(Access可用)
法一:select * into b from a where 1 <> 1
法二:select top 0 * into a from
14,说明:拷贝表拷贝数据,源表名:一个目标表:B)(接入可用)
插入到B(A,B,C)中选择d,E,F从B;
15,说明:在数据库中
选择d,e,f来自b。在具体的数据库中,选择d,e,f中的任何一个数据库,
在“&Server.MapPath(”。“)&”\ data.mdb“&”'where ..
16,说明:子查询(表名1:a表名2:b)
select a,b,从c其中一个IN(选择从步骤bd)或者:选择A,b ,从c其中一个IN
(1,2,3)
17,说明:显示文章,人和提交回复主求最后时间
选择a.title,a.username,从表b.adddate,(选择最大值(
ADDDATE)ADDDATE 从 b表,其中table.title = a.title)
18。说明:外连接查询(表名1:a表名2:b)
选择aa,ab,ac,bc,bd,bf从左边的连接b ON aa = bc
19,说明:在线视图查询:a)
select * from(select a,b,c FROM a)T where ta> 1;
20,说明:之间的用法,之间限制查询数据范围包括了边界值,
select * from table1 where time1 and time2之间的时间
选择a,b,c,从table1其中一个不在数值1和数值2之间
21,说明:在的使用方法
select * from table1 where ['value 1','value 2','value 4','值6')
22,说明:两张关联表,删除主表中已经在副表中没有信息
从表 1中删除不存在的地方select * from table2 where
table1.field1 = table2.field1)
23,说明:四表联查问题:
select * from a left inner join b on aa = bb right inner join c on aa = cc inner join
d on aa = dd where ...。
24,说明:日程安排提前五分钟提醒
SQL:SELECT * FROM日程安排,其中DATEDIFF('分钟',F开始时间,GETDATE())> 5
25,说明:一条SQL语句搞定数据库分页
选择顶端10b上。*(从表名排序字段中选择排名前20位的主键字段
desc )a,表名b其中b。主键字段= a。主键字段order by a。排序字段
26,说明:前10条记录
select top 10 * form table1 where范围
27,说明:选择在每一组中的b值相同的数据中对应的一个最大的记录的所有信息(类似这样的用法英语谚语。英语谚语可以用
于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等。)
选择A,b ,从C tablename ta where a =(select
table (from tablename tb where tb.b = ta.b)
28,说明:包括所有在TableA中但不在TableB和TableC中的行并消除所有重复行而派生出一个
结 果表
(从表A中选择一个)除了(从tableB的中选择一个),除了(从表C中选择一个)
29,说明:随机取出10条数据
选择top 10 *从表名顺序newid()
30,说明:随机选择记录
select newid()
31,说明:删除重复记录
从表名中删除其中id不从(从
col1, col2,...中选择表名组中的max(id )
32,说明:列出数据库里所有的表名
从sysobjects中选择名字where type ='
U'33,说明:列出表中所有的
选择名称从syscolumns其中id = object_id('TableName')
34,说明:列出类型,厂商,pcs字段,以type字段排列,case可以方便地实现多重选择,类似
select case,情况 .select
type,sum 'a'then个其他0)结束时,总和当' C '时,
颗否则为0)结束时,总和(case'b'时,则个别的0端)FROM表名
组由类型
显示结果:
类型卖主件
电脑甲1
电脑A 1
光盘B 2
光盘A 2
手机B 3
手机C 3
35,说明:初始表table1
TRUNCATE TABLE table1
36,说明:选从10到15的记录
选择top 5 * from(选择top 15 * from table order by id asc)table_别名order by
id desc
随机选择数据库记录的方法(使用随机化函数,通过SQL语句实现)
对存储在数据库中的数据来说,随机数特性能给出上面的效果,但它们可能太慢了些。不能你
要求ASP“找个随机数”然后打印出来实际上常见的解决方案是建立如下所示的循环:
随机化
RNumber = INT(RND * 499)+1
虽然objRec.EOF
如果objRec(“ID”)= RNumber THEN
......的英文这里执行脚本。 ..
端如果
objRec.MoveNext
WEND
这很容易理解。首先,你取出1到500范围之内的一个随机数(假设500就是数据库内记录的总
数)。然后,你遍历每一记录来测试ID的值,检查其是否匹配RNumber。满足条件的话就执行由
THEN关键字开始的那一块代码。假如你的RNumber等于495,要那么循环一遍数据库花 时间的可就
长了。虽然500这个数字看起来大了些,但相比更为稳固的业解决方案这还是个小型数据库了,
后者通常在一个数据库内就包含了成千上万条记录。这时候不就死定了?
使用SQL,你就可以很快地找到准确的记录并且打开一个只包含该记录的记录集,如下所示
:
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,只需要检查匹配情况即可。只要你对以上代码的工作满意,你自柯林斯
按需操作“随机”记录。记录没有包含其他内容,很快因此你就能找到你需要的记录这样就
大大降低了处理时间。
再谈随机数
现在你下定决心要榨干随机函数的求最后一滴油,那么你可能会一次取出多随机条记录或者
想采用一定随机范围内的记录。把上面的标准随机示例扩展一下就可以用SQL应对 两种面情况
了。
为了取出几条随机选择的记录并存放在同一记录内,你可以存储三个随机数,然后查询
数据库获得匹配这些数字的记录:
SQL =“SELECT * FROM顾客ID =”&RNumber&
ID =“&RNumber3
假如你想选出10条记录(也许是每次页面装载时的10条链接的列表),你可以用BETWEEN或者
数学等式选出第一条记录状语从句:适当数量的递增记录。这一操作可以通过好几种方式来完成,但是
选择语句只显示一种可能(这里的ID是自动生成的号码):
sql =“Select * FROM Customers其中ID BETWEEN“&RNumber&”AND“&RNumber&”+
9“
注意:以上代码的执行目的不是检查数据库内是否有9条并发记录。
随机读取若干条记录,测试过
访问语法:选择前10 *从表名字ORDER BY赛第一轮(ID)
的SQL Server:select n * from表名order by newid()
mysqlelect *从表名order By rand()Limit n
Access左连接语法(最近开发要用左连接,Access帮助什么都没有,网上没有访问的SQL说明,只有
自己测试,现在记下以后后查)
语法选举table1.fd1,表1,FD2 table2.fd2从表1左连接表2在
table1.fd1,table2.fd1哪里...
使用SQL语句用...代替过长的字符串显示
语法:
SQL数据库:当前字段> 10然后离开(字段,10)+'...'其他字段结束为
news_name,news_id从表名
访问数据库选择案例 数据库:选择iif(len(field)> 2,left (field,2)+'...',field)FROM tablename;
Conn.Execute说明
执行方法
该方法用于执行SQL语句根据SQL语句执行后是否返回记录集,该方法的使用格式分为以下两。
种:
(1)执行的SQL查询语句时,将返回查询得到的记录集用法为:
设置对象变量名=连接对象.Execute(“SQL查询语言”)
执行方法调用后,会自动创建记录集对象,并将查询结果存储在该记录对象中,通过设置
方法,记录
(2)执行SQL的操作语言时,没有记录集的返回此对象保存,以后对象变量就代表了该记录集对象。 (2)执行SQL的操作语言时,没有记录集的返回此
连接对象.Execute“SQL操作性语句“[,RecordAffected] [,Option]
?RecordAffected为可选项,此出可放置一个变量,SQL语句执行后,所生效的记录
数会自动保存到该变量中。通过访问该变量,就可知道SQL语句队多少条记录进行了操作。
?选项可选项,该参数的取值通常为为adCmdText,它用于告诉ADO,应该将执
方法之后的第一个字符解释为命令文本。通过指定该参数,可使执行更高效。
* BeginTrans,RollbackTrans,CommitTrans方法
这三个方法的英文连接对象提供了用于事务处理的方法.BeginTrans用于开始一个事物;
RollbackTrans用于回滚事务; CommitTrans用于提交所有的事务处理结果,即确认事务的处理。
事务处理可以将一组操作视为一个整体,只有全部语句都成功执行后,事务处理才算成功;若
其中有一个语句执行失败,则整个处理就算失败,并恢复到处理前的状态
的BeginTrans和CommitTrans用于标记事务的开始和结束,在这两个之间的语句,就是作为事务
处理的语句。判断事务处理是否成功,可通过连接对象的错误集合来实现,错误若集合的成员个
数不为0,则说明有错误发生,事务处理失败.Error中集合的每一个错误对象,代表一个错误信
。息
37,一道SQL语句面试题,关于组别
表内容:
2005-05-09胜
2005-05-09胜
2005-05-09负
2005-05-09负
2005-05-10胜
2005-05-10负
2005-05-10负
如果要生成下列结果,该如何写sql语句?
胜负
2005-05-09 2 2
2005-05-10 1 2
回答:代码如下:
create table #tmp(rq varchar(10),shengfu nchar(1))
插入#tmp值('2005-05-09','胜')
插入到#tmp值('2005-05-09','胜')
插入到#tmp值('2005-05-09','负')
插入到#tmp值
插入到#tmp值( '2005-05-10', '胜')
插入到#tmp值( '2005-05(' '' '' '' '' '' '' '' '' '' '' '''''''')'
插入到#tmp值中('2005-05-10','负')
1)选择rq,sum sum(当shengfu ='
负'then 1 else 0 end )'负'从#tmp group by rq
2)选择N.rq,N.胜,M。负来自(
从#tmp中选择rq,胜= count(*)其中shengfu ='胜' 由rq
选择rq,负= count(*),其中shengfu ='负'N.rq = M.rq
3)选择a.col001,a.a1胜,b.b1负来自
(从col1选择col001,count(col001)a1,其中col002 ='胜'group by col001)a,
(选择col001,计数从temp1中(col001)B1其中col002 = '负'由col001组)b
其中a.col001 = b.col001
38,一个请教面试中遇到 的SQL的语句查询问题
表中有ABC三列,用SQL语法实现:当A列大于B列时选择A列否选择B列,当B列大于C列时选择B列
否选择C 列示例如下
:
select(a> b then a else b end)的情况下,
(情况下,当b> C则besleç端)
从表名
39,一个日期判断的SQL语句?
请取出tb_send表中日期(SendTime字段)为当天的所有记录?(SendTime字段为日期时间型,所有游戏日
网络出版总库与时间)
示例如下:
select * from tb where datediff(dd,SendTime,getdate())= 0
40,有一张表,里面有3个字节:语文,数学,英语其中有3条记录分别表示语文70分,数学80分。
,英语58分,请用一条SQL语句查询出这三条记录并按以下条件显示出来(并写出您的思路):
大于或等于80表示优秀,大于或等 60表示及格,小于60分表示不及格。
显示格式:
。数学语文。英语
及格优秀不及格
例如如下:
选择
(情况下,当语文> = 80那么'优秀'
时语文> = 60然后'及格'
其他'不及格')作为语文,
(情况下,当数学
如果数学> = 60,那么'优秀', 当数学> = 60,然后'和格'
其他'不及格')作为数学,
(当英语> = 80,那么'优秀'
英语> = 60时'及格'
其他'不及格' )作为英语,
从表
41,在SQLSERVER2000中请用SQL创建一张用户临时表和系统临时表,里面包含两个字段的ID和
IDValues,类型都是int型,并解释下两者的区别?
用户临时表:create table #xx(ID int,IDValues int)
系统临时表:create table ## xx(ID int,IDValues int)
区别:
用户临时表只对创建这个表的用户的Session可见,对其他进程是不可见的。
当创建它的进程消失时这个临时表就自动删除。
全局临时表对于一个SQL Server实例都可见,但是是所有访问它的Session都消失的时候,它也自动删除
。42,SQLSERVER2000是一种大型数据库,他的存储容量只受存储介质的限制,请问它的英文通过什么方
式实现这种无限容量机制的。
它的所有数据都存储在数据文件中(* DBF),所以只要文件够大,SQL服务器存储的容量的英文可以扩
大的。
SQL Server 2000的数据库有三种类型的文件:
主要数据文件
主要数据文件的英文数据库的起点,指向数据库中文件的其它部分。每个数据库都有一个主要数据文件
。主要数据文件的文件扩展名是.mdf。
次要数据文件
次要数据文件所有游戏除主要数据文件外的所有数据文件。有些数据库可能没有次要数据文件,而有些
数据库则有多个次要数据文件。次要数据文件的推荐文件扩展名是.NDF。
日志文件
日志文件所有游戏恢复数据库所需的所有日志信息。每个数据库必须至少有一个日志文件,但可以不要
一个。日志文件的推荐文件扩展名是.ldf。43
,请用一个SQL得出语句查询查询结果
从表1,表2中取出如表3所列格式数据,注意提供的数据及结果不准确,作为只是一 格
式向大家请教。
如使用存储过程也可以。
表1
月份周一部门DEP业绩YJ
一月份01 10
一月份02 10
一月份03 5
二月份02 8
二月份04 9
三月份03 8
表2
部门DEP部门名称DNAME
--------------- -----------------
01国内业务一部
02国内业务二部
03国内业务三部
04国际业务部 表3
(结果)
部门DEP一月份二月份三月份
- ------------------------------------
01 10 null null
02 10 8 null
03 null 5 8
04 null null 9
---------------------------------- --------
1)
选择a。部门名称dname,b。业绩yj为'一月份',c。业绩yj为'二月份',d。业绩yj为'三月份',
由表1 ,表2 b,表2 c,表2 d
其中a。部门dep = b。部门dep和b。月份mon ='一月份'and
a部门dep = c。部门dep和c。月份mon ='二月份'and
a。部门dep = d。部门dep and d。月份mon ='三月份'和
2)
选择a.dep,
sum(b.mon = 1则b.yj else 0 end时)为'一月份' ,
sum(b.mon = 2则b .yj否则为0结束)为'二月份' ,
和(情况下,当b.mon = 3然后b.yj否则为0结束)为'三月份',
和(情况下,当b.mon = 4然后b.yj否则为0端)为'四月份',
和(情况下,当b.mon = 6然后b.yj否则为0结束)为'五月份',
和(情况下,当b.mon = 6然后b.yj否则为0结束)为'六月份',
sum(b.mon = 7 then b。yj else 0 end)as'七月份',
总和(情况下,当b.mon = 8然后b.yj否则为0结束)为'八月份' ,
(情况下,当b.mon = 9然后b.yj否则为0结束)为'九月份',
和(情况下,当b.mon = 10 then b.yj else 0 end)as'十月份',
sum(当b.mon = 11时则b.yj else 0 end)为'十一月份',
sum(当b.mon = 12则b.yj else 0 end时)为'十二月份',
from table2 a left join table1 b on a.dep = b.dep
44,华为一道面试题
一个表中的Id有多个记录,把所有这个id的记录查出来,并显示有多少条记录
.--- --------------------------------- -------------
选择ID,计数(*)从TB组通过ID有计数 *)>