當前位置:首頁 » 編程語言 » 在線練習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安裝後的在線幫助文件,裡面都很詳細,有具體的實例,你可以照著練習