當前位置:首頁 » 數據倉庫 » 怎麼查詢資料庫連接資料庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

怎麼查詢資料庫連接資料庫

發布時間: 2022-04-03 02:58:12

A. 如何查看mysql 當前連接的資料庫

使用 mysql GUI tools 裡面有個 MySQLAdministrator.exe

B. SQL 資料庫 連接查詢

如果你非得一個查詢語句查詢的話,就建議你將用戶表復制,復制為表C,其中表C和表B(用戶表)有一模一樣的數據結構和數據

SELECT A.UID,B.UNAME,C.UNAME FROM
(FRIEND A INNER JOIN USER_B B ON A.HOSTID=B.ID) INNER JOIN USER_C C
ON A.FRIENDID=C.ID

C. 資料庫連接查詢

select 欄位列表 from 表1 join 表2 on 兩個表之間的關聯條件
select 欄位列表 from 表1,表2 where 兩個表之間的關聯條件
上面這兩句是一個意思,都屬於連接查詢中的內連接,返回完全滿足關聯條件的記錄;第一句其實完整寫法應該這樣:select 欄位列表 from 表1 inner join 表2 on 兩個表之間的關聯條件.
-----------------------------------

inner join內部連接 兩表都滿足的組合

full outer 全連 兩表相同的組合在一起,A表有但B表沒有的數據(顯示null), 同樣B表有,A表沒有的顯示為(null)

A表 left join B表 左連,以A表為基礎,A表的全部數據,B表有的組合。沒有的為null

A表 right join B表 右連,以B表為基礎,B表的全部數據,A表的有的組合。沒有的為null

查詢分析器中執行:

--建表table1,table2:

create table table1(id int,name varchar(10))

create table table2(id int,score int)

insert into table1 select 1,'lee'

insert into table1 select 2,'zhang'

insert into table1 select 4,'wang'

insert into table2 select 1,90

insert into table2 select 2,100

insert into table2 select 3,70

如表

-------------------------------------------------

table1| table2|

-------------------------------------------------

|id name| |id score|

|1 lee| |1 90|

|2 zhang| |2 100|

|4 wang| |3 70|

-------------------------------------------------

以下均在查詢分析器中執行

一、外連接

1.概念:包括左向外聯接、右向外聯接或完整外部聯接

2.左連接:left join 或 left outer join

(1)左向外聯接的結果集包括 LEFT OUTER 子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行

,則在相關聯的結果集行中右表的所有選擇列表列均為空值(null)。

(2)sql語句

select * from table1 left join table2 on table1.id=table2.id

-------------結果-------------

| id | name | id | score |

------------------------------

| 1 | lee | 1 | 90 |

| 2 | zhang | 2 | 100 |

| 4 | wang |NULL| NULL |

------------------------------

注釋:包含table1的所有子句,根據指定條件返回table2相應的欄位,不符合的以null顯示

3.右連接:right join 或 right outer join

(1)右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。

(2)sql語句

select * from table1 right join table2 on table1.id=table2.id

-------------結果-------------

|id | name | id | score |

------------------------------

| 1 | lee | 1 | 90 |

| 2 |zhang | 2 | 100 |

|NULL| NULL | 3 | 70 |

------------------------------

注釋:包含table2的所有子句,根據指定條件返回table1相應的欄位,不符合的以null顯示

4.完整外部聯接:full join 或 full outer join

(1)完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行

,則整個結果集行包含基表的數據值。

(2)sql語句

select * from table1 full join table2 on table1.id=table2.id

-------------結果-------------

| id | name | id | score |

------------------------------

| 1 | lee | 1 | 90 |

| 2 | zhang| 2 | 100 |

| 4 | wang|NULL| NULL|

|NULL| NULL| 3 | 70 |

------------------------------

注釋:返回左右連接的和(見上左、右連接)

二、內連接

1.概念:內聯接是用比較運算符比較要聯接列的值的聯接

2.內連接:join 或 inner join

3.sql語句

select * from table1 join table2 on table1.id=table2.id

-------------結果-------------

| id | name | id | score |

------------------------------

| 1 | lee | 1 | 90 |

