A. sql語句的問題
有中文欄位,是編碼會出現很多意想不到的錯誤。
首先欄位,表名用 ` 間隔號或引號括起來,這是中文欄位必須要做的。如果還有問題,再查。
B. SQL語句的簡單問題(有誰能真正幫我解決這個問題)
首先,SQL語句是一個字元串.
字元串形式是
例:
a="ABCDE"
字元串如果要與變數連接時
例:
b=5
a="abcde"
+
b
然後a中的值就是abcde5
就像樓主所說為什麼要'"+變數+"'"呢?
因為有時我們需要得到a的值為abcde'5'的字元串,那麼就應該
a="abcde'"+5+"'"
在SQL語句中有些是需要字元'的有些則不需要
例:
SQLStmt
=
"INSERT
INTO
PasswdInfo
Values('"
+
AAA+
"','"
+
BBB
"',"
+
CCC
+
")"
假設AAA的值為abc,BBB的值為def,CCC的值為5
那麼SQLStmt實際上是INSERT
INTO
PasswdInfo
Values('abc','def',5)
SQL語句中字元類型的值前後要加'',數字則不用加''了.
C. sql語句的問題
給你個思路:
select
*
from
(select
count(age)
as
'14歲'
from
test
where
age=14)
,
((select
count(age)
as
'15歲'
from
test
where
age=15)),
((select
count(age)
as
'18歲'
from
test
where
age=18))
可以通過程序,來完成子查詢部分的sql語句。
select
DISTINCT
age
from
test
查出所有的年齡,循環生成子查詢。
D. SQL語句問題
SELECT
dbo.ca_hr_perinfo.perid,
dbo.ca_hr_pere.name,dbo.ca_hr_perinfo.birth,dbo.ca_hr_perinfo.realname,dbo.ca_hr_perinfo.updata,dbo.ca_hr_perinfo.sex,
dbo.ca_hr_pere.ecation,
dbo.ca_hr_perinfo.postdate,dbo.ca_hr_pere.speciality,dbo.ca_hr_perinfo.experience
FROM
dbo.ca_hr_perinfo
left
JOIN
dbo.ca_hr_pere
ON
dbo.ca_hr_perinfo.perid
=
dbo.ca_hr_pere.perid
where
dbo.ca_hr_perinfo.status=1
and
(ca_hr_pere.ecation
like
'%高中%'
or
ca_hr_pere.ecation
like
'%中專%'
or
ca_hr_pere.ecation
like
'%大專%'
or
ca_hr_pere.ecation
like
'%本科%')
and
ca_hr_perinfo.yyyy
>=
'1'
and
ca_hr_perinfo.yyyy<=
'2'
and
Year(getdate())-left(ca_hr_perinfo.birth,4)
>=
'23'
and
Year(getdate())-left(ca_hr_perinfo.birth,4)
<=
'27'
and
dbo.ca_hr_perinfo.sex
like
'%男%'
and
datediff(day,ca_hr_perinfo.updata,getdate())<'90'
order
by
ca_hr_perinfo.updata
desc
試試,應該是這幾個or的問題
E. SQL語言的問題
SQL語言快速入門之一
SQL是英文Structured Query Language的縮寫,意思為結構化查詢語言。SQL語言的主要功能就是同各種資料庫建立聯系,進行溝通。按照ANSI(美國國家標准協會)的規定,SQL被作為關系型資料庫管理系統的標准語言。SQL語句可以用來執行各種各樣的操作,例如更新資料庫中的數據,從資料庫中提取數據等。目前,絕大多數流行的關系型資料庫管理系統,如Oracle, Sybase, Microsoft SQL Server, ACCESS等都採用了SQL語言標准。雖然很多資料庫都對SQL語句進行了再開發和擴展,但是包括Select, Insert, Update, Delete, Create, 以及Drop在內的標準的SQL命令仍然可以被用來完成幾乎所有的資料庫操作。下面,我們就來詳細介紹一下SQL語言的基本知識。
資料庫表格
一個典型的關系型資料庫通常由一個或多個被稱作表格的對象組成。資料庫中的所有數據或信息都被保存在這些資料庫表格中。資料庫中的每一個表格都具有自己唯一的表格名稱,都是由行和列組成,其中每一列包括了該列名稱,數據類型,以及列的其它屬性等信息,而行則具體包含某一列的記錄或數據。以下,是一個名為天氣的資料庫表格的實例。
城市 最高氣溫 最低氣溫
北京 10 5
上海 15 8
天津 8 2
重慶 20 13
該表格中「城市」, 「最高氣溫」和「最低氣溫」就是三個不同的列,而表格中的每一行則包含了具體的表格數據。
數據查詢
在眾多的SQL命令中,select語句應該算是使用最頻繁的。Select語句主要被用來對資料庫進行查詢並返回符合用戶查詢標準的結果數據。Select語句的語法格式如下:
select column1 [, column2,etc] from tablename
[where condition];
([] 表示可選項)
select語句中位於select關鍵詞之後的列名用來決定那些列將作為查詢結果返回。用戶可以按照自己的需要選擇任意列,還可以使用通配符「*」來設定返回表格中的所有列。
select語句中位於from關鍵詞之後的表格名稱用來決定將要進行查詢操作的目標表格。
Select語句中的where可選從句用來規定哪些數據值或哪些行將被作為查詢結果返回或顯示。
在where條件從句中可以使用以下一些運算符來設定查詢標准:
= 等於
> 大於
< 小於
>= 大於等於
<= 小於等於
<> 不等於
除了上面所提到的運算符外,LIKE運算符在where條件從句中也非常重要。LIKE運算符的功能非常強大,通過使用LIKE運算符可以設定只選擇與用戶規定格式相同的記錄。此外,我們還可以使用通配符「%」用來代替任何字元串。舉例如下:
select firstname, lastname, city
from employee
where firstname LIKE 『E%』;
(注意,字元串必須被包含在單括弧內)
上述SQL語句將會查詢所有名稱以E開頭的姓名。或者,通過如下語句:
select * from employee
where firstname = 『May』;
查詢所有名稱為May的行。
SQL語言快速入門之二
創建表格
SQL語言中的create table語句被用來建立新的資料庫表格。Create table語句的使用格式如下:
create table tablename
(column1 data type,
column2 data type,
column3 data type);
如果用戶希望在建立新表格時規定列的限制條件,可以使用可選的條件選項:
create table tablename
(column1 data type [constraint],
column2 data type [constraint],
column3 data type [constraint]);
舉例如下:
create table employee
(firstname varchar(15),
lastname varchar(20),
age number(3),
address varchar(30),
city varchar(20));
簡單來說,創建新表格時,在關鍵詞create table後面加入所要建立的表格的名稱,然後在括弧內順次設定各列的名稱,數據類型,以及可選的限制條件等。注意,所有的SQL語句在結尾處都要使用「;」符號。
使用SQL語句創建的資料庫表格和表格中列的名稱必須以字母開頭,後面可以使用字母,數字或下劃線,名稱的長度不能超過30個字元。注意,用戶在選擇表格名稱時不要使用SQL語言中的保留關鍵詞,如select, create, insert等,作為表格或列的名稱。
數據類型用來設定某一個具體列中數據的類型。例如,在姓名列中只能採用varchar或char的數據類型,而不能使用number的數據類型。
SQL語言中較為常用的數據類型為:
char(size):固定長度字元串,其中括弧中的size用來設定字元串的最大長度。Char類型的最大長度為255位元組。
varchar(size):可變長度字元串,最大長度由size設定。
number(size):數字類型,其中數字的最大位數由size設定。
Date:日期類型。
number(size,d):數字類型,size決定該數字總的最大位數,而d則用於設定該數字在小數點後的位數。
最後,在創建新表格時需要注意的一點就是表格中列的限制條件。所謂限制條件就是當向特定列輸入數據時所必須遵守的規則。例如,unique這一限制條件要求某一列中不能存在兩個值相同的記錄,所有記錄的值都必須是唯一的。除unique之外,較為常用的列的限制條件還包括not null和primary key等。Not null用來規定表格中某一列的值不能為空。Primary key則為表格中的所有記錄規定了唯一的標識符。
向表格中插入數據SQL語言使用insert語句向資料庫表格中插入或添加新的數據行。Insert語句的使用格式如下:
insert into tablename
(first_column,...last_column)
values (first_value,...last_value);
例如:
insert into employee
(firstname, lastname, age, address, city)
values (『Li』, 『Ming』, 45, 『No.77 Changan Road』, 『Beijing」);
簡單來說,當向資料庫表格中添加新記錄時,在關鍵詞insert into後面輸入所要添加的表格名稱,然後在括弧中列出將要添加新值的列的名稱。最後,在關鍵詞values的後面按照前面輸入的列的順序對應的輸入所有要添加的記錄值。
更新記錄
SQL語言使用update語句更新或修改滿足規定條件的現有記錄。Update語句的格式為:
update tablename
set columnname = newvalue [, nextcolumn = newvalue2...]
where columnname OPERATOR value [and|or column OPERATOR value];
例如:
update employee
set age = age+1
where first_name= 『Mary』and last_name= 『Williams』;
使用update語句時,關鍵一點就是要設定好用於進行判斷的where條件從句。
刪除記錄
SQL語言使用delete語句刪除資料庫表格中的行或記錄。Delete語句的格式為:
delete from tablename
where columnname OPERATOR value [and|or column OPERATOR value];
例如:
delete from employee
where lastname = May;
簡單來說,當需要刪除某一行或某個記錄時,在delete from關鍵詞之後輸入表格名稱,然後在where從句中設定刪除記錄的判斷條件。注意,如果用戶在使用delete語句時不設定where從句,則表格中的所有記錄將全部被刪除。
刪除資料庫表格
在SQL語言中使用drop table命令刪除某個表格以及該表格中的所有記錄。Drop table命令的使用格式為:
drop table tablename;
例如:
drop table employee;
如果用戶希望將某個資料庫表格完全刪除,只需要在drop table命令後輸入希望刪除的表格名稱即可。Drop table命令的作用與刪除表格中的所有記錄不同。刪除表格中的全部記錄之後,該表格仍然存在,而且表格中列的信息不會改變。而使用drop table命令則會將整個資料庫表格的所有信息全部刪除。
以上,我們對SQL語言主要的命令和語句進行了較為詳細的介紹。應該說SQL語句的語法結構和風格還是相當簡單和直觀的,只要用戶結合實踐多加練習,一定會在短期內迅速掌握。
SQL語言快速入門之三
我們日常使用SQL語言的工作過程中,使用最多的還是從已經建立好的資料庫中查詢信息。下面,我們就來詳細介紹一下如何使用SQL語言實現各種資料庫查詢操作。
SELECT…FROM
為方便講解,我們在資料庫中創建名為Store_Information的如下數據表。
Store_Information
Store_Name
Sales
Date
Los Angeles
$1500
Jan-10-2000
San Diego
$250
Jan-11-2000
Los Angeles
$300
Jan-12-2000
Boston
$700
Jan-12-2000
SQL語言中用於資料庫查詢的最簡單的命令就是SELECT…FROM,語法格式為:
SELECT "column_name" FROM "table_name"
例如,如果我們希望查詢Store_Information數據表中所有的商店名稱時,可以使用如下命令:
SELECT store_name FROM Store_Information
查詢結果顯示為:
Store_Name
Los Angeles
San Diego
Los Angeles
Boston
如果用戶希望一次查詢多個欄位,可以將所要查詢的欄位名稱依次加入SELECT關鍵字之後,中間用「,」隔開即可。
DISTINCT
SELECT關鍵字支持用戶查詢數據表中指定欄位的所有數據,但是這樣有時就會不可避免的出現重復信息。如果用戶希望只查詢那些具有不同記錄值的信息的話,可以使用SQL語言的DISTINCT關鍵字。語法格式如下:
SELECT DISTINCT "column_name"
FROM "table_name"
例如,我們可以使用以下命令查詢Store_Information數據表具有不同記錄值的所有記錄。
SELECT DISTINCT Store_Name FROM Store_Information
查詢結果如下:
Store_Name
Los Angeles
San Diego
Boston
WHERE
除了選擇具有不同記錄值的記錄之外,有時我們可能還會需要根據某些條件對資料庫中的數據進行查詢。例如,我們可能需要查詢Store_Information數據表中銷售額超過1000美圓的商店。為此,我們可以使用SQL語言的WHERE關鍵字設定查詢條件。語法格式如下:
SELECT "column_name"
FROM "table_name"
WHERE "condition"
由此,我們可以使用如下命令查詢銷售額超過1000美圓的商店信息:
SELECT store_name FROM Store_Information WHERE Sales > 1000
查詢結果顯示為:
store_name
Los Angeles
運算函數
現在,我們已經了解到在使用SQL語言進行資料庫查詢操作時可以通過對數值的判斷設定靈活的查詢條件。為了增強對運算的支持能力,SQL提供了眾多實用的運算函數供廣大用戶使用。例如,我們可以直接在SQL命令中調用SUM或AVG這兩個分別用於計算總數和平均數的函數。語法格式如下:
SELECT "function type"("column_name")
FROM "table_name"
如果我們希望查詢Store_Information數據表中所有商店的總銷售額的話,可以使用如下命令:
SELECT SUM(Sales) FROM Store_Information
查詢結果顯示為:
SUM(Sales)
$2750
COUNT
除了SUM和AVG函數之外,COUNT函數是SQL語言中另一個較為常用的運算函數。COUNT函數可以用來計算數據表中指定欄位所包含的記錄數目。語法格式為:
SELECT COUNT("column_name")
FROM "table_name"
例如,如果我們希望查詢Store_Information數據表中的有關商店的記錄條數時,可以使用如下命令:
SELECT COUNT(store_name)
FROM Store_Information
查詢結果顯示為:
Count(store_name)
4
COUNT函數可以和DISTINCT關鍵字一起使用從而可以查詢數據表中指定欄位中所有具有不同記錄值的記錄數目。例如,如果我們希望查詢Store_Information數據表中不同商店的數目時,可以使用如下命令:
SELECT COUNT(DISTINCT store_name)
FROM Store_Information
查詢結果顯示為:
Count(DISTINCT store_name)
3
GROUP BY
下面我們來進一步看一下SQL語言中的集合函數。上文中,我們曾使用SUM函數計算所有商店的銷售總額,如果我們希望計算每一家商店各自的總銷售額時該怎麼辦呢?要實現這一目的我們需要做兩件事:首先,我們需要查詢商店名稱和銷售額兩個欄位;然後,我們使用SQL語言的GROUP BY命令將銷售額按照不同的商店進行分組,從而計算出不同商店的銷售總額。GROUP BY命令的語法格式為:
SELECT "column_name1", SUM("column_name2")
FROM "table_name"
GROUP BY "column_name1"
我們可以使用如下命令實現上述查詢目的:
SELECT store_name, SUM(Sales)
FROM Store_Information
GROUP BY store_name
查詢結果顯示為:
store_name SUM(Sales)
Los Angeles $1800
San Diego $250
Boston $700
小註:
GROUP BY關鍵字一般應用於同時查詢多個欄位並對欄位進行算術運算的SQL命令中。
HAVING
用戶在使用SQL語言的過程中可能希望解決的另一個問題就是對由sum或其它集合函數運算結果的輸出進行限制。例如,我們可能只希望看到Store_Information數據表中銷售總額超過1500美圓的商店的信息,這時我們就需要使用HAVING從句。語法格式為:
SELECT "column_name1", SUM("column_name2")
FROM "table_name"
GROUP BY "column_name1"
HAVING (arithematic function condition)
(GROUP BY從句可選)
由此,我們可以使用如下命令實現上述查詢目的:
SELECT store_name, SUM(sales)
FROM Store_Information
GROUP BY store_name
HAVING SUM(sales) > 1500
查詢結果顯示為:
store_name SUM(Sales)
Los Angeles $1800
小註:
SQL語言中設定集合函數的查詢條件時使用HAVING從句而不是WHERE從句。通常情況下,HAVING從句被放置在SQL命令的結尾處。下面,我們重點介紹一下如何在SQL命令中設定別名。SQL語言中一般使用兩種類型的別名,分別為欄位別名和數據表別名。
簡單的說,使用欄位別名可以幫助我們有效的組織查詢的輸出結果。例如,上文所列舉的多個實例中,當我們計算商店銷售總額時,顯示結果中就會出現SUM(sales)。雖然SUM(sales)並不會對我們理解查詢結果帶來不便,但是如果我們需要在查詢中使用多項復雜運算時,顯示結果就不會這么直觀了。如果這時我們使用欄位別名就會極大的提高查詢結果的可讀性。
對於數據表別名,我們可以通過將別名直接放置在FROM從句中數據表名稱的後面設定。數據表別名在我們下面將要講述的連接多個數據表進行查詢的操作中極為有用。
欄位和數據表別名的語法格式如下:
SELECT "table_alias"."column_name1" "column_alias"
FROM "table_name" "table_alias"
即別名都直接放置在各自對應名稱的後面,中間用空格分開。
以Store_Information數據表為例,我們可以在GROUP BY一節中所使用的SQL命令中設置如下欄位和數據表別名:
SELECT A1.store_name Store, SUM(Sales) "Total Sales"
FROM Store_Information A1
GROUP BY A1.store_name
查詢結果顯示為:
Store Total Sales
Los Angeles $1800
San Diego $250
Boston $700
連接多個數據表
最後,我們來看一下如果使用SQL語言連接多個數據表,實現對多個數據表的查詢。為方便講解,我們在資料庫中分別創建了兩個名為Store_Information和Region的數據表。
Store_Information
Store_Name
Sales
Date
Los Angeles
$1500
Jan-10-2000
San Diego
$250
Jan-11-2000
Los Angeles
$300
Jan-12-2000
Boston
$700
Jan-12-2000
Region
Region_Name
Store_Name
East
Boston
East
New York
West
Los Angeles
West
San Diego
下面,我們就來看一下通過數據表的連接實現按不同區域查詢銷售額。
我們注意到在名為Region的數據表中包含區域和商店兩個欄位信息,而在名為Store_Information的數據表中則包含每一家商店的銷售信息。因此,為了得到按區域劃分的銷售信息,我們需要將兩個不同數據表的信息結合在一起進行查詢。通過對上述兩個數據表的分析,我們發現每個數據表中都包含一個名為Store_Name的欄位,因此,我們可以使用如下命令實現查詢目的:
SELECT A1.region_name REGION, SUM(A2.Sales) SALES
FROM Geography A1, Store_Information A2
WHERE A1.store_name = A2.store_name
GROUP BY A1.region_name
查詢結果顯示為:
REGION SALES
East $700
West $2050
說明:
上述查詢命令的前兩行用於指定所要查詢的目標欄位,分別為Region數據表中的Region_Name欄位和Store_Information數據表中Sales欄位的記錄值總數。這里,我們設定兩個欄位的別名分別為REGION和SALES,兩個數據表的別名分別為A1和A2。如果我們只使用欄位別名而不設定數據表別名的話,上述SQL命令的第一行就變成 如下形式:
SELECT Region.Region_Name REGION, SUM(Store_Information.Sales) SALES
由此我們可以看出有效的使用數據表別名,可以極大的簡化對多個數據表進行操作的SQL命令。
上述查詢命令的第3行為WHERE從句,正是該從句設定了兩個數據表的連接條件。因為我們希望確保Region數據表中的Store_Name欄位能夠與Store_Information數據表中的同名欄位相對應,所以我們規定兩個欄位的記錄值應當相等。在連接多個數據表時,一定要准確設定數據表的連接條件,如果WHERE從句設定不正確,則可能導致查詢結果中出現眾多不相關的數據
F. SQL語句那有問題
mysql中,前面創建表沒問題。
1、alter table major alter column MNO char(5)not null 修改成
alter table major modify column MNO char(5) not null
2、alter table major alter column MNAME varchar(32)not null 修改成
alter table major modify column MNAME varchar(32)not null
3、alter table major alter column deptNO char(5)not null 修改成
alter table major modify column deptNO char(5)not null
可以去看看alert column、modify column和change column的用法
G. SQL的語句問題
你所說的進存銷就是 sql 語句查詢 添加 修改 刪除
SQL INSERT 語句
這里有一個如何使用這種語句的例子:[code]INSERT mytable (mycolumn) VALUES (『some data』) [/code]這個語句把字元串』some data』插入表mytable的mycolumn欄位中。將要被插入數據的欄位的名字在第一個括弧中指定,實際的數據在第二個括弧中給出。INSERT 語句的完整句法如下:[code]INSERT [INTO] {table_name|view_name} [(column_list)] {DEFAULT VALUES |Values_list | select_statement} [/code]如果一個表有多個欄位,通過把欄位名和欄位值用逗號隔開,你可以向所有的欄位中插入數據。假設表mytable有三個欄位first_column,second_column,和third_column。下面的INSERT語句添加了一條三個欄位都有值的完整記錄:[code]INSERT mytable (first_column,second_column,third_column)
VALUES (『some data』,』some more data』,』yet more data』) [/code]注意
你可以使用INSERT語句向文本型欄位中插入數據。但是,如果你需要輸入很長的字元串,你應該使用WRITETEXT語句。這部分內容對本書來說太高級了,因此不加討論。要了解更多的信息,請參考Microsoft SQL Sever 的文檔。
如果你在INSERT 語句中只指定兩個欄位和數據會怎麼樣呢?換句話說,你向一個表中插入一條新記錄,但有一個欄位沒有提供數據。在這種情況下,有下面的四種可能:
如果該欄位有一個預設值,該值會被使用。例如,假設你插入新記錄時沒有給欄位third_column提供數據,而這個欄位有一個預設值』some value』。在這種情況下,當新記錄建立時會插入值』some value』。
如果該欄位可以接受空值,而且沒有預設值,則會被插入空值。如果該欄位不能接受空值,而且沒有預設值,就會出現錯誤。你會收到錯誤信息:
The column in table mytable may not be null.
最後,如果該欄位是一個標識欄位,那麼它會自動產生一個新值。當你向一個有標識欄位的表中插入新記錄時,只要忽略該欄位,標識欄位會給自己賦一個新值。
注意
向一個有標識欄位的表中插入新記錄後,你可以用SQL變數@@identity來訪問新記錄
的標識欄位的值。考慮如下的SQL語句:[code]INSERT mytable (first_column) VALUES(『some value』) [code]
[code]INSERT anothertable(another_first,another_second)
VALUES(@@identity,』some value』) [/code]如果表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』的記錄:[code]DELETE mytable WHERE first_column=』Deltet Me』 [/code]DELETE 語句的完整句法如下:[code]DELETE [FROM] {table_name|view_name} [WHERE clause] [/code]在SQL SELECT 語句中可以使用的任何條件都可以在DELECT 語句的WHERE子句 中使用。例如,下面的這個DELETE語句只刪除那些first_column欄位的值為』goodbye』或second_column欄位的值為』so long』的記錄:[code]DELETE mytable WHERE first_column=』goodby』 OR second_column=』so long』 [/code]如果你不給DELETE 語句提供WHERE 子句,表中的所有記錄都將被刪除。你不應該有這種想法。如果你想刪除應該表中的所有記錄,應使用第十章所講的TRUNCATE TABLE語句。
注意
為什麼要用TRUNCATE TABLE 語句代替DELETE語句?當你使用TRUNCATE TABLE語句時,記錄的刪除是不作記錄的。也就是說,這意味著TRUNCATE TABLE 要比DELETE快得多。
更新記錄
要修改表中已經存在的一條或多條記錄,應使用SQL UPDATE語句。同DELETE語句一樣,UPDATE語句可以使用WHERE子句來選擇更新特定的記錄。請看這個例子:[code]UPDATE mytable SET first_column=』Updated!』 WHERE second_column=』Update Me!』 [/code]這個UPDATE 語句更新所有second_column欄位的值為』Update Me!』的記錄。對所有被選中的記錄,欄位first_column的值被置為』Updated!』。
下面是UPDATE語句的完整句法:[code]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] [/code]注意
你可以對文本型欄位使用UPDATE語句。但是,如果你需要更新很長的字元串,應使用UPDATETEXT語句。這部分內容對本書來說太高級了,因此不加討論。要了解更多的信息,請參考Microsoft SQL Sever 的文檔。
如果你不提供WHERE子句,表中的所有記錄都將被更新。有時這是有用的。例如,如果你想把表titles中的所有書的價格加倍,你可以使用如下的UPDATE 語句:
你也可以同時更新多個欄位。例如,下面的UPDATE語句同時更新first_column,second_column,和third_column這三個欄位:[code]UPDATE mytable SET first_column=』Updated!』
Second_column=』Updated!』
Third_column=』Updated!』
WHERE first_column=』Update Me1』 [/code]技巧
SQL忽略語句中多餘的空格。你可以把SQL語句寫成任何你最容易讀的格式。
用SELECT 創建記錄和表
你也許已經注意到,INSERT 語句與DELETE語句和UPDATE語句有一點不同,它一次只操作一個記錄。然而,有一個方法可以使INSERT 語句一次添加多個記錄。要作到這一點,你需要把INSERT 語句與SELECT 語句結合起來,象這樣:[code]INSERT mytable (first_column,second_column)
SELECT another_first,another_second
FROM anothertable
WHERE another_first=』Copy Me!』 [/code]這個語句從anothertable拷貝記錄到mytable.只有表anothertable中欄位another_first的值為』Copy Me!』的記錄才被拷貝。
當為一個表中的記錄建立備份時,這種形式的INSERT 語句是非常有用的。在刪除一個表中的記錄之前,你可以先用這種方法把它們拷貝到另一個表中。
如果你需要拷貝整個表,你可以使用SELECT INTO 語句。例如,下面的語句創建了一個名為newtable的新表,該表包含表mytable的所有數據:[code]SELECT * INTO newtable FROM mytable [/code]你也可以指定只有特定的欄位被用來創建這個新表。要做到這一點,只需在欄位列表中指定你想要拷貝的欄位。另外,你可以使用WHERE 子句來限制拷貝到新表中的記錄。下面的例子只拷貝欄位second_columnd的值等於』Copy Me!』的記錄的first_column欄位。[code]SELECT first_column INTO newtable
FROM mytable
WHERE second_column=』Copy Me!』 [/code]使用SQL修改已經建立的表是很困難的。例如,如果你向一個表中添加了一個欄位,沒有容易的辦法來去除它。另外,如果你不小心把一個欄位的數據類型給錯了,你將沒有辦法改變它。但是,使用本節中講述的SQL語句,你可以繞過這兩個問題。
例如,假設你想從一個表中刪除一個欄位。使用SELECT INTO 語句,你可以創建該表的一個拷貝,但不包含要刪除的欄位。這使你既刪除了該欄位,又保留了不想刪除的數據。
如果你想改變一個欄位的數據類型,你可以創建一個包含正確數據類型欄位的新表。創建好該表後,你就可以結合使用UPDATE語句和SELECT 語句,把原來表中的所有數據拷貝到新表中。通過這種方法,你既可以修改表的結構,又能保存原有的數據。
H. java程序,SQL語句的問題
根據錯誤提示信息,可以明顯知道是 「學號=getUser」有問題,若你有使用數據層框架的話,則是為對getUser佔位符進行賦值,若沒用框架,則可能是sql語句單引號的緣故(參數為字元類型時,使用單引號進行包圍)。應該可以解決掉bug。
對於不同用戶顯示不同功能的需求,如果要做的完善點的話,可以添加一個許可權控制模塊,網上有很多這類的參考材料,而簡單的解決辦法就是直接寫死在代碼里,驗證是否管理員帳號再決定是否顯示功能
I. SQL語句問題
三句SQL語句
1、更新已經存在的數據
update b set b.wnum=a.wnum,b.wname=a.wname from a表 a inner join b表 on a.wnum=b.wnum
2、插入不存在的數據
insert into b表 (wnum,wname)
select a.wnum,a.wname from a表 a left join b表 on a.wnum=b.wnum where b.wnum isnull
3、刪除b表裡在a表裡不存在的數據
delete b from b left join a表 on a.wnum=b.wnum where a.wnum isnull