当前位置:首页 » 编程语言 » 在线练习sql语句
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

在线练习sql语句

发布时间: 2022-03-08 10:09:30

㈠ 有没有在线sql语句查询练习的平台

在线的我倒不知道,不过我知道用新浪sae随便创建个应用(php的,免费),然后你就可以免费用里面的云数据库了,当然也可以在线练习sql语句了。顺便说一句,选应用仓库千万不要选git,新浪的git仓库是巨坑啊!!当初我不小心选了git仓库,现在吐血中。。

㈡ 有没有可以在线练习sql语法的网站

线我倒知道我知道用新浪sae随便创建应用(php免费)免费用面云数据库线练习sql语句顺便说句选应用仓库千万要选git新浪git仓库巨坑啊初我选git仓库现吐血

㈢ sql 中谁有所有关于select语句练习题,在线等~!~!求求个位大神。我想弄明白所有关于selece语句意思

这个简单啊,我也做过这样的要求,最后实现了,就是再增加一个字段(列),这个列是标识列(自动增加)的列。
具体做法是:增加列(不妨列名叫sequence),bigint,(是标识),标识增量 1,标识种子 1.
当你输入的id是 2,5,3,7,数据表中就按照你输入的顺序存。
查询时你就按这个sequence排序,也就是说结果按照你输入的id来排序的。

sequence id data content
1 2 美国 不重要
2 5 英国 不重要
3 3 日本 不重要
4 7 印度 不重要

CREATE TABLE country(
sequence bigint IDENTITY(1,1) NOT NULL,
id char(10) primary key,
data nvarchar(50),
content varchar(5000)
)
primary key是把id做成主键列,如果你不想把id做成主键,又不想有重复,就加上unique(唯一)。
select id,data,content from country where id in('2','5','3','7') order by sequence
查询时并不显示sequence列,不妨碍。这样查询的结果就是按照你输入的顺序来的。
成功!谢谢你的分!

㈣ SQL server练习题,在线急等答案

**************
第一大题
**************
1. 求客户ID为“张娟”所下的订单中所包含的产品ID(10)
select distinct 产品ID from orders where 订单ID in (select 订单ID from procts where 客户ID = '张娟');
2. 求客户ID:要求这些客户所下的订单中产品ID有“51”的客户ID(10)
select distinct 客户ID from procts where 订单ID in(select 订单ID from orders where 产品ID = '51');
3. 求产品ID为“51”所在的订单中所包含的所有的 产品ID(10)
select distinct 产品ID from orders where 订单ID in( select 订单ID from orders where 产品ID = '51');
4. 统计客户ID为“张娟”所下的订单中所包含的产品种类个数。(15)
select count(distinct 产品ID) from orders where 订单ID in (select 订单ID from procts where 客户ID = '张娟');
5. 统计每个客户所下的订单中所包含的产品种类个数。(20)
select 客户ID,sum((select count(distinct 产品ID) from orders where 订单ID = procts.订单ID)) as 产品种类个数 from procts group by 客户ID;
6. 创建一个名称”proc_ClientIDByOrderID”为存储过程:要求给出客户ID,返回该该客户ID所下的订单中产品ID(15)
create proc proc_ClientIDByOrderID(@customer_id varchar(50))
as
declare @str_sql varchar(1000);
set @str_sql = 'select distinct 产品ID from orders where 订单ID in (select 订单ID from procts where 客户ID = ' + @customer_id + ')';
exec(@str_sql);
7. 创建一个名称为Field_Rule的规则,并将其绑定到订单表Orders的订单ID上,规定取值只能五个数字(10)
create rule Field_Rule
as
@id like '[0-9][0-9][0-9][0-9][0-9]'
exec sp_bindrule 'Field_Rule','Orders.订单ID';

**************
第二大题
**************

