sql中的
㈠ sql的四個組成部分,到底是怎麼分的
(1)數據定義語言,即SQL DDL,用於定義SQL模式、基本表、視圖、索引等結構。
(2)數據操縱語言,即SQL DML。數據操縱分成數據查詢和數據更新兩類。
(3)數據查詢語言,即SQL DQL。
(4)數據控制語言,即SQL DCL,這一部分包括對基本表和視圖的授權、完整性規則的描述、事務控制等內容。
結構化查詢語言是高級的非過程化編程語言,允許用戶在高層數據結構上工作。它不要求用戶指定對數據的存放方法,也不需要用戶了解具體的數據存放方式,所以具有完全不同底層結構的不同資料庫系統, 可以使用相同的結構化查詢語言作為數據輸入與管理的介面。結構化查詢語言語句可以嵌套,這使它具有極大的靈活性和強大的功能。
(1)sql中的擴展閱讀:
SQL可以獨立完成資料庫生命周期中的全部活動,包括定義關系模式、錄入數據、建立資料庫、査詢、更新、維護、資料庫重構、資料庫安全性控制等一系列操作,這就為資料庫應用系統開發提供了良好的環境,在資料庫投入運行後,還可根據需要隨時逐步修改模式,且不影響資料庫的運行,從而使系統具有良好的可擴充性。
㈡ SQL中的符號^,!,$,#,&,各表示什麼意思
^(按位互斥 OR)
在 Transact-SQL 語句中,將兩個給定的整型值轉換為二進製表達式,對其執行按位互斥 OR 運算。
㈢ sql資料庫中常用的數據類型有什麼
一、整數數據類型:整數數據類型是最常用的數據類型之一。
1、INT(INTEGER)
INT (或INTEGER)數據類型存儲從-2的31次方 (-2 ,147 ,483 ,648) 到2的31次方-1 (2 ,147 ,483,647) 之間的所有正負整數。每個INT 類型的數據按4 個位元組存儲,其中1 位表示整數值的正負號,其它31 位表示整數值的長度和大小。
2、SMALLINT
SMALLINT 數據類型存儲從-2的15次方( -32, 768) 到2的15次方-1( 32 ,767 )之間的所有正負整數。每個SMALLINT 類型的數據佔用2 個位元組的存儲空間,其中1 位表示整數值的正負號,其它15 位表示整數值的長度和大小。
二、浮點數據類型:浮點數據類型用於存儲十進制小數。浮點數值的數據在SQL Server 中採用上舍入(Round up 或稱為只入不舍)方式進行存儲。
1、REAL數據類型
REAL數據類型可精確到第7 位小數,其范圍為從-3.40E -38 到3.40E +38。 每個REAL類型的數據佔用4 個位元組的存儲空間。
2、FLOAT
FLOAT數據類型可精確到第15 位小數,其范圍為從-1.79E -308 到1.79E +308。 每個FLOAT 類型的數據佔用8 個位元組的存儲空間。 FLOAT數據類型可寫為FLOAT[ n ]的形式。n 指定FLOAT 數據的精度。n 為1到15 之間的整數值。
當n 取1 到7 時,實際上是定義了一個REAL 類型的數據,系統用4 個位元組存儲它;當n 取8 到15 時,系統認為其是FLOAT 類型,用8 個位元組存儲它。
三、二進制數據類型
1、BINARY
BINARY 數據類型用於存儲二進制數據。其定義形式為BINARY( n), n 表示數據的長度,取值為1 到8000 。在使用時必須指定BINARY 類型數據的大小,至少應為1 個位元組。BINARY 類型數據佔用n+4 個位元組的存儲空間。
在輸入數據時必須在數據前加上字元「0X」 作為二進制標識,如:要輸入「abc 」則應輸入「0xabc 」。若輸入的數據過長將會截掉其超出部分。若輸入的數據位數為奇數,則會在起始符號「0X 」後添加一個0,如上述的「0xabc 」會被系統自動變為「0x0abc」。
2、VARBINARY
VARBINARY數據類型的定義形式為VARBINARY(n)。 它與BINARY 類型相似,n 的取值也為1 到8000, 若輸入的數據過長,將會截掉其超出部分。
不同的是VARBINARY數據類型具有變動長度的特性,因為VARBINARY數據類型的存儲長度為實際數值長度+4個位元組。當BINARY數據類型允許NULL 值時,將被視為VARBINARY數據類型。
四、邏輯數據類型
1、BIT:BIT數據類型佔用1 個位元組的存儲空間,其值為0 或1 。如果輸入0 或1 以外的值,將被視為1。 BIT 類型不能定義為NULL 值(所謂NULL 值是指空值或無意義的值)。
五、字元數據類型:字元數據類型是使用最多的數據類型。它可以用來存儲各種字母、數字元號、特殊符號。一般情況下,使用字元類型數據時須在其前後加上單引號』或雙引號」 。
1、CHAR
CHAR 數據類型的定義形式為CHAR[ (n) ]。 以CHAR 類型存儲的每個字元和符號佔一個位元組的存儲空間。n 表示所有字元所佔的存儲空間,n 的取值為1 到8000, 即可容納8000 個ANSI 字元。
若不指定n 值,則系統默認值為1。 若輸入數據的字元數小於n,則系統自動在其後添加空格來填滿設定好的空間。若輸入的數據過長,將會截掉其超出部分。
(3)sql中的擴展閱讀:
SQL包括了所有對資料庫的操作,主要是由4個部分組成:
1、數據定義:這一部分又稱為「SQL DDL」,定義資料庫的邏輯結構,包括定義資料庫、基本表、視圖和索引4部分。
2、數據操縱:這一部分又稱為「SQL DML」,其中包括數據查詢和數據更新兩大類操作,其中數據更新又包括插入、刪除和更新三種操作。
3、數據控制:對用戶訪問數據的控制有基本表和視圖的授權、完整性規則的描述,事務控制語句等。
4、嵌入式SQL語言的使用規定:規定SQL語句在宿主語言的程序中使用的規則。
㈣ sql中=和:=的區別
一、區別:
sql中':='符號為對變數賦值;
'='符號為if等條件判斷中使用;
以下為示例演示,
1、編寫sql腳本,
declare
v1 varchar2(20);
v2 varchar2(20);
begin
v1 := 10;
v2 := 20;
if v1 = 10 then
dbms_output.put_line('v1=10');
end if;
if v2 = 20 then
dbms_output.put_line('v2=10');
end if;
end;
㈤ SQl中「(+)」表示什麼意思
在select語句中(+)指的是外連接,是連接查詢的一種方法。
例:select t1.*,t2.* from dept t1,emp t2 where t1.deptno=t2.deptno(+);
其中:t1.deptno=t2.deptno(+)代表意思是,
即使t2(emp表)中不存在匹配的記錄,
在t1(dept表)也查詢出來。
㈥ sql中「<>」是什麼意思
sql中「<>」是「不等於」的意思。
㈦ SQL server 中的@,@@、#,##分別代表什麼
@ 表示局部變數
@@ 表示全局變數
# 表示本地臨時表的名稱,以單個數字元號打頭;它們僅對當前的用戶連接是可見的
## 表示全局臨時表
使用事例如下圖所示:
(7)sql中的擴展閱讀:
本地臨時表
以一個井號 (#) 開頭的表名。只有在創建本地臨時表連接是才能看得到,連接斷開時臨時表立馬被刪除,也就是到貨本地臨時表為創建它的該鏈接的會話所獨有,或者說局部臨時表是有當前用戶創建的,並且只有當前用戶的會話才可以訪問。
全局臨時表
以兩個井號 (##) 開頭的表名。在所有連接上都能看到全局臨時表,也就是說只要全局臨時表存在,那麼對所有創建用戶的會話後都是可見的。如果在創建全局臨時表的連接斷開前沒有顯式地除去全局臨時表,那麼只能等到其它所有任務都停止引用,這些表才會被刪除。
當創建全局臨時表的連接斷開後,新的任務不能再引用它們,也就是說舊的任務才可以引用。當前的語句一執行完,任務與表之間的關聯即被除去;因此通常情況下,只要創建全局臨時表的連接斷開,全局臨時表也會同時被刪除。
㈧ sql 語句 中的表示什麼意思
sql語句中的?相當於一個變數,你可以再其後通過具體賦值,例如setString(1,「nihao」),設置對應?位置處的變數的值。
這樣做的目的是:當你有很多相同的sql語句執行時,可以先發出sql語句的定義,然後再將具體的值傳過去,這樣只發了一次sql語句,提高效率;否則,你發多次相同的sql語句,效率就低了。另外,在防sql注入方面,可以通過這樣的方法來避免簡單的侵害。