| 2 | zhang| 2 | 100 |

------------------------------

注釋:只返回符合條件的table1和table2的列

4.等價(與下列執行效果相同)

A:select a.*,b.* from table1 a,table2 b where a.id=b.id

B:select * from table1 cross join table2 where table1.id=table2.id (註:cross join後加條件只能用where,不能用on)

三、交叉連接(完全)

1.概念:沒有 WHERE 子句的交叉聯接將產生聯接所涉及的表的笛卡爾積。第一個表的行數乘以第二個表的行數等於笛卡爾積結果集的大小。

(table1和table2交叉連接產生3*3=9條記錄)

2.交叉連接:cross join (不帶條件where...)

3.sql語句

select * from table1 cross join table2

-------------結果-------------

| id | name | id | score |

------------------------------

| 1 | lee | 1 | 90 |

| 2 | zhang| 1 | 90 |

| 4 | wang| 1 | 90 |

| 1 | lee| 2 | 100 |

| 2 | zhang| 2 | 100 |

| 4 | wang| 2 | 100 |

| 1 | lee | 3 | 70 |

| 2 | zhang| 3 | 70 |

| 4 | wang| 3 | 70 |

------------------------------

注釋:返回3*3=9條記錄,即笛卡爾積

4.等價(與下列執行效果相同)

A:select * from table1,table2

D. SQL資料庫連接查詢

不管是1還是2都是同一個欄位cityName
你要是這樣只能用下面的方法了
a,b是上面的表
select
t1.busnum,case
when
t1.begincityid=1
then
'長春'
ELSE
'廣州'end
as
begincityid,
case
when
t1.endCityId=1
then
'長春'
ELSE
'廣州'end
as
endCityId,t1.startTime
from
a
t1,
b
t2
where
t1.begincityid=t2.cityid

E. 如何快速查看Oracle服務名連接的資料庫的信息

如果不能連接到資料庫,則在tnsname.ora文件中的test網路服務名(net service)後面加上Oracle資料庫的DB_Domain參數值,通過用sqlplus show parameter db_domain命令察看。此處db_domain參數值為testserver.com
,將其加到網路服務名後面,修改後的tnsname.ora中關於該網路服務名的內容為:test
.testserver.com =
(DESCRIPTION=
(ADDRESS_LIST=
(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521)))(CONNECT_DATA=(
SERVICE_NAME
=orcl.testserver.com)))用sqlplus程序通過test.testserver.com網路服務名測試,如sqlplus system/[email protected]
關於為什們在網路服務名後面加db_domain參數,需要了解sql*plus連接資料庫的原理,解決12154常見故障中有詳細的說明。摘自genispan答客戶端網路服務名配置的回帖。
其中紅色字體就是本貼目標對象
本段內容中:網路服務名:test域名(db_domain):
testserver.com
SERVICE_NAME:
orcl.testserver.com
網路服務名+域名後的完整內容為:
test.testserver.com=(DESCRIPTION=
(ADDRESS_LIST=
(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521)))(CONNECT_DATA
=(SERVICE_NAME
=orcl.testserver.com)))
**************************資料庫名與資料庫實例名*****************************資料庫名是用於區分資料庫的一個內部標識,是以二進制方式存儲在資料庫控制文件中的參數。資料庫創建之後不能再修改這個參數。資料庫創建後,它被寫入資料庫參數文件pfile或Spfile中。格式如下:
db_name="orcl"
db_domain=dbcenter.toys.com
資料庫實例名
是操作資料庫的實體,用戶通過實例與資料庫交互。實例名用來標識這個資料庫實例。資料庫創建後,實例名可以被修改。也在資料庫參數文件pfile或Spfile中。格式如下:
instance_name=orcl
資料庫名與實例名可以相同。一個資料庫對應一個實例的情況下設置成相同的便於標識資料庫。但是在8i,9i的並行伺服器中,資料庫與實例不存在一一對應關系,而是一對多關系,一個資料庫對應多個實例。不過一個用戶只能與一個實例相連。

F. 如何查看資料庫

