oracle中的boolean數(shù)據(jù)類型僅限于PL/SQL,oracle本身沒有默認(rèn)的提供布爾型的存儲方式
在龍山等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計制作、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需開發(fā)網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站制作,龍山網(wǎng)站建設(shè)費(fèi)用合理。
在設(shè)計數(shù)據(jù)庫表結(jié)構(gòu)時,選擇一種高效的策略來存儲一個可以在很多編程環(huán)境中使用的邏輯布爾值是非常重要的。(雖然 Oracle 沒有 Boolean 數(shù)據(jù)類型來表示數(shù)據(jù)庫字段,但是在 PL/SQL 中卻具有 Boolean 數(shù)據(jù)類型。)
任何布爾定義的字段還應(yīng)該被正確進(jìn)行約束檢查,以確保在插入/更新時輸入了有效的值。
create table tbool (bool char check (bool in ('N','Y'));
insert into tbool values ('N');
insert into tbool values ('Y');
最常見的設(shè)計是模擬很多 Oracle 的數(shù)據(jù)字典視圖中使用的類似布爾的標(biāo)志,選擇‘Y’表示真,‘N’表示假。然而,要正確地與宿主環(huán)境交互,比如與 JDBC、OCCI 和其它編程環(huán)境交互,最好選擇0表示假,選擇1表示真,從而使getBoolean 和setBoolean 能夠正確地處理它們。
We could define a Boolean as NUMBER(1); however, in Oracle's internal number format, 0 takes 1 byte and 1 takes 2 bytes after the length byte (so it's more efficient to store it as CHAR). Even though the character is defined as CHAR, SQL can convert and verify against actual numbers.
我們可以將一個布樂類型定義為 NUMBER(1);然而,在 Oracle 的內(nèi)部數(shù)字格式中,0在長度字節(jié)之后占用一個字節(jié),而1在長度字節(jié)之后占用兩個字節(jié)(所以更加高效地方式是將其存儲為 CHAR)。即使字符被定義為 CHAR,SQL 也可以轉(zhuǎn)換和驗(yàn)證實(shí)際的數(shù)字。
create table tbool (bool char check (bool in (0,1));
insert into tbool values(0);
insert into tbool values(1);
一直被Oracle中沒有boolean類型困擾 網(wǎng)上有兩種解決方案 一是用Number( ) 二是用Char( ) 各有所長 個人比較喜歡用Number方式解決 原因很簡單 因?yàn)槭菑腃語言開始的 這符合C語言的習(xí)慣
前幾天有幸咨詢到Oracle方面的顧問 他們提供的解決方案是用Char( )實(shí)現(xiàn)boolean 但也有需要注意的地方 原話如下
lishixinzhi/Article/program/Oracle/201311/18383
以下提供幾種替代方法: ??????
如果用編碼,實(shí)際項(xiàng)目使用的時候會用CHAR(1)或者INTEGER、NUMBER(1)之類的進(jìn)行替代,然后在代碼中進(jìn)行判斷,稍微熟練一下就知道跟true/false沒什么區(qū)別。
如果不用編碼,就會用VARCHAR2(N)之類的用原文。
另外,實(shí)際項(xiàng)目中對建表約束比較少操作,這種約束會消耗一點(diǎn)資源,包括編碼、報錯處理和系統(tǒng)內(nèi)部校驗(yàn)等。同樣的大學(xué)里學(xué)到的數(shù)據(jù)庫范式在正式項(xiàng)目中并不會全面的實(shí)施。
【布爾類型】
布爾類型( bool),布爾類型只有兩個值,false 和 true。通常用來判斷條件是否成立。
如果變量值為 0 就是 false,否則為 true,布爾變量只有這兩個值。
如:
例1:bool pb= -1.5; // pb=true;
例2:bool pt=0; // pt=false;
【不同的關(guān)系運(yùn)算符中的布爾類型值的結(jié)果】
數(shù)據(jù)庫的字段為布爾值:一般是設(shè)計
字段名:boolean_column
類型:number(1)
值:0:代表false、1:代表true