1. 求名称为“编辑”的菜单所对应的子菜单项(10)
select distinct 菜单名称 from Menu where 上级菜单编码 in( select 菜单编码 from Menu where 菜单名称 = '编辑');
2. 求名称为“保存”的子菜单项所在的上级菜单名称(10)
select distinct 菜单名称 from Menu where 菜单编码 in( select 上级菜单编码 from Menu where 菜单名称 = '保存');
3. 求角色名称为“一般用户”的角色所能操作的菜单名称(10)
select distinct 菜单名称 from Menu where 权限编码 in( select 权限编码 from Role where 角色名称 = '一般用户');
4. 统计名称为“一般用户”的角色所能操作的菜单项数(15)
select count(distinct 菜单名称) from Menu where 权限编码 in( select 权限编码 from Role where 角色名称 = '一般用户');
5. 统计每个角色所能操作的菜单项数(20)
select 角色名称,sum((select count(distinct 菜单名称) from Menu where 权限编码 =Role.权限编码)) as 菜单项数 from Role group by 角色名称;
6. 创建一个名称为存储过程:要求给出角色名称,返回该该角色所能操作的菜单名称。(15)
create proc Role_count_proc(@Role_name varchar(50))
as
declare @str_sql varchar(1000);
set @str_sql = 'select distinct 菜单名称 from Menu where 权限编码 in( select 权限编码 from Role where 角色名称 = '+ @Role_name +')';
exec(@str_sql);
7. 创建一个名称为Field_Rule的规则,并将其绑定到菜单表Menu上的上级菜单编码列上,规定取值只能是两个数字,或者是四个数字,或者为null
create rule Field_Rule
as
@id like '[0-9][0-9]' or @id like '[0-9][0-9]' or @id is null;
exec sp_bindrule 'Field_Rule','Menu.上级菜单编码'

---
以上,希望对你有所帮助。

㈤ SQL Server 练习题 在线 急!!!

c,d,d,d,a
c,d,,c,b
d,d,d,a,d
a,d,c,b,?
最后一题不确定,4个答案个人感觉都不准确,数据冗余是指数据出现重复的情况,并非不太重要的数据,由基本数据导出也不准确

㈥ 有没有在线sql server练习环境

http://sqlzoo.net
这个网站可以,支持多种数据库,右上角可以选择中文语言和数据库类型

㈦ 第二个- -SQL的练习题、务必帮帮忙、实在也不想做- - 在线等

1.创建“员工表”和“薪水表”,表信息如上图所示,emp表中,员工编号为主键;salary表中员工编号为外键。
create table emp(
empno int(4) not null auto_increment,
ename varchar(30) not null,
ebirthday date not null,
ssex varchar(3) not null,
tel varchar(12),
e varchar(30),
job varchar(30) not null,
primary key(empno)
);
create table salary(
deptno varchar(30) not null,
sal decimal(6,1) not null default 0,
empno int(4) not null,
primary key(deptno),
foreign key(empno) references emp(empno)
);
------------------------------------------------------
2.修改表信息,给emp表添加一个字段“addr”
alter table emp add addr varchar(100);
------------------------------------------------------
3.向“员工表”、“薪水表”中添加数据(数据如表1、2)
insert into emp values(1001,'BLAKE','1974-12-11','男','33123456','本科','市场专员','');
insert into emp values(1002,'SCOTT','1974-10-02','男','33123456','大专','总经理','');
insert into emp values(1003,'JAMES','1974-04-02','男','56119676','博士','主管','');
insert into emp values(1004,'MIKE','1974-01-02','女','45134514','硕士','主管','');
insert into emp values(1005,'SMITH','1974-08-02','男','56116710','本科','主管','');
insert into emp values(1006,'LILY','1974-06-01','女','43134514','硕士','主管','');
insert into emp values(1007,'LUCY','1975-06-01','女','45234534','大专','市场专员','');
~~~~~~
insert into salary values('001',4500,1001);
insert into salary values('002',6600,1002);
insert into salary values('003',7900,1003);
insert into salary values('004',2300,1004);
insert into salary values('005',3870,1005);
insert into salary values('006',2870,1006);
insert into salary values('007',5870,1007);
------------------------------------------------------
4.修改数据,将电话号码以56开头的所有的人员的薪水加上500
update salary s join emp e on s.empno=e.empno set s.sal=s.sal+500 where e.tel like '56%';
------------------------------------------------------
5.查询工资在4000--7000之间,名字中有“AM”的人员的全部信息
select e.*,s.* from emp e join salary s on e.empno=s.empno where s.sal between 4000 and 7000 and e.ename like '%AM%';
------------------------------------------------------
6.查询1974年之后出生的,学历为“硕士”的人员的全部信息
select e.*,s.* from emp e join salary s on e.empno=s.empno where e.e='硕士' and e.ebirthday>'1974';
------------------------------------------------------
7. 查询出年龄最大和年龄最小的2个员工的全部信息
select e.*,s.* from emp e,(select min(ebirthday) as min,max(ebirthday) as max from emp) st,salary s
where e.empno=s.empno and (e.ebirthday>=st.max or e.ebirthday<=st.min);
------------------------------------------------------
8.查询出所有与姓名为‘MIKE’的同年出生、同性别的人员的全部信息
select e.*,s.* from emp e,(select ebirthday as birth,ssex as sex from emp where ename='MIKE') st,salary s
where e.empno=s.empno and e.ssex=st.sex and substring(e.ebirthday,1,4)=substring(st.birth,1,4);
------------------------------------------------------
9.查询出部门号为001和003的的人员的全部信息
select s.*,e.* from salary s left join emp e on s.empno=e.empno where s.deptno in ('001','003');
------------------------------------------------------
10.创建一个存储过程,查询人员是主管的全部信息
create procere p() select s.*,e.* from salary s join emp e on s.empno=e.empno where e.job='主管';
输入call p();即可查看结果.
/** 更高级的查询 **/
create procere qu(in param char(30))
begin
declare v char(30);
set v=param;
if v='' then
select s.*,e.* from salary s join emp e on s.empno=e.empno;
else
select s.*,e.* from salary s join emp e on s.empno=e.empno where e.job=v;
end if;
end;
输入:call qu('主管');查询主管,输入:call qu('');查询所有,同理输入:call qu('总经理');