1.通過系統的「性能」來查看:
開始->管理工具->性能(或者是運行裡面輸入 mmc)然後通過
添加計數器添加 SQL 的常用統計(MSSQL General Statistics) 然後在下面列出的項目裡面選擇 用戶連接(User Connection) 就可以時時查詢到sql server資料庫連接數了。

2.通過系統表來查詢:
SELECT * FROM
[Master].[dbo].[SYSPROCESSES] WHERE [DBID]
IN
(
SELECT
[DBID]
FROM
[Master].[dbo].[SYSDATABASES]
WHERE
NAME=』databaseName』
)
databaseName 是需要查看的資料庫,然後查詢出來的行數,就是當前的sql server資料庫連接數。不過裡面還有一些別的狀態可以做參考用。
或者使用以下查詢語句:
select * from sysprocesses where dbid in (select dbid from sysdatabases where name=』MyDatabase』)

G. plsql 怎麼查看資料庫的連接數

查詢資料庫當前進程的連接數:

selectcount(*)fromv$process;

查看資料庫當前會話的連接數:

selectcount(*)fromv$session;

查看資料庫的並發連接數:

selectcount(*)fromv$sessionwherestatus='ACTIVE';

查看當前資料庫建立的會話情況:

selectsid,serial#,username,program,machine,statusfromv$session;

查詢資料庫允許的最大連接數:

selectvaluefromv$parameterwherename='processes';

或者:

showparameterprocesses;

查詢所有資料庫的連接數

selectschemaname,count(*)fromv$sessiongroupbyschemaname;

查詢終端用戶使用資料庫的連接情況。

selectosuser,schemaname,count(*)fromv$sessiongroupbyschemaname,osuser;

#查看當前不為空的連接

select*fromv$sessionwhereusernameisnotnull

#查看不同用戶的連接數

selectusername,count(username)fromv$

H. 資料庫如何查詢

選擇列表
選擇列表(select_list)指出所查詢列,它可以是一組列名列表、星號、表達式、變數(包括局部變
量和全局變數)等構成。

1、選擇所有列
例如,下面語句顯示testtable表中所有列的數據:
SELECT *
FROM testtable

2、選擇部分列並指定它們的顯示次序
查詢結果集合中數據的排列順序與選擇列表中所指定的列名排列順序相同。
例如:
SELECT nickname,email
FROM testtable

3、更改列標題
在選擇列表中,可重新指定列標題。定義格式為:
列標題=列名
列名 列標題
如果指定的列標題不是標準的標識符格式時,應使用引號定界符,例如,下列語句使用漢字顯示列
標題:
SELECT 昵稱=nickname,電子郵件=email
FROM testtable

4、刪除重復行
SELECT語句中使用ALL或DISTINCT選項來顯示表中符合條件的所有行或刪除其中重復的數據行,默認
為ALL。使用DISTINCT選項時,對於所有重復的數據行在SELECT返回的結果集合中只保留一行。

5、限制返回的行數
使用TOP n [PERCENT]選項限制返回的數據行數,TOP n說明返回n行,而TOP n PERCENT時,說明n是
表示一百分數,指定返回的行數等於總行數的百分之幾。
例如:
SELECT TOP 2 *
FROM testtable
SELECT TOP 20 PERCENT *
FROM testtable

(二) FROM子句
FROM子句指定SELECT語句查詢及與查詢相關的表或視圖。在FROM子句中最多可指定256個表或視圖,
它們之間用逗號分隔。
在FROM子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應使用對象名限定這些列
所屬的表或視圖。例如在usertable和citytable表中同時存在cityid列,在查詢兩個表中的cityid時應
使用下面語句格式加以限定:
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在FROM子句中可用以下兩種格式為表或視圖指定別名:
表名 as 別名
表名 別名
例如上面語句可用表的別名格式表示為:
SELECT username,b.cityid
FROM usertable a,citytable b
WHERE a.cityid=b.cityid
SELECT不僅能從表或視圖中檢索數據,它還能夠從其它查詢語句所返回的結果集合中查詢數據。
例如:
SELECT a.au_fname+a.au_lname
FROM authors a,titleauthor ta
(SELECT title_id,title
FROM titles
WHERE ytd_sales>10000
) AS t
WHERE a.au_id=ta.au_id
AND ta.title_id=t.title_id
此例中,將SELECT返回的結果集合給予一別名t,然後再從中檢索數據。

