『壹』 求一份openGauss常用sql示例 做個簡單的入門練手測試~
如下羅列了一些創建、增、刪、改、查相關,請參考(涉及的具體語法及參數自行查閱官方文檔):
--1.CREATE USER
--創建用戶jim,登錄密碼為xxxxxxxxx。
openGauss=# CREATE USER jim PASSWORD 'xxxxxxxxx';
--下面語句與上面的等價。
openGauss=# CREATE USER kim IDENTIFIED BY 'xxxxxxxxx';
--如果創建有「創建資料庫」許可權的用戶,則需要加CREATEDB關鍵字。
openGauss=# CREATE USER dim CREATEDB PASSWORD 'xxxxxxxxx';
--將用戶jim的登錄密碼由xxxxxxxxx修改為Abcd@123。
openGauss=# ALTER USER jim IDENTIFIED BY 'Abcd@123' REPLACE 'xxxxxxxxx';
--為用戶jim追加CREATEROLE許可權。
openGauss=# ALTER USER jim CREATEROLE;
--將enable_seqscan的值設置為on, 設置成功後,在下一會話中生效。
openGauss=# ALTER USER jim SET enable_seqscan TO on;
--重置jim的enable_seqscan參數。
openGauss=# ALTER USER jim RESET enable_seqscan;
--鎖定jim帳戶。
openGauss=# ALTER USER jim ACCOUNT LOCK;
--刪除用戶。
openGauss=# DROP USER kim CASCADE;
openGauss=# DROP USER jim CASCADE;
openGauss=# DROP USER dim CASCADE;
--2.創建和管理資料庫
--使用如下命令創建一個新的資料庫db_tpcc。
openGauss=# CREATE DATABASE db_tpcc;
註:
•資料庫名稱遵循SQL標識符的一般規則。當前角色自動成為此新資料庫的所有者。
•如果一個資料庫系統用於承載相互獨立的用戶和項目,建議把它們放在不同的資料庫里。
•如果項目或者用戶是相互關聯的,並且可以相互使用對方的資源,則應該把它們放在同一個資料庫里,但可以規劃在不同的模式中。模式只是一個純粹的邏輯結構,某個模式的訪問許可權由許可權系統模塊控制。
•創建資料庫時,若資料庫名稱長度超過63位元組,server端會對資料庫名稱進行截斷,保留前63個位元組,因此建議資料庫名稱長度不要超過63個位元組。
--查看資料庫
•使用\l元命令查看資料庫系統的資料庫列表。
openGauss=# \l
•使用如下命令通過系統表pg_database查詢資料庫列表。
openGauss=# SELECT datname FROM pg_database;
--修改資料庫
用戶可以使用如下命令修改資料庫屬性(比如:owner、名稱和默認的配置屬性)。
•使用以下命令為資料庫設置默認的模式搜索路徑。
openGauss=# ALTER DATABASE db_tpcc SET search_path TO pa_catalog,public;
--使用如下命令為資料庫重新命名。
openGauss=# ALTER DATABASE db_tpcc RENAME TO human_tpcds;
--刪除資料庫
用戶可以使用DROP DATABASE命令刪除資料庫。這個命令刪除了資料庫中的系統目錄,並且刪除了磁碟上帶有數據的資料庫目錄。用戶必須是資料庫的owner或者系統管理員才能刪除資料庫。當有人連接資料庫時,刪除操作會失敗。刪除資料庫時請先連接到其他的資料庫。
使用如下命令刪除資料庫:
openGauss=# DROP DATABASE human_tpcds;
--3.CREATE TABLE
--表是建立在資料庫中的,在不同的資料庫中可以存放相同的表。甚至可以通過使用模式在同一個資料庫中創建相同名稱的表。創建表前請先規劃存儲模型。
openGauss=# CREATE TABLE customer_t1
(
c_customer_sk integer,
c_customer_id char(5),
c_first_name char(6),
c_last_name char(8)
);
當結果顯示為如下信息,則表示創建成功。
CREATE TABLE
其中c_customer_sk 、c_customer_id、c_first_name和c_last_name是表的欄位名,integer、char(5)、char(6)和char(8)分別是這四欄位名稱的類型。
--4.向表中插入數據
--向表中插入數據前,意味著表已創建成功。
向表customer_t1中插入一行:
數據值是按照這些欄位在表中出現的順序列出的,並且用逗號分隔。通常數據值是文本(常量),但也允許使用標量表達式。
openGauss=# INSERT INTO customer_t1(c_customer_sk, c_customer_id, c_first_name) VALUES (3769, 'hello', 'Grace');
如果用戶已經知道表中欄位的順序,也可無需列出表中的欄位。例如以下命令與上面的命令效果相同。
openGauss=# INSERT INTO customer_t1 VALUES (3769, 'hello', 'Grace');
如果用戶不知道所有欄位的數值,可以忽略其中的一些。沒有數值的欄位將被填充為欄位的預設值。例如:
openGauss=# INSERT INTO customer_t1 (c_customer_sk, c_first_name) VALUES (3769, 'Grace');
openGauss=# INSERT INTO customer_t1 VALUES (3769, 'hello');
用戶也可以對獨立的欄位或者整個行明確預設值:
openGauss=# INSERT INTO customer_t1 (c_customer_sk, c_customer_id, c_first_name) VALUES (3769, 'hello', DEFAULT);
openGauss=# INSERT INTO customer_t1 DEFAULT VALUES;
如果需要在表中插入多行,請使用以下命令:
openGauss=# INSERT INTO customer_t1 (c_customer_sk, c_customer_id, c_first_name) VALUES
(6885, 'maps', 'Joes'),
(4321, 'tpcds', 'Lily'),
(9527, 'world', 'James');
如果需要向表中插入多條數據,除此命令外,也可以多次執行插入一行數據命令實現。但是建議使用此命令可以提升效率。
如果從指定表插入數據到當前表,例如在資料庫中創建了一個表customer_t1的備份表customer_t2,現在需要將表customer_t1中的數據插入到表customer_t2中,則可以執行如下命令。
openGauss=# CREATE TABLE customer_t2
(
c_customer_sk integer,
c_customer_id char(5),
c_first_name char(6),
c_last_name char(8)
);
openGauss=# INSERT INTO customer_t2 SELECT * FROM customer_t1;
從指定表插入數據到當前表時,若指定表與當前表對應的欄位數據類型之間不存在隱式轉換,則這兩種數據類型必須相同。
刪除備份表
openGauss=# DROP TABLE customer_t2 CASCADE;
在刪除表的時候,若當前需刪除的表與其他表有依賴關系,需先刪除關聯的表,然後再刪除當前表。
--5.更新表中數據
修改已經存儲在資料庫中數據的行為叫做更新。用戶可以更新單獨一行,所有行或者指定的部分行。還可以獨立更新每個欄位,而其他欄位則不受影響。
使用UPDATE命令更新現有行,需要提供以下三種信息:
•表的名稱和要更新的欄位名
•欄位的新值
•要更新哪些行
SQL通常不會為數據行提供唯一標識,因此無法直接聲明需要更新哪一行。但是可以通過聲明一個被更新的行必須滿足的條件。只有在表裡存在主鍵的時候,才可以通過主鍵指定一個獨立的行。
建立表和插入數據的步驟請參考創建表和向表中插入數據。
需要將表customer_t1中c_customer_sk為9527的地域重新定義為9876:
openGauss=# UPDATE customer_t1 SET c_customer_sk = 9876 WHERE c_customer_sk = 9527;
這里的表名稱也可以使用模式名修飾,否則會從默認的模式路徑找到這個表。SET後面緊跟欄位和新的欄位值。新的欄位值不僅可以是常量,也可以是變數表達式。
比如,把所有c_customer_sk的值增加100:
openGauss=# UPDATE customer_t1 SET c_customer_sk = c_customer_sk + 100;
在這里省略了WHERE子句,表示表中的所有行都要被更新。如果出現了WHERE子句,那麼只有匹配其條件的行才會被更新。
在SET子句中的等號是一個賦值,而在WHERE子句中的等號是比較。WHERE條件不一定是相等測試,許多其他的操作符也可以使用。
用戶可以在一個UPDATE命令中更新更多的欄位,方法是在SET子句中列出更多賦值,比如:
openGauss=# UPDATE customer_t1 SET c_customer_id = 'Admin', c_first_name = 'Local' WHERE c_customer_sk = 4421;
批量更新或刪除數據後,會在數據文件中產生大量的刪除標記,查詢過程中標記刪除的數據也是需要掃描的。故多次批量更新/刪除後,標記刪除的數據量過大會嚴重影響查詢的性能。建議在批量更新/刪除業務會反復執行的場景下,定期執行VACUUM FULL以保持查詢性能。
--6.查看數據
使用系統表pg_tables查詢資料庫所有表的信息。
openGauss=# SELECT * FROM pg_tables;
使用gsql的\d+命令查詢表的屬性。
openGauss=# \d+ customer_t1;
執行如下命令查詢表customer_t1的數據量。
openGauss=# SELECT count(*) FROM customer_t1;
執行如下命令查詢表customer_t1的所有數據。
openGauss=# SELECT * FROM customer_t1;
執行如下命令只查詢欄位c_customer_sk的數據。
openGauss=# SELECT c_customer_sk FROM customer_t1;
執行如下命令過濾欄位c_customer_sk的重復數據。
openGauss=# SELECT DISTINCT( c_customer_sk ) FROM customer_t1;
執行如下命令查詢欄位c_customer_sk為3869的所有數據。
openGauss=# SELECT * FROM customer_t1 WHERE c_customer_sk = 3869;
執行如下命令按照欄位c_customer_sk進行排序。
openGauss=# SELECT * FROM customer_t1 ORDER BY c_customer_sk;
--7.刪除表中數據
在使用表的過程中,可能會需要刪除已過期的數據,刪除數據必須從表中整行的刪除。
SQL不能直接訪問獨立的行,只能通過聲明被刪除行匹配的條件進行。如果表中有一個主鍵,用戶可以指定準確的行。用戶可以刪除匹配條件的一組行或者一次刪除表中的所有行。
使用DELETE命令刪除行,如果刪除表customer_t1中所有c_customer_sk為3869的記錄:
openGauss=# DELETE FROM customer_t1 WHERE c_customer_sk = 3869;
如果執行如下命令之一,會刪除表中所有的行。
openGauss=# DELETE FROM customer_t1;
或
openGauss=# TRUNCATE TABLE customer_t1;
全表刪除的場景下,建議使用truncate,不建議使用delete。
刪除創建的表:
openGauss=# DROP TABLE customer_t1;
『貳』 「本系統資料庫軟體應支持SQL和ODBC兩種工業標准」~~~這句話是什麼意思
哈哈,招標需求上的么?
不要太較真了,如果SQL沒有提及是那種,其實就是支持OLEDB和ODBC兩種資料庫連接方式,這兩個的詳細描述,都可以在網路查到,不贅述了。
『叄』 t-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 位表示整數值的長度和大小。
3、TINYINT
TINYINT數據類型存儲從0 到255 之間的所有正整數。每個TINYINT類型的數據佔用1 個位元組的存儲空間。
4、BIGINT
BIGINT 數據類型存儲從-2^63 (-9 ,223, 372, 036, 854, 775, 807) 到2^63-1( 9, 223, 372, 036 ,854 ,775, 807) 之間的所有正負整數。每個BIGINT 類型的數據佔用8個位元組的存儲空間。
二、 浮點數據類型
浮點數據類型用於存儲十進制小數。浮點數值的數據在SQLServer中採用上舍入(Round up 或稱為只入不舍)方式進行存儲。所謂上舍入是指,當(且僅當)要舍入的數是一個非零數時,對其保留數字部分的最低有效位上的數值加1 ,並進行必要的進位。若一個數是上舍入數,其絕對值不會減少。如:對3.14159265358979 分別進行2 位和12位舍入,結果為3.15 和3.141592653590。
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 個位元組存儲它。
3、DECIMAL
DECIMAL數據類型可以提供小數所需要的實際存儲空間,但也有一定的限制,您可以用2 到17 個位元組來存儲從-10的38次方-1 到10的38次方-1 之間的數值。可將其寫為DECIMAL[ p [s] ]的形式,p 和s 確定了精確的比例和數位。其中p 表示可供存儲的值的總位數(不包括小數點),預設值為18; s 表示小數點後的位數,預設值為0。 例如:decimal (15 5),表示共有15 位數,其中整數10 位,小數5。 位表4-3 列出了各精確度所需的位元組數之間的關系。
4、NUMERIC
NUMERIC數據類型與DECIMAL數據類型完全相同。
注意:SQLServer為了和前端的開發工具配合,其所支持的數據精度默認最大為28位。
三、 二進制數據類型
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數據類型。
一般情況下,由於BINARY 數據類型長度固定,因此它比VARBINARY 類型的處理速度快。
四、 邏輯數據類型
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,則系統自動在其後添加空格來填滿設定好的空間。若輸入的數據過長,將會截掉其超出部分。
2、NCHAR
NCHAR數據類型的定義形式為NCHAR[ (n) ]。 它與CHAR 類型相似。不同的是NCHAR數據類型n 的取值為1 到4000。 因為NCHAR 類型採用UNICODE 標准字元集(CharacterSet)。 UNICODE 標准規定每個字元佔用兩個位元組的存儲空間,所以它比非UNICODE 標準的數據類型多佔用一倍的存儲空間。使用UNICODE 標準的好處是因其使用兩個位元組做存儲單位,其一個存儲單位的容納量就大大增加了,可以將全世界的語言文字都囊括在內,在一個數據列中就可以同時出現中文、英文、法文、德文等,而不會出現編碼沖突。
3、VARCHAR
VARCHAR數據類型的定義形式為VARCHAR [ (n) ]。 它與CHAR 類型相似,n 的取值也為1 到8000, 若輸入的數據過長,將會截掉其超出部分。不同的是,VARCHAR數據類型具有變動長度的特性,因為VARCHAR數據類型的存儲長度為實際數值長度,若輸入數據的字元數小於n ,則系統不會在其後添加空格來填滿設定好的空間。
一般情況下,由於CHAR 數據類型長度固定,因此它比VARCHAR 類型的處理速度快。
4、NVARCHAR
NVARCHAR數據類型的定義形式為NVARCHAR[ (n) ]。 它與VARCHAR 類型相似。不同的是,NVARCHAR數據類型採用UNICODE 標准字元集(Character Set), n 的取值為1 到4000。
六、文本和圖形數據類型
這類數據類型用於存儲大量的字元或二進制數據。
1、TEXT
TEXT數據類型用於存儲大量文本數據,其容量理論上為1 到2的31次方-1 (2, 147, 483, 647)個位元組,在實際應用時需要視硬碟的存儲空間而定。
SQLServer2000以前的版本中,資料庫中一個TEXT 對象存儲的實際上是一個指針,它指向一個個以8KB (8192 個位元組)為單位的數據頁(Data Page)。 這些數據頁是動態增加並被邏輯鏈接起來的。在SQL Server 2000中,則將TEXT 和IMAGE 類型的數據直接存放到表的數據行中,而不是存放到不同的數據頁中。 這就減少了用於存儲TEXT 和IMA- GE 類型的空間,並相應減少了磁碟處理這類數據的I/O 數量。
2 NTEXT
NTEXT數據類型與TEXT.類型相似不同的,是NTEXT 類型採用UNICODE 標准字元集(Character Set), 因此其理論容量為230-1(1, 073, 741, 823)個位元組。
3 IMAGE
IMAGE數據類型用於存儲大量的二進制數據Binary Data。 其理論容量為2的31次方-1(2,147,483,647)個位元組。其存儲數據的模式與TEXT 數據類型相同。通常用來存儲圖形等OLE Object Linking and Embedding,對象連接和嵌入)對象。在輸入數據時同BINARY數據類型一樣,必須在數據前加上字元「0X」作為二進制標識
七、日期和時間數據類型
1 DATETIME
DATETIME 數據類型用於存儲日期和時間的結合體。它可以存儲從公元1753 年1 月1 日零時起到公元9999 年12 月31 日23 時59 分59 秒之間的所有日期和時間,其精確度可達三百分之一秒,即3.33 毫秒。DATETIME 數據類型所佔用的存儲空間為8 個位元組。其中前4 個位元組用於存儲1900 年1 月1 日以前或以後的天數,數值分正負,正數表示在此日期之後的日期,負數表示在此日期之前的日期。後4 個位元組用於存儲從此日零時起所指定的時間經過的毫秒數。如果在輸入數據時省略了時間部分,則系統將12:00:00:000AM作為時間預設值:如果省略了日期部分,則系統將1900 年1 月1 日作為日期預設值。
2 SMALLDATETIME
SMALLDATETIME 數據類型與DATETIME 數據類型相似,但其日期時間范圍較小,為從1900 年1 月1 日到2079 年6 月6:日精度較低,只能精確到分鍾,其分鍾個位上為根據秒數四捨五入的值,即以30 秒為界四捨五入。如:DATETIME 時間為14:38:30.283時SMALLDATETIME 認為是14:39:00 SMALLDATETIME 數據類型使用4 個位元組存儲數據。其中前2 個位元組存儲從基礎日期1900 年1 月1 日以來的天數,後兩個位元組存儲此日零時起所指定的時間經過的分鍾數。
八、 貨幣數據類型
貨幣數據類型用於存儲貨幣值。在使用貨幣數據類型時,應在數據前加上貨幣符號,系統才能辨識其為哪國的貨幣,如果不加貨幣符號,則默認為「¥」。各貨幣符號如圖4-2所示。
1 MONEY
MONEY 數據類型的數據是一個有4 位小數的DECIMAL 值,其取值從-2的63次方(-922,337,203,685,477.5808到2的63次方-1(+922,337,203,685,477.5807),數據精度為萬分之一貨幣單位。MONEY 數據類型使用8個位元組存儲。
2 SMALLMONEY
SMALLMONEY數據類型類似於MONEY 類型,但其存儲的貨幣值范圍比MONEY數據類型小,其取值從-214,748.3648到+214,748.3647,存儲空間為4 個位元組。
九、 特定數據類型
SQL Server 中包含了一些用於數據存儲的特殊數據類型。
1 TIMESTAMP
TIMESTAMP數據類型提供資料庫范圍內的惟一值此類型相當於BINARY8或VARBINARY(8),但當它所定義的列在更新或插入數據行時,此列的值會被自動更新,一個計數值將自動地添加到此TIMESTAMP數據列中。每個資料庫表中只能有一個TIMESTAMP數據列。如果建立一個名為「TIMESTAMP」的列,則該列的類型將被自動設為TIMESTAMP數據類型。
2 UNIQUEIDENTIFIER
UNIQUEIDENTIFIER 數據類型存儲一個16 位的二進制數字。此數字稱為(GUIDGlobally Unique Identifier ,即全球惟一鑒別號)。此數字由SQLServer 的NEWID函數產生的全球惟一的編碼,在全球各地的計算機經由此函數產生的數字不會相同。
十、 用戶自定義數據類型
SYSNAME SYSNAME 數據類型是系統提供給用戶的,便於用戶自定義數據類型。它被定義為NVARCHAR(128),即它可存儲128個UNICODE字元或256個一般字元。
以表格形式說明:
欄位類型 描述
bit 0或1的整型數字
int 從-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型數字
smallint 從-2^15(-32,768)到2^15(32,767)的整型數字
tinyint 從0到255的整型數字
decimal 從-10^38到10^38-1的定精度與有效位數的數字
numeric decimal的同義詞
money 從-2^63(-922,337,203,685,477.5808)到2^63-1(922,337,203,685,477.5807)的貨幣數據,最小貨幣單位千分之十
smallmoney 從-214,748.3648到214,748.3647的貨幣數據,最小貨幣單位千分之十
float 從-1.79E+308到1.79E+308可變精度的數字
real 從-3.04E+38到3.04E+38可變精度的數字
datetime 從1753年1月1日到9999年12日31的日期和時間數據,最小時間單位為百分之三秒或3.33毫秒
smalldatetime 從1900年1月1日到2079年6月6日的日期和時間數據,最小時間單位為分鍾
timestamp 時間戳,一個資料庫寬度的唯一數字
uniqueidentifier 全球唯一標識符GUID
char 定長非Unicode的字元型數據,最大長度為8000
varchar 變長非Unicode的字元型數據,最大長度為8000
text 變長非Unicode的字元型數據,最大長度為2^31-1(2G)
nchar 定長Unicode的字元型數據,最大長度為8000
nvarchar 變長Unicode的字元型數據,最大長度為8000
ntext 變長Unicode的字元型數據,最大長度為2^31-1(2G)
binary 定長二進制數據,最大長度為8000
varbinary 變長二進制數據,最大長度為8000
image 變長二進制數據,最大長度為2^31-1(2G)
『肆』 mysql完全支持標準的sql語句是否正確
正確。
MySQL一直秉持的原則是實用主義。標準是什麼?什麼是標准?最多人使用的做法就是標准,不要削足適履。如果一個功能或者用法是很多人要求的,那麼mysql開發團隊就會做;如果很少的人要求某個功能或者用法,恐怕這個功能不會被優先開發,更別說為了支持標准而做無意義的開發。這種有效的實時互動,最大程度地確保了MySQL團隊所做的正是大量用戶所需要的,不會跑偏。並且mysql最終呈現給用戶的,一定是具有大量使用需求的功能集合,大概率對大量用戶也是有用的,是值得大家學習和使用的。這才是『標准』本來的意義和價值。
『伍』 SQL語言屬於sql server還是ORACLE
SQL全稱是「結構化查詢語言(Structured Query Language)」
是一種資料庫查詢和程序設計語言,用於存取數據以及查詢、更新和管理關系資料庫系統.
結構化查詢語言(Structured Query Language)最早是IBM的聖約瑟研究實驗室為其關系資料庫管理系統SYSTEM R開發的一種查詢語言,它的前身是SQUARE語言。SQL語言結構簡潔,功能強大,簡單易學,所以自從IBM公司1981年推出以來,SQL語言得到了廣泛的應用。如今無論是像Oracle、Sybase、Informix、SQL Server這些大型的資料庫管理系統,還是像Visual Foxporo、PowerBuilder這些PC上常用的資料庫開發系統,都支持SQL語言作為查詢語言。
現在所說的SQL,應該是泛指大部分資料庫廠商支持的SQL標准,即ANSI SQL.
1992年,ISO和IEC發布了SQL國際標准,稱為SQL-92。ANSI隨之發布的相應標準是ANSI SQL-92。ANSI SQL-92有時被稱為ANSI SQL。盡管不同的關系資料庫使用的SQL版本有一些差異,但大多數都遵循 ANSI SQL 標准。SQL Server使用ANSI SQL-92的擴展集,稱為T-SQL,其遵循ANSI制定的 SQL-92標准。
『陸』 關於標准SQL(結構化查詢語言)的版本問題
不管是T-SQL還是T-SQL增強版都是從標準的SQL語言演化來的,可能局部語法上有一些改動,但總體上都是一樣的。況且SQL Server的每個版本都具有很好的前向兼容性。所以在2008中使用2005的語言格式不會有任何問題。。
『柒』 關系資料庫的標准語言是什麼
關系資料庫的標准語言是SQL。
SQL (英文全稱:Structured Query Language),結構化查詢語言是關系資料庫的標准語言。1974年由 Boyce 和 Chamberlin 提出,1979年IBM公司首次在其關系資料庫系統 System R上實現了SQL。1986年由ANSI批准成為美國國家標准。隨即由ISO批准成為國際標准。歷經兩次修改(SQL-89,SQL-92)。
SQL功能包括:查詢(Query)、操縱(Manipulation)、定義(Definition)和控制(Control)四個方面,是一個綜合的、通用的、功能極強的關系資料庫語言。目前,幾乎所有的關系資料庫管理系統都支持SQL。
註:完全沒有問題,希望幫助到您。請及時點擊採納。
『捌』 關系資料庫的標准語言是
三、關系資料庫的標准語言———SQL
1.SQL概述SQL的英語名稱是結構查詢語言(Structured Query Language)實際上它的功能包括查詢(Query)、操縱(Manipulation)、定義(Definition)和控制(Control)四個方面,是一個綜合的、通用的、功能極強的關系資料庫語言。SQL支持資料庫的三級模式結構。
2.SQL的數據定義功能SQL的數據定義功能包括三部分:
定義基本表,定義視圖和定義索引。它們是:CREATE TABLE CREATE VIEW CREATE INDEX DROP TABLE DROP VIEW DROP INDEX SQL的數據定義功能可用於定義和修改模式(如基本表),定義外模式(如視圖)和內模式(如索引)。
3.基本表的定義與刪除定義基本表的語句格式為:
CREATE TABLE表名 (列名1 類型[NOT NULL]
[,列名2類型[NOT NULL]]…)[其他參數];其中,任選項「其它參數」是與物理存儲有關的參數。根據具體系統的不同而不同。刪除基本表的語句為:DROP TABLE表名;刪除索引的語句為:DROP INDEX索引名;刪除索引的同時把有關索引的描述也從數據字典中刪去。但表的內涵仍存在且其數據外延內容不變。把一個基本表的定義連同表上所有的記錄、索引以及由此基本表導出的所有視圖全部都刪除,並釋放相應的存儲空間。
4.索引的建立與刪除對一個基本表,可以根據應用環境的需要建立若干索引,以提供多種存取方式。通常,索引的建立和刪除由DBA或表的主人(即建立表的人)負責。用戶不必也不能在存取數據時選擇索引。存取路徑的選擇由系統自動進行。索引的描述存放在數據字典中。建立索引的語句格式為:
CREATE[UNIQUE] INDEX索引名ON基本表名(列名[次序][,列名[次序]]…)[其他參數];這里的任選項———其他參數是與物理存儲有關的參數。索引可以建在一列或幾列上。圓括弧內是索引列的順序說明表。其中的任選項———次序,指定了索引值排序的次序。可取ASC(升序)或DESC(降序)。預設值為升序。UNIQUE表示每一索引值只對應唯一的數據記錄。
5.SQL的數據操縱功能SQL的數據操縱功能包括SELECT,INSERT,DELETE和UPDATE四個語句,即檢索和更新(包括增、刪、改)兩部分工能。檢索就是查詢。
SQL更新語句SQL的更新語句包括修改,刪除和插入三類語句。
①修改(UPDATE)(亦稱為更新)修改語句的一般格式為:
UPDATE表名SET欄位=表達式[,欄位=表達式]…[WHERE謂詞];修改指定表中滿足謂詞(或條件)的元組,把這些元組按SET子句中的表達式修改相應屬性或欄位上的值。
②刪除(DELETE)刪除語句一般格式為:
DELETE FROM表名[WHERE謂詞];從指定表中刪除滿足謂詞的那些記錄。沒有WHERE子句時表示刪去此表中的全部記錄,但此表的定義仍在數據字典中,只是一個空表。DELETE只對表外延操作,不對內涵操作。
③插入(INSERT)插入語句的一般格式為:
INSERT INTO表名[(欄位名[,欄位名]…)]
valueS(常量[,常量]…);或INSERTINTO表名[(欄位名[,欄位名]…)]
子查詢;第一種格式把一個新記錄插入指定的表中。第二種格式把子查詢的結果插入表中。若表中有些欄位在插入語句中沒有出現,則這些欄位上的值取空值NULL。當然在表定義中說明了NOT NULL的欄位在插入時不能取NULL。若插入語句中沒有指出欄位名,則新記錄必須在每個欄位上均有值6.視圖視圖是從一個或幾個基本表(或視圖)導出的表。某一用戶可以定義若干視圖。因此對某一用戶而言,按ANSI/SPARC報告的觀點,他的外模式是由若干基本表和若干視圖組成的。視圖和基本表不同,視圖是一個虛表,即視圖所對應的數據不實際存儲在資料庫中,資料庫中只存儲視圖的定義(存在數據字典中)。視圖一經定義就可以和基本表一樣被查詢、被刪除(DROP),也可以用來定義新的視圖,但更新(增、刪、改)操作將有一定限制。視圖可以理解成一個資料庫,只有內涵保存在資料庫字典中,而無外延存儲;其外延是在使用時動態地生成的或計算出來的。
(1)視圖的定義與刪除SQL建立視圖的語句格式為:
CREATE VIEW視圖名[(欄位名[,欄位名]…)]
AS子查詢[WITH CHECK OPTION謂詞];視圖可以刪除,語句格式為:
DROP VIEW視圖名;視圖的定義就從數據字典中刪除。由此視圖導出的其它視圖也將自動被刪除。若導出此視圖的基本表刪除了,則此視圖也將自動刪除。
(2)視圖的查詢語句視圖定義後,用戶可以如同基本表那樣對視圖查詢。
(3)視圖的更新語句對視圖的更新最終要轉換成對基本表的更新(這里的更新,指INSERT,UPDATE和DELETE三類操作)。在關系資料庫中,並非所有的視圖都是可更新的,也就是說,有些視圖的更新不能唯一地有意義地轉換成對基本表的更新。
(4)視圖的優點視圖的概念具有很多優點,主要有:
(1)視圖對於資料庫的重構造提供了一定程度的邏輯獨立性;(2)簡化了用戶觀點;(3)視圖機制使不同的用戶能以不同的方式看待同一數據;(4)視圖機制對機密數據提供了自動的安全保護功能。
7.SQL的數據控制功能SQL數據控制功能是指控制用戶對數據的存取權力。某個用戶對某類數據具有何種操作權力是由DBA決定的。這是個政策問題而不是技術問題。資料庫管理系統的功能是保證這些決定的執行。為此它必須能:
(1)把授權的決定告知系統,這是由SQL的GRANT和REVOKE語句來完成的。
(2)把授權的結果存入數據字典。
(3)當用戶提出操作請求時,根據授權情況進行檢查,以決定是執行操作請求還是拒絕之。授權語句的一般格式為:GRANT權力[,權力]…[ON對象類型對象名] TO用戶[,用戶]…,[WITH GRANT OPTION];對不同類型的操作對象可有不同的操作權力。
(1)對基本表、視圖及其欄位的操作權力有查詢、插入、更新、刪除以及它們的總和ALL PRIVILEGE。
(2)對基本表的操作權力還有修改(ALTER)和建立索引(INDEX)。
(3)對資料庫的操作權力有建立表(CREATETAB)。某用戶有了此權力就可以使用Create table建立基本表。稱他為表的主人,擁有對此表的一切操作權力。
(4)對表空間的權力有使用(USE)資料庫空間存儲基本表的權力。
(5)系統權力有建立新資料庫(CREATEDBA)的權力。GRANT語句中的任選項WITH GRANT OPTION的作用是使獲得某種權力的用戶可以把權力再授予別的用戶。
8.嵌入式SQL把SQL嵌入主語言使用時必須解決三個問題:
(1)區分SQL語句與主語言語句。這是通過在所有的SQL語句前加前綴EXEC SQL來解決的。SQL語句結束標志隨主語言不同而不同,如PL/1用分號(;),COBOL用EMD-EXEC來表示。SQL語句首先由預編譯程序加以處理,轉換為主語言編譯程序能夠識別的形式,然後交主語言編譯程序進一步處理。
(2)資料庫工作單元和程序工作單元之間的通信。SQL語句中可以使用主語言的程序變數(簡稱主變數),這些變數名前加冒號(:)作標志,以區別地欄位名,程序中使用的任何錶(基本表或視圖)都要用EXEC SQL DECLARE語句加以說明。一則使程序更加清晰,二則使預編譯程序能作某些語法檢查。SQL語句執行後,系統要反饋給應用程序若干信息,這些信息送到SQL的通信區SQL CA。SQL CA用語句EXEC SQL INCLUDE加以定義。在SQL CA中有一個狀態指示欄位SQL CODE。當SQL CODE為零時,表示SQL語句執行成功,否則返回一個錯誤代碼(負值)或警告信息(正值)。程序員應該在每個SQL語句之後測試SQL CODE的值,以便處理各種情況。
(3)一個SQL語句原則上可產生或處理一組記錄,而主語言一次只能處理一個記錄,為此必須協調兩種處理方式。這是用游標(Cursor)來解決的。下面首先討論不需要游標的DML語句,然後討論使用游標的DML語句。
9.不用游標的DML語句不需要游標的DML語句有:查詢結果為單記錄的SELECT語句UPDATE(除了CURRENT形式的UPDATE)語句DELETE(除了CURRENT形式的DELETE)語句INSERT語句(1)查詢結果為單記錄的SELECT語句這類語句的一般格式是:(主語言為PL/1)EXEC SQL SELECT目標列INTO主變數[空值標志]FROM基本表(或視圖)[WHERE條件表達式];SELECT語句從資料庫中找到符合條件的記錄,把結果放到主變數中。(2)UPDATE語句(3)DELETE語句(4)INSERT語句
10.使用游標的DML語句一般情況下SELECT語句的查詢結果是記錄的集合而不是單個記錄,為此需要用游標機製作為橋梁,把集合操作轉換為單記錄處理。與游標有關的語句有四個:
(1)定義游標。游標是與某一查詢結果相聯系的符號名。用DECLARE語句定義。這是一個說明語句。與游標相對應的SELECT語句這時並不執行。
(2)打開(OPEN)游標。打開游標語句使游標處於活動狀態。與游標相應的查詢語句被執行。游標指向查詢結果集中的第一個記錄之前。
(3)推進(FETCH)游標。把游標向前推進一個記錄,並把游標指向的當前記錄中的欄位值取出,放到INTO子句後相應的主變數中。FETCH語句常常用於循環,以藉助主語言功能逐一處理結果集中的數據。
(4)關閉(CLOSE)游標。關閉游標,使它不再和原來的查詢結果相聯系。關閉了的游標可以再次被打開,與新的查詢結果集相聯系。使用CURRENT形式的UPDATE和刪除語句應注意:
(1)若游標定義中的SELECT語句帶有UNION或ORDER BY子句,或者這個SELECT語句相當於定義了一個不可更新的視圖,則不能用這兩個更新語句。
(2)若使用CURRENT形式的UPDATE語句,則游標定義中要包括FOR UPDATE子句,指出更新的欄位(SET子句中使用的欄位)。因此,游標定義語句的一般格式為:EXEC SQL DECLARE游標名CURSOR FOR子查詢UNION子查詢…[FOR UPDATE OF欄位名[,欄位名]…|ORDER-BY-子句];11.SQL的事務處理功能(1)事務處理的概述所謂事務(Transaction)是指一系列動作的組合,這些動作被當作一個整體來處理。這些動作或者相繼都被執行,或者什麼也不做。在資料庫中,一個動作是指一個SQL語句。事務是一組SQL語句組成的一個邏輯單位。要麼這些SQL語句全部被按順序正確執行,要麼在某SQL語句執行失敗時,按照用戶要求,取消已執行的SQL語句對資料庫中數據的修改。或者要麼事務中SQL語句都被正確執行,完成該事務對資料庫中數據的所有操作;或者要麼相當於一條SQL語句也未執行,資料庫數據未做任何改動。
(2)SQL語言的事務處理語句SQL語言有3條語句用於事務處理,它們是:
(1)Commit語句,對於正確執行了的事務進行提交,進行提交即對資料庫中數據的修改永久化。同時還釋放事務和封鎖,標志該事務結束。
(2)Save point語句,定義事務中的一個回滾保留點,它是事務恢復時的一個標記點。
(3)rollback語句,無論事務執行的當前位置在哪裡,該語句的執行要麼取消事務執行以來對資料庫的全部修改,要麼取消至某個指定回滾點後對資料庫的全部修改。釋放自保留點之後的全部表或行的封鎖(沒有保留點,相當於回滾到事務開始處,終止該事務)。事務的恢復(回滾)是根據事務執行前保存下的當時資料庫狀態來實現的。一遇到rollback語句,就將資料庫中數據恢復到原來的狀態,相當於撤消事務中已執行了的SQL語句。
『玖』 powerscript支持哪一種SQL語法
PowerScript語言支持的標准嵌入式SQL語句和動態SQL語句的語法格式,
PowerScript支持在腳本中使用嵌入式SQL語句。
PowerScript是PB使用的程序設計語言,有點類似於VB與C的混合物,非常簡潔高效:)~~