PostgreSQL 提供了三種實現模式匹配的方法:傳統 SQL 的 LIKE 操作符、SQL99 新增的 SIMILAR TO 操作符、 POSIX 風格的正則表達式。另外還有一個模式匹配函數 substring可用,它可以使用 SIMILAR TO 風格或者 POSIX 風格的正則表達式
創新互聯長期為上1000家客戶提供的網站建設服務,團隊從業經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯網生態環境。為長豐企業提供專業的成都網站制作、網站設計,長豐網站改版等技術服務。擁有十年豐富建站經驗和眾多成功案例,為您定制開發。
LIKE
string LIKE pattern [ESCAPE escape-character]
string NOT LIKE pattern [ESCAPE escape-character]
每個 pattern 定義一個字符串的集合。如果該 string 包含在 pattern 代表的字符串集合里,那么 LIKE 表達式返回真。和我們想像的一樣,如果 LIKE 返回真,那么 NOT LIKE 表達式將返回假,反之亦然。一個等效的表達式是 NOT (string LIKE pattern) 。
如果 pattern 不包含百分號或者下劃線,那么該模式只代表它本身;這時候 LIKE 的行為就像等號操作符。在 pattern 里的下劃線(_)匹配任何單個字符;而一個百分號(%)匹配零或多個任何字符。
一些例子:
'abc' LIKE 'abc' true
'abc' LIKE 'a%' true
'abc' LIKE '_b_' true
'abc' LIKE 'c' false
LIKE 模式匹配總是覆蓋整個字符串。要匹配在字符串內部任何位置的序列,該模式必須以百分號開頭和結尾。
要匹配下劃線或者百分號本身,在 pattern 里相應的字符必須前導逃逸字符。缺省的逃逸字符是反斜杠,但是你可以用 ESCAPE 子句指定一個。要匹配逃逸字符本身,寫兩個逃逸字符。
請注意反斜杠在字符串文本里已經有特殊含義了,所以如果你寫一個包含反斜杠的模式常量,那你就要在 SQL 語句里寫兩個反斜杠。因此,寫一個匹配單個反斜杠的模式實際上要在語句里寫四個反斜杠。你可以通過用 ESCAPE 選擇一個不同的逃逸字符來避免這樣;這樣反斜杠就不再是 LIKE 的特殊字符了。但仍然是字符文本分析器的特殊字符,所以你還是需要兩個反斜杠。
我們也可以通過寫成 ESCAPE '' 的方式關閉逃逸機制,這時,我們就不能關閉下劃線和百分號的特殊含義。
關鍵字 ILIKE 可以用于替換 LIKE ,令該匹配就當前的區域設置是大小寫無關的。這個特性不是 SQL 標準,是 PostgreSQL 擴展。
操作符 ~~ 等效于 LIKE ,而 ~~* 等效于 ILIKE 。還有 !~~ 和 !~~* 操作符分別代表 NOT LIKE 和 NOT ILIKE 。所有這些操作符都是 PostgreSQL 特有的.
例子: 查找數據庫中表的名字(查找以tbl_開頭的表的名字)
select tablename from pg_tables where tablename like 'tbl!_%'ESCAPE '!';
利用escape轉義: 上面的sql語句中就是將!作為轉義字符,作用是將"_"轉換成普通的"_"
1)增加磁盤,創建分區,掛載目錄
2)目錄授權
Chown postgres /data2'
Chmod 777 /data2'
3)創建表空間指向該目錄
create tablespace ts_demo location '/data2';
4)設置默認表空間參數值
SET default_tablespace = ts_demo;
select * from pg_settings where name ='default_tablespace';
5)后續創建表會默認存儲在該表空間對應的目錄
創建表查看表存儲路徑是否改過來了
select pg_relation_filepath('out_tiqu0')
Postgres數據庫有默認的2個表空間
select * from pg_tablespace
Name | Owner | Location
-----------+----------+-----------------------------------
pg_default | postgres |
pg_global | postgres |
創建表如果不指定表空間 那么就會默認使用pg_default,對應的路徑為pg安裝路徑中data文件夾下面,
6)對已存在的表更改表空間
alter table out_831108_1 set tablespace ts_demo;
更改之后再查看是否改過來了
postgreSQL的JDBC驅動是支持數組返回的,數組對應的類型為org.postgresql.jdbc4.Jdbc4Array(我用的是jdbc4).
一個示例, 函數如下:
create or replace function fn_rtbAry()
returns integer[]
as $fn_rtbAry$
begin
return '{10, 20, 30}'::integer[];
end;
$fn_rtbAry$ language plpgsql;
Java中獲得返回的數組, 要引入java.lang.*,java.sql.*,java.util.*,org.postgresql.jdbc4.*:
Connection conn = null;
Statement cmd = null;
ResultSet rs = null;
Jdbc4Array obj = null;
Integer[] dataAry = null;
// 連接,查詢創建以及初始化代碼省略
rs = cmd.executeQuery("select fn_rtbAry() as v");
// 循環獲得數據
while (rs.next()) {
obj = (Jdbc4Array)rs.getObject(1);
dataAry = (Integer[])obj.getArray(); // 這里獲得函數返回的數組,并轉換成Integer數組
// 其他代碼省略
}
// 釋放對象代碼省略
使用 serial 來處理。
CREATE TABLE test_create_tab2 (
id SERIAL,
val VARCHAR(10)
);
Test=# CREATE TABLE test_create_tab2 (
Test(# id SERIAL,
Test(# val VARCHAR(10)
Test(# );
注意: CREATE TABLE 將為 serial 字段 "test_create_tab2.id" 創建隱含序列 "test_create_tab2_id_seq"
CREATE TABLE
Test=# \d test_create_tab2;
資料表 "public.test_create_tab2"
欄位 | 型別 | 修飾詞
------+-----------------------+-------------------------------------------------
-------
id | integer | 非空 缺省 nextval('test_create_tab2_id_seq'::regclass)
val | character varying(10) |
Test=# INSERT INTO test_create_tab2(val) VALUES ('NO id');
INSERT 0 1
Test=# INSERT INTO test_create_tab2(val) VALUES ('NO id 2');
INSERT 0 1
Test=# select * from test_create_tab2;
id | val
----+---------
1 | NO id
2 | NO id 2
(2 行記錄)
Test=# select lastval();
lastval
---------
2
(1 行記錄)
PostgreSQL 和 MySQL 是將數據組織成表的關系數據庫。這些表可以根據每個表共有的數據鏈接或關聯。關系數據庫使您的企業能夠更好地了解可用數據之間的關系,并幫助獲得新的見解以做出更好的決策或發現新的機會。
PostgreSQL 和 MySQL 都依賴于 SQL(結構化查詢語言),這是與管理系統交互的標準語言。SQL 允許使用具有簡單結構的幾行源代碼連接表,大多數非技術員工可以快速學習。
使用 SQL,分析師不需要知道訂單表在磁盤上的位置、如何執行查找以查找特定訂單或如何連接訂單表和客戶表。數據庫編譯查詢并計算出正確的數據點。
MySQL 和 PostgreSQL 都支持 JavaScript Object Notation (JSON) 存儲和傳輸數據,盡管 PostgreSQL 也支持 JSONB,這是 JSON 的二進制版本,它消除了鍵的重復和無關的空格。
除了傳統的支持機制外,這兩個數據庫都提供強大的社區支持。
PostgreSQL,也稱為 Postgres,是一種開源關系數據庫,因其可靠性、靈活性和對開放技術標準的支持而享有盛譽。PostgreSQL 支持非關系和關系數據類型。它被稱為當今可用的最兼容、最穩定和最成熟的關系數據庫之一,并且可以輕松處理復雜的查詢。
PostgreSQL 的特性包括:
PostgreSQL 這是一個“一刀切”的解決方案,適用于許多尋求經濟高效的方法來改進其數據庫管理系統 (DBMS) 的企業。它具有足夠的可擴展性和多功能性,可以通過強大的擴展生態系統快速支持各種專業用例,涵蓋時間序列數據類型和地理空間分析等工作。作為開源數據庫解決方案構建的 PostgreSQL 完全不受許可限制、供應商鎖定的可能性或過度部署的風險。PostgreSQL 通過對象關系數據庫管理系統 (ORDBMS) 進行管理。
PostgreSQL 負責管理業務活動的在線事務處理 (OLTP)協議的企業數據庫管理員提供了理想的解決方案,包括電子商務、客戶關系管理系統 (CRM) 和財務分類帳。它也是管理接收、創建和生成的數據分析的理想選擇。
這些是 PostgreSQL 的一些主要優點:
MySQL — 一種快速、可靠、可擴展且易于使用的開源關系數據庫系統 — 旨在處理關鍵任務、高負載的生產應用程序。它是一種常見且易于啟動的數據庫,內存、磁盤和 CPU 利用率較低,有關系數據庫管理系統 (RDMS) 管理。MySQL Community Edition 是一個由活躍的在線社區支持的免費下載版本。
MySQL 功能包括所有 SQL 標準命令以及事務和 ACID 合規性(代表原子性、一致性、隔離性和持久性)。
兩個最常見的關系數據庫是什么 MySQL 和 Oracle。MySQL 不是 SQL Server 的同義詞,SQL Server 是 Microsoft 許可產品,與 MAC OS X 缺乏兼容性。
MariaDB 經常與 MySQL 混淆,它是 MySQL 的一個開源分支,速度更快,提供更多存儲引擎 (12),但功能有限。MySQL 和 MariaDB 使用的存儲引擎都是 InnoDB。InnoDB 提供標準的 ACID 兼容特性。與 MySQL 不同,MariaDB 不支持數據屏蔽或動態列表。
MySQL 通常用作 Web 數據庫來存儲各種信息類型,從單個信息數據點到為組織提供的產品或服務的完整列表。它是LAMP(Linux 操作系統、Apache HTTP 服務器、MySQL RDBMS 和 PHP 編程語言)的基礎組件,這是一種有助于創建API、Web 應用程序和網站的軟件堆棧模型。
MySQL Workbench 是一個單一的、集成的可視化 SQL 平臺,用于 MySQL 數據庫的創建、開發、設計和管理。
MySQL 為市場提供了許多好處,包括:
PostgreSQL 和 MySQL 之間有很多不同之處。特性、功能和優勢方面的一些差異如下:
總之,PostgreSQL 和 MySQL 都有不同的用途,它們之間的選擇取決于企業目標和資源。一般來說,PostgreSQL 是一個更強大、更高級的數據庫管理系統,非常適合需要在大型環境中快速執行復雜查詢的組織。但是,對于預算和空間更受限制的公司來說,MySQL 是一個理想的解決方案。
1、使用CREATEDATABASE該命令將創建一個數據庫PostgreSQL的shell提示符,但你應該有適當的權限來創建數據庫。默認情況下,創建新的數據庫將通過克隆標準系統數據庫template1。語法:CREATEDATABASE語句的基本語法如下:CREATEDATABASEdbname;其中dbname是要創建的數據庫的名稱。例子:下面是一個簡單的例子,這將創建testdb在PostgreSQL模式:postgres=#CREATEDATABASEtestdb;postgres-#2、使用createdb的命令PostgreSQL命令行可執行createdb是是SQL命令CREATEDATABASE一個包裝器。此命令和SQL命令CREATEDATABASE之間唯一的區別是,前者可以直接在命令行中運行,它允許的注釋被添加到數據庫中,全部在一個命令。語法:createdb語法如下所示:createdb[option][dbname[description]]參數下表列出了參數及它們的描述。參數名稱描述dbnameThenameofadatabasetocreate.descriptionSpecifiesacommenttobeassociatedwiththenewlycreateddatabase.optionscommand-lineargumentswhichcreatedbaccepts.選項下表列出了命令行參數CREATEDB接收:選項描述-DtablespaceSpecifiesthedefaulttablespaceforthedatabase.-eEchothecommandsthatcreatedbgeneratesandsendstotheserver.-EencodingSpecifiesthecharacterencodingschemetobeusedinthisdatabase.-llocaleSpecifiesthelocaletobeusedinthisdatabase.-TtemplateSpecifiesthetemplatedatabasefromwhichtobuildthisdatabase.--helpShowhelpaboutdropdbcommandlinearguments,andexit.-hhostSpecifiesthehostnameofthemachineonwhichtheserverisrunning.-pportSpecifiestheTCPportorthelocalUnixdomainsocketfileextensiononwhichtheserverislisteningforconnections.-UusernameUsernametoconnectas.-wNeverissueapasswordprompt.-WForcecreatedbtopromptforapasswordbeforeconnectingtoadatabase.打開命令提示符,然后去是PostgreSQL安裝所在的目錄。進入到bin目錄,執行下面的命令創建一個數據庫。createdb-hlocalhost-p5432-Upostgresstestdbpassword******上面的命令會提示Postgres的默認的PostgreSQL管理用戶的密碼,以便提供密碼和繼續創建新的數據庫。一旦創建數據庫時可以使用上述方法,可以檢查它在列表中的數據庫使用l即反斜線el命令如下:postgres-#lListofdatabasesName|Owner|Encoding|Collate|Ctype|Accessprivileges-----------+----------+----------+---------+-------+-----------------------postgres|postgres|UTF8|C|C|template0|postgres|UTF8|C|C|=c/postgres+|||||postgres=CTc/postgrestemplate1|postgres|UTF8|C|C|=c/postgres+|||||postgres=CTc/postgrestestdb|postgres|UTF8|C|C|(4rows)postgres-#
分享名稱:postgresql處理的簡單介紹
網站網址:http://vcdvsql.cn/article22/dsdjocc.html
成都網站建設公司_創新互聯,為您提供移動網站建設、企業網站制作、網站設計、網站收錄、網站排名、品牌網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