(三) 使用WHERE子句設置查詢條件
WHERE子句設置查詢條件,過濾掉不需要的數據行。例如下面語句查詢年齡大於20的數據:
SELECT *
FROM usertable
WHERE age>20
WHERE子句可包括各種條件運算符:
比較運算符(大小比較):>、>=、=、<、<=、<>、!>、!<
范圍運算符(表達式值是否在指定的范圍):BETWEEN…AND…
NOT BETWEEN…AND…
列表運算符(判斷表達式是否為列表中的指定項):IN (項1,項2……)
NOT IN (項1,項2……)
模式匹配符(判斷值是否與指定的字元通配格式相符):LIKE、NOT LIKE
空值判斷符(判斷表達式是否為空):IS NULL、NOT IS NULL
邏輯運算符(用於多條件的邏輯連接):NOT、AND、OR
1、范圍運算符例:age BETWEEN 10 AND 30相當於age>=10 AND age<=30
2、列表運算符例:country IN ('Germany','China')
3、模式匹配符例:常用於模糊查找,它判斷列值是否與指定的字元串格式相匹配。可用於char、
varchar、text、ntext、datetime和smalldatetime等類型查詢。
可使用以下通配字元:
百分號%:可匹配任意類型和長度的字元,如果是中文,請使用兩個百分號即%%。
下劃線_:匹配單個任意字元,它常用來限製表達式的字元長度。
方括弧[]:指定一個字元、字元串或范圍,要求所匹配對象為它們中的任一個。
[^]:其取值也[] 相同,但它要求所匹配對象為指定字元以外的任一個字元。
例如:
限制以Publishing結尾,使用LIKE '%Publishing'
限制以A開頭:LIKE '[A]%'
限制以A開頭外:LIKE '[^A]%'
4、空值判斷符例WHERE age IS NULL
5、邏輯運算符:優先順序為NOT、AND、OR
(四)查詢結果排序
使用ORDER BY子句對查詢返回的結果按一列或多列排序。ORDER BY子句的語法格式為:
ORDER BY {column_name [ASC|DESC]} [,…n]
其中ASC表示升序,為默認值,DESC為降序。ORDER BY不能按ntext、text和image數據類型進行排
序。
例如:
SELECT *
FROM usertable
ORDER BY age desc,userid ASC
另外,可以根據表達式進行排序。

二、 聯合查詢
UNION運算符可以將兩個或兩個以上上SELECT語句的查詢結果集合合並成一個結果集合顯示,即執行聯
合查詢。UNION的語法格式為:
select_statement
UNION [ALL] selectstatement
[UNION [ALL] selectstatement][…n]
其中selectstatement為待聯合的SELECT查詢語句。
ALL選項表示將所有行合並到結果集合中。不指定該項時,被聯合查詢結果集合中的重復行將只保留一
行。
聯合查詢時,查詢結果的列標題為第一個查詢語句的列標題。因此,要定義列標題必須在第一個查詢語
句中定義。要對聯合查詢結果排序時,也必須使用第一查詢語句中的列名、列標題或者列序號。
在使用UNION 運算符時,應保證每個聯合查詢語句的選擇列表中有相同數量的表達式,並且每個查詢選
擇表達式應具有相同的數據類型,或是可以自動將它們轉換為相同的數據類型。在自動轉換時,對於數值類
型,系統將低精度的數據類型轉換為高精度的數據類型。
在包括多個查詢的UNION語句中,其執行順序是自左至右,使用括弧可以改變這一執行順序。例如:
查詢1 UNION (查詢2 UNION 查詢3)

