SQL資料庫之QQ農場版
人物:菜鳥, 收垃圾的, 數據機器
菜鳥: 吃菜的鳥,簡稱菜鳥
數據機器: 指的SQL Server 2008(微軟體最新推出的資料庫,數據大小支持100TB(我的家庭住址:http://www.microsoft.com/china/sql/2008/)
計算機基礎單位換算:
一道「月亮之上」mp3文件大小為5MB左右
1GB=1024MB 1TB=1024G
資料庫 Database,簡稱DB,是一種總稱,有幾種資料庫產品:
大型:Oracle(甲骨文),DB2(IBM) 這種軟體用於電信,工業。
中型:SQL Server 2000, SQL Server2005, SQL Server 2008(都是微軟)
小型:ACCESS, foxpro, vf
這樣的,你電腦上的文件也比較多吧,你要什麼資料的時候,想一下,如何做的!!!!!!!!!!!!!
是不是一個文件夾包一個文件夾的,我們要一個一個的解開,,特是煩,時間浪費了,而且我要說的,很多人,放文件是東一個西一個,不好找,文件不能充分利用。
用過系統里的搜索沒有,你只要說文件名或文件內容,他會乖乖從硬碟里給找出來,這就是資料庫的原形,但找到這個文件可能要1分,或者更長時間。
我們能不能把搜索的時間從5分鍾變為100ms(毫秒)了。
提示: 1000ms = 1s秒)
一個大街走過來的人: 可以,現在的百毒不是這樣嗎,輸一個詞 「艷照門」颼的一個就出來了。
菜鳥: 對,這就是資料庫的應用,速度快,想一下你是怎麼存文件的吧,每次關程序的時候,要你這里選那裡選存放地方,煩,用了這么久,還不知道要存什麼地方。
收垃圾的:資料庫有什麼秘密了。
菜鳥:說你菜,你還不相信,是這樣的,好比一個100米的菜地,今天你要吃面,為了味道好吃一點,需要菜葉做為調料,好,這個菜地里這樣的,每過十米一種菜:
1. 靚菜 2. 白菜 3.油菜 4.太空大白菜 5.茄子白菜
6. 白火食菜 7.紫菜 8.花菜 9.捲心菜 10.不鳥不菜
你這個人對生活要求不高,但求生活多資多彩的,下個面,要10種菜都來一點,走來走去,總算花了5分鍾才摘完菜。
而我們如果把每十米都種十種菜,每塊區域都一樣,就算這種多資多彩的人可能20秒也完成了。
收垃圾的:OH,YES(人跳了大約0.00123毫米),是這樣的,把東西集中一齊,速度自然提高了,同時也可以一下知道我種那些菜。
菜鳥:對,這就是資料庫的好處,速度快,不關心文件具體存放地,(OH,YEAR)我不要保存對話框了。給它一個數據,它就會返回相應的結果,再想一想我們windows裡面的搜索
觀眾:老大「windows搜索」老頭已是春天的故事了
數據機器: It's my world(歌詞),媽呀,終於我可以演講演講了,你們說的也很不錯,真正操作起來還有很多工作要作,如何放,如何取。你們懂啥哦!
我們的Excel其實就是一個簡單的資料庫,它縱橫交錯的在一個表格里存放著數據,不可亂存,這是保證我們快速存儲與搜索的基石。
收垃圾的:不聽你們說了,菜鳥的說的100米的菜園,我看我沒有這么多時間去種,還是去QQ農場種些,我感覺,那速度,更快,更直觀(觀眾已扔鞋,apple,banana,orange),,DIDI(聲音),不好,我的BP機通知我的QQ農場1號靚菜被隔壁大媽偷了一個,不對呀!我養了狗的了,(觀眾:這叫臨死也要偷,誰叫你種名字多要吸引的靚菜了,而且還掛了一個標簽:太空一號靚菜).哎(聲音)昨天揀垃圾,忘了給狗一份,這狗狗,這里長時間,一次不給吃,我就下了菜,不說了,,我要火箭速度去抓住偷,這是歷史第一次。
原創自:http://hi..com/ohxs
作者:小魚
結語: 資料庫是種把數據按一定格式有序存儲,能快速,准確返回數據
建議: 初學者學習先學習 Access,office系列的,比較快的就可以上手,界面和word,excel一樣,之後學習sql server,和mysql(免費),論壇用的比較多(PHPWind論壇,喬客)
⑵ 資料庫SQL語言
1)select sno, snmae, sex, age,addr from s
(2)select sname,sex,age from s where sex = '男' and age between 19 and 21
(3)insert into s (sno, snmae, sex, age,addr) values ('N10','姓名','男',21,'籍貫')
(4)delete from s where age >= 30
(5)delete from s where sname like '王%'
'
(6)update s set sname = '李鐵' where sname = '李四'
(7)update s set age = age + 1 where sex = '男'
(8)select sno, snmae, sex, age,addr from s order by age Desc
(9)select avg(age) as '平均年齡' where sex = '男'
(10)select sno,sname from s inner join sc on s.sno = sc.sno where sc.Cno = 'C2'
(11)create table s
(
sno varchar(5) primary key,
sname varchar(8),
sex varchar(2),
age int ,
addr varchar(10)
)
完全是按照你上邊的要求寫的, 希望能幫到你
⑶ sql注入工具下載
黑客SQL伺服器入侵實戰演習(一)
1.0緒論
當一台機器只開放了80埠(這里指的是提供HTTP服務)時,可能你的大多數漏洞掃描器都不能給到你很多有價值的信息(漏洞信息),倘若這台機器的管理員是經常為他的伺服器打PATCH的話,我們只好把攻擊的矛頭指向WEB服務攻擊了。SQL注入攻擊是WEB攻擊類型中的一種,這種攻擊沒有什麼特殊的要求,只需要對方提供正常的HTTP服務,且不需要理會管理員是否是個「PATCH狂」。這類攻擊主要是針對某種WEB處理程序(如ASP,JSP,PHP,CGI等等)的而進行。
這篇文章不是在為閣下介紹什麼新「玩意」,SQL注入攻擊以前就一直廣為流傳著。我之所以現在才寫這篇文章是因為我想把我最近實驗所得的某些經驗與積累記錄下來,希望能給予讀者某些參考吧。你也可以在「9.0我從哪裡可以得到更多相關資料?」的欄目中找到更多其他人所寫的、關於SQL注入技巧的相關資料。
1.1什麼是SQL注入?
這種攻擊的要訣在於將SQL的查詢/行為命令通過『嵌入』的方式放入合法的HTTP提交請求中從而達到攻擊者的某種意圖。現在很多的動態網頁都會從該網頁使用者的請求中得到某些參數,
然後動態的構成SQL請求發給資料庫的。舉個例子,當有某個用戶需要通過網頁上的用戶登陸(用戶身份驗證)時,動態網頁會將
該用戶提交上來的用戶名與密碼加進SQL詢問請求發給資料庫,用於確認該用戶提交的身份驗證信息是否有效。在SQL注入攻擊的角度看來,這樣可以使我們在發送SQL請求時通過修改用戶名與/或密碼值的『領域』區來達到攻擊的目的。
1.2SQL注入需要什麼(工具等)呢?
一個(些)網頁瀏覽器。
2.0什麼信息是你所需要找尋的呢?
首先你需要找到允許提交數據的頁面,如:登陸頁面、搜索頁面、反饋頁面、等等。有的時候,某些HTML頁面會通過POST命令將所需要的參數傳遞給其他的ASP頁面。所以,有的時候你不會在URL路徑中看到相關的參數。盡管如此,
你仍可以通過查看HTML的源代碼中的"FORM標簽來辨別是否有參數傳遞,相關的代碼如下:
<FORM action=Search/search.asp method=post>
<input type=hidden name=A value=C>
</FORM>
在<FORM>與</FORM>的標簽對間的每一個參數傳遞都有可能可以被利用(利用在攻擊的情況下)著SQL注入。
2.1當你找不到有輸入行為的頁面時應該怎麼辦呢?
你可以找一些相關ASP、JSP、CGI或PHP這類型的頁面。嘗試找一些帶有某些參數的特殊URL,如:
http://ck/index.asp?id=10
3.0你應該如何測試這些缺陷是否存在呢?
首先先加入某些特殊的字元標記,輸入如:
hi' or 1=1--
尋找一些登陸頁面,在其登陸ID與密碼輸入處,或URL中輸入:
- Login: hi' or 1=1--
- Pass: hi' or 1=1--
- http://ck/index.asp?id=hi' or 1=1--
如果想以『隱藏』的方式進行此類測試,你可以把該HTML網頁從網站上下載至本地硬碟,修改其隱藏部分
的值,如:
<FORM action=http://ck/Search/search.asp method=post>
<input type=hidden name=A value="hi' or 1=1-->
</FORM>
如果閣下是幸運的話估計現在已經可以不需要帳號與密碼而『成功登陸』了。
⑷ sql server2005標准版 免費下載地址
http://hi..com/hicdl/blog/item/cbaaa91be8e4481e8718bf12.html
你只需要進這個裡面,選擇你要的標准就可以了!
具體步奏有介紹
⑸ 求里諾進銷存SQL網路版 V3.25完美破解注冊碼!!!!
免費是沒有。。那些免費的,性能,功能,穩定,出錯,都不大好。用了也是白用。
建議你還是使用比較正規。。
所謂沒有免費的午餐。
聽說,鵬世進銷存的價格在市場上是最便宜。。 穩定性也是最好的。
你可以先去下,試用版 。如果覺得好。。
在跟他們聯系。。
⑹ 哪裡有免費的SQL Server 2005(中文版)下載啊
我知道你的意思了,中文,免費。
這個可以直接使用微軟官方提供的SQL SERVER2005中文快速開發版本。
在日誌里有下載地址和安裝使用說明。
http://hi..com/44498/blog/item/08d1fed857faec3d32fa1ccd.html
⑺ 誰能給下SQL語句查詢大全,謝謝!
日誌清除
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
創建資料庫
創建之前判斷該資料庫是否存在 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
⑻ 找國內國外免費空間申請哪裡有呀
國內免費空間
1.免費空間datasir:200M/php/asp/access/Mysql
2.飛龍科技:300M/asp/php/access/綁定域名2個
3.連雲港IDC: 100M/asp/php/access/綁定6個域名
4.50M/asp/ftp/支持動易、喬客、新雲、漸飛組件/免費空間
5.100M 網頁空間 全能空間 無條件申請/免費空間
6.38互聯:100M/全能空間/免費空間
7.中國8U免費空間:100M/200M/php/asp/米只0.8元
8.火山互聯1G/php/asp/資料庫/免費空間
9.50M/PHP/HTML/空間/10M MYSQL空間/ftp
國外免費空間
1.空間推薦:250M/phpMysql/綁米無限個、獨立面板/商業級
2.商業空間推薦:100M-10G,FTP/hostmonster商業空間
3.free hosting:300M/php/mysql/無文件大小、類型限制/
4.free websites:3G/php/mysql/ftp/訪問統計
5.free web hosting:5G/php/mysql/cgi/perl/
6.free web page:7G/php/mysql/dns/綁定域名/domains support
7.free hosting:15G/php/mysql/zend/gd2.0/二級域名/綁定頂米
8.free host:20G/php/mysql/綁定域名/support domains
9.free hosting:無限大小/php/mysql/文件最大5M
php免費空間
1.商業空間推薦:100M-10G,FTP/hostmonster商業空間
2.php免費空間 300M/php/mysql/無文件大小、類型限制/
3.空間推薦: 250M/php/mysql/Perl, CGI, Ruby/米/成人
4.php免費空間 5G/php/mysql/cgi/perl/
5.php免費空間 7G/php/mysql/dns/綁定域名
6.php免費空間 15G/php/mysql/zend/gd2.0/二級域名/綁定頂米
7.php免費空間 20G/php/mysql/綁定域名
8.php免費空間 無限大小/php/mysql/文件最大5M
9.php免費空間 200M/php/mysql/ftp/綁定域名
asp免費空間
1.國外asp免費空間: 50M/asp/ftp/綁定域名
2.國外asp免費空間: 350M/asp3.0/access/ftp/
3.國外asp免費空間: 100M/asp/access/ftp
4.國外asp空間: 100M/asp/access/ftp/無文件大小、類型限制
5.國外asp免費空間: 30M/asp/ftp/二級域名
6.國內asp免費空間: 30M/asp/ftp/綁定域名
7.國內asp免費空間: 300M/asp/php/access/綁定域名2個
8.中國8U免費空間:100M/200M/php/asp/米只0.8元
9.火山互聯1G/php/asp/資料庫/免費空間
⑼ 請問有沒有免費的asp.net空間,還有就是SQL的資料庫如何上傳,麻煩知道的解說一下、
免費的空間有應該是有,不過很少,而且那種空間很容易出問題,廣告也多,SQL資料庫一般是通過導出導入的方式來上傳~
希望對你的問題有所幫助,如果還有什麼疑問可以HI在線咨詢,IT精英俱樂部真誠為您解答!
⑽ SQL附加資料庫出錯 如下圖 在線等 百度Hi在線 QQQ在線 1072892248
1. 修改資料庫文件屬性:右鍵資料庫文件--屬性--去鉤「只讀」
2. 添加用戶許可權:右鍵資料庫文件--屬性--安全--把當前用戶的許可權設置為「完全控制」