-------------------------------------------------------
总结,花了点时间帮你认真的在mysql平台上写完了(sql2000没有装,所以没有验证,不过应该没有问题),这个题不难,但是要时间
你的数据我修改了部分,因为是做题的过程中我发现少了些数据,我就组加上了,当然,没有数据也是正确的,只是为了方便你学习,查询的时候不至于出不来数据
如果有问题可以MAIL我。 也可以到www.wsleo.com/上找我

㈧ 求免费在线使用 练习的 SQL Server 2005

没这东西吧!

㈨ SQL语句学习大全

创建数据库
创建之前判断该数据库是否存在 if exists (select * from sysdatabases where name='databaseName') drop database 'databaseName' go Create DATABASE database-name
删除数据库
drop database dbname
备份sql server
--- 创建 备份数据的 device USE master EXEC sp_admpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBack
创建新表
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
删除新表
drop table tabname
增加一个列
Alter table tabname add column col type 注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
添加主键
Alter table tabname add primary key(col) 说明:删除主键: Alter table tabname drop primary key(col)
创建索引
create [unique] index idxname on tabname(col….) 删除索引:drop index idxname on tabname 注:索引是不可更改的,想更改必须删除重新建。
创建视图
create view viewname as select statement 删除视图:drop view viewname
几个简单的基本的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%’ (所有包含‘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[separator]
几个高级查询运算词
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),不消除重复行。 注:使用运算词的几个查询结果行必须是一致的。
使用外连接
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: 全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
[编辑本段]提升
复制表
(只复制结构,源表名:a 新表名:b) (Access可用) 法一:select * into b from a where 1<>1 法二:select top 0 * into b from a
拷贝表
(拷贝数据,源表名:a 目标表名:b) (Access可用) insert into b(a, b, c) select d,e,f from b;
跨数据库之间表的拷贝
(具体数据使用绝对路径) (Access可用) insert into b(a, b, c) select d,e,f from b in ‘具体数据库’ where 条件 例子:..from b in '"&Server.MapPath("."&"\data.mdb" &"' where..
子查询
(表名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)
显示文章、提交人和最后回复时间
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b
外连接查询
(表名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
在线视图查询
(表名1:a select * from (Select a,b,c FROM a) T where t.a > 1;
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
in 的使用方法
select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’)
删除主表中已经在副表中没有的信息
两张关联表delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1
四表联查问题
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 .....
日程安排提前五分钟提醒
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5
一条sql 语句搞定数据库分页
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段
前10条记录
select top 10 * form table1 where 范围
选择排名
选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)
派生结果表
包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 (select a from tableA except (select a from tableB) except (select a from tableC)
随机取出10条数据
select top 10 * from tablename order by newid()
随机选择记录
select newid()
删除重复记录
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...)
列出数据库里所有的表名
select name from sysobjects where type='U'
列出表里的所有的
select name from syscolumns where id=object_id('TableName')
列示排列
列示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
初始化表table1
TRUNCATE TABLE table1
选择从10到15的记录
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc
数据类型转换
declare @numid int declare @id varchar(50) set @numid=2005 set @id=convert(varchar,@numid) 通过上述语句完成数据类型Int转换成varchar,其他转换类似,可参看convert函数
[编辑本段]技巧
1=1,1=2的使用
在SQL语句组合时用的较多 “where 1=1” 是表示选择全部 “where 1=2”全部不选, 如: if @strWhere !=' begin set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere end else begin set @strSQL = 'select count(*) as Total from [' + @tblName + ']' end 我们可以直接写成 set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere
收缩数据库
--重建索引 DBCC REINDEX DBCC INDEXDEFRAG --收缩数据和日志 DBCC SHRINKDB DBCC SHRINKFILE
压缩数据库
dbcc shrinkdatabase(dbname) 转移数据库给新用户以已存在用户权限 exec sp_change_users_login 'update_one','newname','oldname' go
检查备份集
RESTORE VERIFYONLY from disk='E:\dvbbs.bak'
修复数据库
Alter DATABASE [dvbbs] SET SINGLE_USER GO DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK GO Alter DATABASE [dvbbs] SET MULTI_USER GO
日志清除
SET NOCOUNT ON DECLARE @LogicalFileName sysname, @MaxMinutes INT, @NewSize INT USE tablename -- 要操作的数据库名 Select @LogicalFileName = 'tablename_log', -- 日志文件名 @MaxMinutes = 10, -- Limit on time allowed to wrap log. @NewSize = 1 -- 你想设定的日志文件的大小(M) -- Setup / initialize DECLARE @OriginalSize int Select @OriginalSize = size FROM sysfiles Where name = @LogicalFileName Select 'Original Size of ' + db_name() + ' LOG is ' + CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' + CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' FROM sysfiles Where name = @LogicalFileName Create TABLE DummyTrans (DummyColumn char (8000) not null) DECLARE @Counter INT, @StartTime DATETIME, @TruncLog VARCHAR(255) Select @StartTime = GETDATE(), @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' DBCC SHRINKFILE (@LogicalFileName, @NewSize) EXEC (@TruncLog) -- Wrap the log if necessary. WHILE @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired AND @OriginalSize = (Select size FROM sysfiles Where name = @LogicalFileName) AND (@OriginalSize * 8 /1024) > @NewSize BEGIN -- Outer loop. Select @Counter = 0 WHILE ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) BEGIN -- update Insert DummyTrans VALUES ('Fill Log') Delete DummyTrans Select @Counter = @Counter + 1 END EXEC (@TruncLog) END Select 'Final Size of ' + db_name() + ' LOG is ' + CONVERT(VARCHAR(30),size) + ' 8K pages or ' + CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' FROM sysfiles Where name = @LogicalFileName Drop TABLE DummyTrans SET NOCOUNT OFF
更改某个表
exec sp_changeobjectowner 'tablename','dbo'
存储更改全部表
Create PROCEDURE dbo.User_ChangeObjectOwnerBatch @OldOwner as NVARCHAR(128), @NewOwner as NVARCHAR(128) AS DECLARE @Name as NVARCHAR(128) DECLARE @Owner as NVARCHAR(128) DECLARE @OwnerName as NVARCHAR(128) DECLARE curObject CURSOR FOR select 'Name' = name, 'Owner' = user_name(uid) from sysobjects where user_name(uid)=@OldOwner order by name OPEN curObject FETCH NEXT FROM curObject INTO @Name, @Owner WHILE(@@FETCH_STATUS=0) BEGIN if @Owner=@OldOwner begin set @OwnerName = @OldOwner + '.' + rtrim(@Name) exec sp_changeobjectowner @OwnerName, @NewOwner end -- select @name,@NewOwner,@OldOwner FETCH NEXT FROM curObject INTO @Name, @Owner END close curObject deallocate curObject GO
SQL SERVER中直接循环写入数据
declare @i int set @i=1 while @i<30 begin insert into test (userid) values(@i) set @i=@i+1 end

㈩ 学习sql数据库查询语句看什么书

看sql安装后的在线帮助文件,里面都很详细,有具体的实例,你可以照着练习