三、連接查詢
通過連接運算符可以實現多個表查詢。連接是關系資料庫模型的主要特點,也是它區別於其它類型
資料庫管理系統的一個標志。
在關系資料庫管理系統中,表建立時各數據之間的關系不必確定,常把一個實體的所有信息存放在
一個表中。當檢索數據時,通過連接操作查詢出存放在多個表中的不同實體的信息。連接操作給用戶帶
來很大的靈活性,他們可以在任何時候增加新的數據類型。為不同實體創建新的表,爾後通過連接進行
查詢。
連接可以在SELECT 語句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出連接時有助於
將連接操作與WHERE子句中的搜索條件區分開來。所以,在Transact-SQL中推薦使用這種方法。
SQL-92標准所定義的FROM子句的連接語法格式為:
FROM join_table join_type join_table
[ON (join_condition)]
其中join_table指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一
個表操作的連接又稱做自連接。
join_type 指出連接類型,可分為三種:內連接、外連接和交叉連接。內連接(INNER JOIN)使用比
較運算符進行表間某(些)列數據的比較操作,並列出這些表中與連接條件相匹配的數據行。根據所使用
的比較方式不同,內連接又分為等值連接、自然連接和不等連接三種。
外連接分為左外連接(LEFT OUTER JOIN或LEFT JOIN)、右外連接(RIGHT OUTER JOIN或RIGHT JOIN)
和全外連接(FULL OUTER JOIN或FULL JOIN)三種。與內連接不同的是,外連接不只列出與連接條件相匹
配的行,而是列出左表(左外連接時)、右表(右外連接時)或兩個表(全外連接時)中所有符合搜索條件的
數據行。
交叉連接(CROSS JOIN)沒有WHERE 子句,它返回連接表中所有數據行的笛卡爾積,其結果集合中的
數據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
連接操作中的ON (join_condition) 子句指出連接條件,它由被連接表中的列和比較運算符、邏輯
運算符等構成。
無論哪種連接都不能對text、ntext和image數據類型列進行直接連接,但可以對這三種列進行間接
連接。例如:
SELECT p1.pub_id,p2.pub_id,p1.pr_info
FROM pub_info AS p1 INNER JOIN pub_info AS p2
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)

(一)內連接
內連接查詢操作列出與連接條件匹配的數據行,它使用比較運算符比較被連接列的列值。內連接分
三種:
1、等值連接:在連接條件中使用等於號(=)運算符比較被連接列的列值,其查詢結果中列出被連接
表中的所有列,包括其中的重復列。
2、不等連接: 在連接條件使用除等於運算符以外的其它比較運算符比較被連接的列的列值。這些
運算符包括>、>=、<=、<、!>、!<和<>。
3、自然連接:在連接條件中使用等於(=)運算符比較被連接列的列值,但它使用選擇列表指出查詢
結果集合中所包括的列,並刪除連接表中的重復列。
例,下面使用等值連接列出authors和publishers表中位於同一城市的作者和出版社:
SELECT *
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
又如使用自然連接,在選擇列表中刪除authors 和publishers 表中重復列(city和state):
SELECT a.*,p.pub_id,p.pub_name,p.country
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
(二)外連接
內連接時,返回查詢結果集合中的僅是符合查詢條件( WHERE 搜索條件或 HAVING 條件)和連接條件
的行。而採用外連接時,它返回到查詢結果集合中的不僅包含符合連接條件的行,而且還包括左表(左外
連接時)、右表(右外連接時)或兩個邊接表(全外連接)中的所有數據行。
如下面使用左外連接將論壇內容和作者信息連接起來:
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b
ON a.username=b.username
下面使用全外連接將city表中的所有作者以及user表中的所有作者,以及他們所在的城市:
SELECT a.*,b.*
FROM city as a FULL OUTER JOIN user as b
ON a.username=b.username

(三)交叉連接
交叉連接不帶WHERE 子句,它返回被連接的兩個表所有數據行的笛卡爾積,返回到結果集合中的數
據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
例,titles表中有6類圖書,而publishers表中有8家出版社,則下列交叉連接檢索到的記錄數將等
於6*8=48行。
SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY typeSQL核心語句(非常實用的幾個技巧)插入數據

向表中添加一個新記錄,你要使用SQL INSERT 語句。這里有一個如何使用這種語句的例子:

INSERT mytable (mycolumn) VALUES (『some data』)

這個語句把字元串』some data』插入表mytable的mycolumn欄位中。將要被插入數據的欄位的名字在第一個括弧中指定,實際的數據在第二個括弧中給出。

INSERT 語句的完整句法如下:

INSERT [INTO] {table_name|view_name} [(column_list)] {DEFAULT VALUES | <br><br>Values_list | select_statement}

如果一個表有多個欄位,通過把欄位名和欄位值用逗號隔開,你可以向所有的欄位中插入數據。假設表mytable有三個欄位first_column,second_column,和third_column。下面的INSERT語句添加了一條三個欄位都有值的完整記錄:

INSERT mytable (first_column,second_column,third_column)

VALUES (『some data』,』some more data』,』yet more data』)

注意

你可以使用INSERT語句向文本型欄位中插入數據。但是,如果你需要輸入很長的字元串,你應該使用WRITETEXT語句。這部分內容對本書來說太高級了,因此不加討論。要了解更多的信息,請參考Microsoft SQL Sever 的文檔。

如果你在INSERT 語句中只指定兩個欄位和數據會怎麼樣呢?換句話說,你向一個表中插入一條新記錄,但有一個欄位沒有提供數據。在這種情況下,有下面的四種可能:

如果該欄位有一個預設值,該值會被使用。例如,假設你插入新記錄時沒有給欄位third_column提供數據,而這個欄位有一個預設值』some value』。在這種情況下,當新記錄建立時會插入值』some value』。

如果該欄位可以接受空值,而且沒有預設值,則會被插入空值。

如果該欄位不能接受空值,而且沒有預設值,就會出現錯誤。你會收到錯誤信息:

The column in table mytable may not be null.

最後,如果該欄位是一個標識欄位,那麼它會自動產生一個新值。當你向一個有標識欄位的表中插入新記錄時,只要忽略該欄位,標識欄位會給自己賦一個新值。

注意

向一個有標識欄位的表中插入新記錄後,你可以用SQL變數@@identity來訪問新記錄

的標識欄位的值。考慮如下的SQL語句:

INSERT mytable (first_column) VALUES(『some value』)

INSERT anothertable(another_first,another_second)

VALUES(@@identity,』some value』)

如果表mytable有一個標識欄位,該欄位的值會被插入表anothertable的another_first欄位。這是因為變數@@identity總是保存最後一次插入標識欄位的值。

欄位another_first應該與欄位first_column有相同的數據類型。但是,欄位another_first不能是應該標識欄位。Another_first欄位用來保存欄位first_column的值。

刪除記錄

要從表中刪除一個或多個記錄,需要使用SQL DELETE語句。你可以給DELETE 語句提供WHERE 子句。WHERE子句用來選擇要刪除的記錄。例如,下面的這個DELETE語句只刪除欄位first_column的值等於』Delete Me』的記錄:

DELETE mytable WHERE first_column=』Deltet Me』

DELETE 語句的完整句法如下:

DELETE [FROM] {table_name|view_name} [WHERE clause]

在SQL SELECT 語句中可以使用的任何條件都可以在DELECT 語句的WHERE子句 中使用。例如,下面的這個DELETE語句只刪除那些first_column欄位的值為』goodbye』或second_column欄位的值為』so long』的記錄:

DELETE mytable WHERE first_column=』goodby』 OR second_column=』so long』

如果你不給DELETE 語句提供WHERE 子句,表中的所有記錄都將被刪除。你不應該有這種想法。如果你想刪除應該表中的所有記錄,應使用第十章所講的TRUNCATE TABLE語句。

注意

為什麼要用TRUNCATE TABLE 語句代替DELETE語句?當你使用TRUNCATE TABLE語句時,記錄的刪除是不作記錄的。也就是說,這意味著TRUNCATE TABLE 要比DELETE快得多。

更新記錄

要修改表中已經存在的一條或多條記錄,應使用SQL UPDATE語句。同DELETE語句一樣,UPDATE語句可以使用WHERE子句來選擇更新特定的記錄。請看這個例子:

UPDATE mytable SET first_column=』Updated!』 WHERE second_column=』Update Me!』

這個UPDATE 語句更新所有second_column欄位的值為』Update Me!』的記錄。對所有被選中的記錄,欄位first_column的值被置為』Updated!』。

下面是UPDATE語句的完整句法:

UPDATE {table_name|view_name} SET [{table_name|view_name}]

{column_list|variable_list|variable_and_column_list}

[,{column_list2|variable_list2|variable_and_column_list2}…

[,{column_listN|variable_listN|variable_and_column_listN}]]

[WHERE clause]

注意

你可以對文本型欄位使用UPDATE語句。但是,如果你需要更新很長的字元串,應使用UPDATETEXT語句。這部分內容對本書來說太高級了,因此不加討論。要了解更多的信息,請參考Microsoft SQL Sever 的文檔。

如果你不提供WHERE子句,表中的所有記錄都將被更新。有時這是有用的。例如,如果你想把表titles中的所有書的價格加倍,你可以使用如下的UPDATE 語句:

你也可以同時更新多個欄位。例如,下面的UPDATE語句同時更新first_column,second_column,和third_column這三個欄位:

UPDATE mytable SET first_column=』Updated!』

Second_column=』Updated!』

Third_column=』Updated!』

WHERE first_column=』Update Me1』

技巧

SQL忽略語句中多餘的空格。你可以把SQL語句寫成任何你最容易讀的格式。

用SELECT 創建記錄和表

你也許已經注意到,INSERT 語句與DELETE語句和UPDATE語句有一點不同,它一次只操作一個記錄。然而,有一個方法可以使INSERT 語句一次添加多個記錄。要作到這一點,你需要把INSERT 語句與SELECT 語句結合起來,象這樣:

INSERT mytable (first_column,second_column)

SELECT another_first,another_second

FROM anothertable

WHERE another_first=』Copy Me!』

這個語句從anothertable拷貝記錄到mytable.只有表anothertable中欄位another_first的值為』Copy Me!』的記錄才被拷貝。

當為一個表中的記錄建立備份時,這種形式的INSERT 語句是非常有用的。在刪除一個表中的記錄之前,你可以先用這種方法把它們拷貝到另一個表中。

如果你需要拷貝整個表,你可以使用SELECT INTO 語句。例如,下面的語句創建了一個名為newtable的新表,該表包含表mytable的所有數據:

SELECT * INTO newtable FROM mytable

你也可以指定只有特定的欄位被用來創建這個新表。要做到這一點,只需在欄位列表中指定你想要拷貝的欄位。另外,你可以使用WHERE 子句來限制拷貝到新表中的記錄。下面的例子只拷貝欄位second_columnd的值等於』Copy Me!』的記錄的first_column欄位。

SELECT first_column INTO newtable

FROM mytable

WHERE second_column=』Copy Me!』

使用SQL修改已經建立的表是很困難的。例如,如果你向一個表中添加了一個欄位,沒有容易的辦法來去除它。另外,如果你不小心把一個欄位的數據類型給錯了,你將沒有辦法改變它。但是,使用本節中講述的SQL語句,你可以繞過這兩個問題。

例如,假設你想從一個表中刪除一個欄位。使用SELECT INTO 語句,你可以創建該表的一個拷貝,但不包含要刪除的欄位。這使你既刪除了該欄位,又保留了不想刪除的數據。

如果你想改變一個欄位的數據類型,你可以創建一個包含正確數據類型欄位的新表。創建好該表後,你就可以結合使用UPDATE語句和SELECT 語句,把原來表中的所有數據拷貝到新表中。通過這種方法,你既可以修改表的結構,又能保存原有的數據。
——from 網路

I. 如何查看當前資料庫的連接信息

1、用SQL語句:select
count(*)
from
master.dbo.sysprocesses
或者
sp_who
2、用管理界面:
SQL2000:進入企業管理器,管理——當前活動——進程信息
SQL2005:進入manager
studio
,展開對象管理器,管理——右鍵「活動監視器」——查看進程
SQL2008:進放manager
studio
在菜單欄下面有一行圖標,點擊最後一個圖標「活動監視器」,進入活動監視器的界面後,點擊「進程」.

J. 連接資料庫,查詢數據的幾種方法

後台SQL操作一般比前台程序操作快得多
如果要求效率,盡量用後台操作
但前台操作實現較簡單