jdbc連接db2資料庫
『壹』 cognos怎麼用JDBC連DB2數據源
我用的是FineReport,不太了解cognos,在網上當的,不知道能不能解決你的問題。
Cognos 8.4 for linux 64
連接GreenPlum數據使用ODBC驅動 僅僅支持32位驅動程序
使用DataDirect32位驅動連接需要配置IANA值為106(UTF-8)轉碼 以解決中文亂碼問題
另外64位linux下連接GreenPlum資料庫使用ODBC方式的兩種解決方案
1.通過unixODBC---greenplum-connectivity配置
greenplum-connectivity的內部已經自帶了unixODBC
2.通過DataDirect64位驅動同樣需要配置IANA值為106
『貳』 dbvisualizer連接db2提示jdbc和sqlj
當連接DB2提示出現SQLJ時,表示資料庫連接成功,可以進行訪問。
安裝好db2資料庫後,選中Connections,滑鼠右鍵選擇:Create Database Connection;選擇後會彈出以下彈出框,選擇:Use Wizard;此處可以任意輸入一個名字,只需無相同名稱即可;
選擇資料庫類型為:DB2;輸入訪問的資料庫名稱(sample),賬號(db2admin)、密碼(Admin2021)、埠號(50000),選擇完成finish即可;當查看到例如SQLJ的內容時,表示資料庫連接成功,可以進行訪問了。
DbVisualizer是一個完全基於JDBC的跨平台資料庫管理工具,內置SQL語句編輯器(支持語法高亮),凡是具有JDBC資料庫介面的資料庫都可以管理;
已經在Oracle, Sybase, DB2, Informix, MySQL, InstantDB, Cloudcape, HyperSonic ,Mimer SQL上通過測試。
『叄』 java中DB2資料庫的jdbc連接如何設置默認的schema
jdbc:db2://192.9.200.108:6789/SAMPLE
看看您的連接字元串是怎麼寫的?
這個應該是連接sample庫的
『肆』 使用jdbc 連接DB2資料庫 總是在連接池出
認證錯了,看看帳戶密碼及採用的連接方式是否正確。
『伍』 JDBC連接怎樣將DB2 CHAR FOR BIT DATA正常顯示
import java.sql.*;
public class DB2conn{
/**設置參數**/
private static Connection conn = null;
private static Statement stmt = null;
private static ResultSet rs = null;
/**構造方法,鏈接資料庫**/
public DB2conn() {
try{
System.out.println("正在連接資料庫..........");
Class.forName("com.ibm.db2.jcc.DB2Driver");//載入mysql驅動程序類
String url = "jdbc:db2://localhost:50000/toolsdb";//url為連接字元串
String user = "db2admin";//資料庫用戶名
String pwd = "1234";//資料庫密碼
conn=(Connection)DriverManager.getConnection(url,user,pwd);
System.out.println("資料庫連接成功!!!");
}catch(Exception e){
System.out.println(e.getMessage());
//e.printStackTrace();
}
}
public static void main(String[] args) throws SQLException {
DB2conn a = new DB2conn();//實例化對象,作用是調用構造方法
a.getClass();//無意義
/**查詢語句**/
String sql="select * from person";
stmt = (Statement) conn.createStatement();
stmt.execute(sql);//執行select語句用executeQuery()方法,執行insert、update、delete語句用executeUpdate()方法。
rs=(ResultSet) stmt.getResultSet();
while(rs.next()){ //當前記錄指針移動到下一條記錄上
int i = rs.getInt(1);//得到當前記錄的第一個欄位(id)的值
String name =rs.getString(2);//得到第二個欄位(name)的值
String psw = rs.getString("ppassword");//得到(password)的值
System.out.println(Integer.toString(i)+" "+name+" "+psw);
}
rs.close();//後定義,先關閉
stmt.close();
conn.close();//先定義,後關閉
}
}
『陸』 淺談JDBC怎麼連接資料庫
各個開發商的介面並不完全相同,所以開發環境的變化會帶來一定的配置變化。本文主要集合了不同資料庫的連接方式。
JDBC怎麼連接資料庫一、連接各種資料庫方式速查表
下面羅列了各種資料庫使用JDBC連接的方式,可以作為一個手冊使用。
1、Oracle8/8i/9i資料庫(thin模式)
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
Stringurl="jdbcracle:thinlocalhost:1521rcl";//orcl為資料庫的SID
Stringuser="test";
Stringpassword="test";
Connectionconn=DriverManager.getConnection(url,user,password);
2、DB2資料庫
Class.forName("com.ibm.db2.jdbc.app.DB2Driver").newInstance();
Stringurl="jdbc:db2://localhost:5000/sample";//sample為你的資料庫名
Stringuser="admin";
Stringpassword="";
Connectionconn=DriverManager.getConnection(url,user,password);
3、SqlServer7.0/2000資料庫
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
Stringurl="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb";
//mydb為資料庫
Stringuser="sa";
Stringpassword="";
Connectionconn=DriverManager.getConnection(url,user,password);
4、Sybase資料庫
Class.forName("com.sybase.jdbc.SybDriver").newInstance();
Stringurl="jdbc:sybase:Tds:localhost:5007/myDB";//myDB為你的資料庫名
PropertiessysProps=System.getProperties();
SysProps.put("user","userid");
SysProps.put("password","user_password");
Connectionconn=DriverManager.getConnection(url,SysProps);
5、Informix資料庫
Class.forName("com.informix.jdbc.IfxDriver").newInstance();
Stringurl="jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;
user=testuser;password=testpassword";//myDB為資料庫名
Connectionconn=DriverManager.getConnection(url);
6、MySQL資料庫
Class.forName("org.gjt.mm.mysql.Driver").newInstance();
Stringurl="jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1"
//myDB為資料庫名
Connectionconn=DriverManager.getConnection(url);
7、PostgreSQL資料庫
Class.forName("org.postgresql.Driver").newInstance();
Stringurl="jdbc:postgresql://localhost/myDB"//myDB為資料庫名
Stringuser="myuser";
Stringpassword="mypassword";
Connectionconn=DriverManager.getConnection(url,user,password);
8、access資料庫直連用ODBC的
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Stringurl="jdbcdbcriver={MicroSoftAccessDriver(*.mdb)};DBQ="+application.getRealPath("/Data/ReportDemo.mdb");
Connectionconn=DriverManager.getConnection(url,"","");
StatementstmtNew=conn.createStatement();
JDBC怎麼連接資料庫二、JDBC連接MySql方式
下面是使用JDBC連接MySql的一個小的教程
1、查找驅動程序
MySQL目前提供的java驅動程序為Connection/J,可以從MySQL官方網站下載,並找到mysql-connector-java-3.0.15-ga-bin.jar文件,此驅動程序為純java驅動程序,不需做其他配置。
2、動態指定classpath
如果需要執行時動態指定classpath,就在執行時採用-cp方式。否則將上面的.jar文件加入到classpath環境變數中。
3、載入驅動程序
try{
Class.forName(com.mysql.jdbc.Driver);
System.out.println(SuccessloadingMysqlDriver!);
}catch(Exceptione)
{
System.out.println(ErrorloadingMysqlDriver!);
e.printStackTrace();
}
4、設置連接的url
jdbc:mysql://localhost/databasename[?pa=va][&pa=va]
JDBC怎麼連接資料庫三、以下列出了在使用JDBC來連接Oracle資料庫時可以使用的一些技巧
1、在客戶端軟體開發中使用Thin驅動程序
在開發Java軟體方面,Oracle的資料庫提供了四種類型的驅動程序,二種用於應用軟體、applets、servlets等客戶端軟體,另外二種用於資料庫中的Java存儲過程等伺服器端軟體。在客戶機端軟體的開發中,我們可以選擇OCI驅動程序或Thin驅動程序。OCI驅動程序利用Java本地化介面(JNI),通過Oracle客戶端軟體與資料庫進行通訊。Thin驅動程序是純Java驅動程序,它直接與資料庫進行通訊。為了獲得最高的性能,Oracle建議在客戶端軟體的開發中使用OCI驅動程序,這似乎是正確的。但我建議使用Thin驅動程序,因為通過多次測試發現,在通常情況下,Thin驅動程序的性能都超過了OCI驅動程序。
2、關閉自動提交功能,提高系統性能
在第一次建立與資料庫的連接時,在預設情況下,連接是在自動提交模式下的。為了獲得更好的性能,可以通過調用帶布爾值false參數的Connection類的setAutoCommit()方法關閉自動提交功能,如下所示:
conn.setAutoCommit(false);
值得注意的是,一旦關閉了自動提交功能,我們就需要通過調用Connection類的commit()和rollback()方法來人工的方式對事務進行管理。
3、在動態SQL或有時間限制的命令中使用Statement對象
在執行SQL命令時,我們有二種選擇:可以使用PreparedStatement對象,也可以使用Statement對象。無論多少次地使用同一個SQL命令,PreparedStatement都只對它解析和編譯一次。當使用Statement對象時,每次執行一個SQL命令時,都會對它進行解析和編譯。這可能會使你認為,使用PreparedStatement對象比使用Statement對象的速度更快。然而,我進行的測試表明,在客戶端軟體中,情況並非如此。因此,在有時間限制的SQL操作中,除非成批地處理SQL命令,我們應當考慮使用Statement對象。
此外,使用Statement對象也使得編寫動態SQL命令更加簡單,因為我們可以將字元串連接在一起,建立一個有效的SQL命令。因此,我認為,Statement對象可以使動態SQL命令的創建和執行變得更加簡單。
4、利用helper函數對動態SQL命令進行格式化
在創建使用Statement對象執行的動態SQL命令時,我們需要處理一些格式化方面的問題。例如,如果我們想創建一個將名字O'Reilly插入表中的SQL命令,則必須使用二個相連的「''」號替換O'Reilly中的「'」號。完成這些工作的最好的方法是創建一個完成替換操作的helper方法,然後在連接字元串心服用公式表達一個SQL命令時,使用創建的helper方法。與此類似的是,我們可以讓helper方法接受一個Date型的值,然後讓它輸出基於Oracle的to_date()函數的字元串表達式。
5、利用PreparedStatement對象提高資料庫的總體效率
在使用PreparedStatement對象執行SQL命令時,命令被資料庫進行解析和編譯,然後被放到命令緩沖區。然後,每當執行同一個PreparedStatement對象時,它就會被再解析一次,但不會被再次編譯。在緩沖區中可以發現預編譯的命令,並且可以重新使用。在有大量用戶的企業級應用軟體中,經常會重復執行相同的SQL命令,使用PreparedStatement對象帶來的編譯次數的減少能夠提高資料庫的總體性能。如果不是在客戶端創建、預備、執行PreparedStatement任務需要的時間長於Statement任務,我會建議在除動態SQL命令之外的所有情況下使用PreparedStatement對象。
6、在成批處理重復的插入或更新操作中使用PreparedStatement對象
如果成批地處理插入和更新操作,就能夠顯著地減少它們所需要的時間。Oracle提供的Statement和CallableStatement並不真正地支持批處理,只有PreparedStatement對象才真正地支持批處理。我們可以使用addBatch()和executeBatch()方法選擇標準的JDBC批處理,或者通過利用PreparedStatement對象的setExecuteBatch()方法和標準的executeUpdate()方法選擇速度更快的Oracle專有的方法。要使用Oracle專有的批處理機制,可以以如下所示的方式調用setExecuteBatch():
PreparedStatementpstmt3Dnull;
try{
((OraclePreparedStatement)pstmt).setExecuteBatch(30);
...
pstmt.executeUpdate();
}
調用setExecuteBatch()時指定的值是一個上限,當達到該值時,就會自動地引發SQL命令執行,標準的executeUpdate()方法就會被作為批處理送到資料庫中。我們可以通過調用PreparedStatement類的sendBatch()方法隨時傳輸批處理任務。
7、使用Oraclelocator方法插入、更新大對象(LOB)
Oracle的PreparedStatement類不完全支持BLOB和CLOB等大對象的處理,尤其是Thin驅動程序不支持利用PreparedStatement對象的setObject()和setBinaryStream()方法設置BLOB的值,也不支持利用setCharacterStream()方法設置CLOB的值。只有locator本身中的方法才能夠從資料庫中獲取LOB類型的值。可以使用PreparedStatement對象插入或更新LOB,但需要使用locator才能獲取LOB的值。由於存在這二個問題,因此,我建議使用locator的方法來插入、更新或獲取LOB的值。
8、使用SQL92語法調用存儲過程
在調用存儲過程時,我們可以使用SQL92或OraclePL/SQL,由於使用OraclePL/SQL並沒有什麼實際的好處,而且會給以後維護你的應用程序的開發人員帶來麻煩,因此,我建議在調用存儲過程時使用SQL92。
9、使用ObjectSQL將對象模式轉移到資料庫中
既然可以將Oracle的資料庫作為一種面向對象的資料庫來使用,就可以考慮將應用程序中的面向對象模式轉到資料庫中。目前的方法是創建Javabean作為偽裝的資料庫對象,將它們的屬性映射到關系表中,然後在這些bean中添加方法。盡管這樣作在Java中沒有什麼問題,但由於操作都是在資料庫之外進行的,因此其他訪問資料庫的應用軟體無法利用對象模式。如果利用Oracle的面向對象的技術,可以通過創建一個新的資料庫對象類型在資料庫中模仿其數據和操作,然後使用JPublisher等工具生成自己的Javabean類。如果使用這種方式,不但Java應用程序可以使用應用軟體的對象模式,其他需要共享你的應用中的數據和操作的應用軟體也可以使用應用軟體中的對象模式。
10、利用SQL完成資料庫內的操作
我要向大家介紹的最重要的經驗是充分利用SQL的面向集合的方法來解決資料庫處理需求,而不是使用Java等過程化的編程語言。
如果編程人員要在一個表中查找許多行,結果中的每個行都會查找其他表中的數據,最後,編程人員創建了獨立的UPDATE命令來成批地更新第一個表中的數據。與此類似的任務可以通過在set子句中使用多列子查詢而在一個UPDATE命令中完成。當能夠在單一的SQL命令中完成任務,何必要讓數據在網上流來流去的?我建議用戶認真學習如何最大限度地發揮SQL的功能。
『柒』 JAVA JDBC連接DB2資料庫問題
JAVA連接DB2
/**了解基礎情況**/ 對於Java程序員而言,DB2 提供了兩種應用程序編程介面(API):JDBC 和 SQLJ。
JDBC:
JDBC 驅動程序分為舊的/CLI 驅動程序<db2java.zip>和新的通用 JDBC 驅動程序(Universal JDBC Driver)<db2jcc.jar>。
JDBC 是一個與供應商無關的動態 SQL 介面,該介面通過標准化的 Java 方法向您的應用程序提供數據訪問。
JDBC 類似於 DB2 CLI,因為您無須預編譯應用程序代碼,也無須將軟體包綁定到 DB2 資料庫。
作為一個與供應商無關的標准,JDBC 應用程序提供了更多的可移植性—這是當今異構業務基礎設施所必需的優點。
在執行 JDBC 應用程序期間,驅動程序將針對當前連接的 DB2 資料庫伺服器驗證 SQL 語句。
訪問期間的任何問題都會作為 Java 異常與相應的 SQLSTATE 和 SQLCODE 一起報告給應用程序。
SQLJ:
SQLJ 是一個用於從 Java 應用程序進行數據訪問的標准開發模型。
SQLJ API 是在 SQL 1999 規范中定義的。
新的通用 JDBC 驅動程序在一個實現中同時為 JDBC 和 SQLJ API 提供了支持。
JDBC 和 SQLJ 可以在同一個應用程序中互操作。
SQLJ 提供了獨特的使用靜態 SQL 語句進行開發以及在 DB2 包級別控制訪問的能力。
/**JDBC連接方式分析**/
JDBC 驅動程序體系結構分為四種類型:Type1,Type2,Type3,Type4。
Type1:
驅動程序基於 JDBC-ODBC 橋。
因此 ODBC 驅動程序可以與此類 JDBC 驅動程序(由 Sun 提供)結合起來使用。
IBM 不支持 Type 1 驅動程序,因此它不是推薦的環境。
Type2:
驅動程序依靠特定於操作系統的庫(共享庫)來與 RDBMS 通信。
應用程序將裝入這種 JDBC 驅動程序,而驅動程序將使用共享庫來與 DB2 伺服器通信。
DB2 UDB for Linux, UNIX和 WindowsV8.1 提供了兩種不同的 Type 2 驅動程序:
<1> 舊的/CLI JDBC 驅動程序在文件db2java.zip中提供。
其實現包名稱為COM.ibm.db2.jdbc.app.DB2Driver。
該驅動程序目前已被用於進行 J2EE 認證。
其別名「app 驅動程序」源自於一種觀念及其包名稱,
這種觀念就是:此驅動程序將通過遠程資料庫的本地 DB2 UDB 客戶機執行本地連接。
<2> 通用 JDBC 驅動程序在文件db2jcc.jar中提供。
其實現包名稱為com.ibm.db2.jcc.DB2Driver。
此驅動程序是 DB2 UDB for Linux, UNIX 和 Windows V8.1 中的新功能。
在最初的實現(V8.1)中,此驅動程序用於使用 Type 4 驅動程序體系結構與 DB2 伺服器進行直接的 Java 連接。
在 DB2 V8.1.2 中,您可以在 Type 2 體系結構中使用此驅動程序。
在 Type 2 體系結構中使用此驅動程序的一個主要原因是為了本地應用程序性能和分布式事務支持。
通用 JDBC Type 2 驅動程序分別使用com.ibm.db2.jcc.DB2XADataSource和com.ibm.db2.jcc.DB2ConnectionPoolDataSource來支持分布式事務和連接池。 註:在將來的版本中不會對舊的/CLI Type 2 驅動程序進行增強。
Type3:
驅動程序是一種純 Java 實現,它必須與 DB2 JDBC Applet 伺服器(DB2 JDBC Applet Server)通信才能訪問 DB2 數據。
此類驅動程序旨在使 Java applet 能訪問 DB2 數據源。
常被稱作「網路(net)驅動程序」,它是根據其包名COM.ibm.db2.jdbc.net命名的。DB2 V8.1 支持網路驅動程序,可以將其用於 JDBC 應用程序。
要求db2java.zip驅動程序總是處於與 DB2 Applet 伺服器相同的維護級別。
如果驅動程序在 applet 內使用,這就不是一個問題,因為瀏覽器會在應用程序執行期間下載相應的db2java.zip文件。
許多客戶使用 Type3 驅動程序而不是 Type2 驅動程序,以避免必需的 DB2 客戶機安裝和必需的DB2 CATALOG DATABASE命令,後者用於創建使用舊的/CLI 驅動程序進行 Type 2 連接所必需的資料庫目錄信息。
目前,WebSphere Application Server 和其它 J2EE 伺服器不支持 IBM Type 3 驅動程序,因為該驅動程序不支持分布式事務(JTA)。
將來的版本不會對 Type 3 驅動程序進行增強。
鼓勵使用通用 JDBC Type 4 驅動程序來替代 Type 3 驅動程序。
Type4:
驅動程序是僅用於 Java 的 JDBC 驅動程序,它直接連接到資料庫伺服器。
DB2 UDB for Linux, UNIX 和 Windows V8.1 引入了稱為「通用 JDBC 驅動程序(Universal JDBC driver)」的 Type 4 驅動程序。
通用 JDBC 驅動程序在文件db2jcc.jar中提供。
其實現包名為com.ibm.db2.jcc.DB2Driver。
請注意,通用 Type 2 和通用 Type 4 驅動程序具有相同的實現類名稱。
有兩種方法可以區別 DB2 在內部將實例化哪個驅動程序:
使用連接特性來確定連接是否使用共享庫(Type2),或者驅動程序是否會啟動來自 Java 應用程序的直接連接(Type4)。
重要:就 DB2 UDB V8.1.2 而言,通用 JDBC 驅動程序要求 CLASSPATH 中有許可證 JAR 文件和db2jcc.jar文件。
以下是所需的許可證 JAR 文件:
Cloudscape Network Server V5.1:db2jcc_license_c.jar
DB2 UDB V8 for Linux, UNIX 和 Windows 伺服器:db2jcc_license_su.jar
DB2 UDB for iSeries and z/OS 伺服器(與 DB2 Connect 和 DB2 Enterprise Server Edition 一起提供):db2jcc_license_cisuz.jar ****************************************************************驅動程序類型:db2java.zip, db2jcc.jar
注意:假如你使用db2java.zip,且web伺服器使用Tomcat的話,請將db2java.zip改名為db2java.jar,最好將zip解壓再用jar命令打包,直接改文件類型也行(呵呵,按照jar文件嚴格意義上來講這是不符合文法的<少了描述性文件:MANIFEST.MF>,能用就行)
還有一般情況下:就是使用 db2java.zip的話需要安裝db2客戶端, 使用db2jcc.jar是通過網路直接來連接的無需安裝db2客戶端(假如用在type2上還是要裝客戶端的)type2:
使用<db2java.zip>:
jdbc.driverClassName=COM.ibm.db2.jdbc.app.DB2Driver
jdbc.url=jdbc:db2:dataBaseName
假如你的工具使用的是myeclipse且使用的是tomcat plugin的話,請將db2jdbc.dll 拷貝到 %JAVA_HOME%/bin下,否則不行地啦
<是不是其他類型的使用db2java.zip驅動也有這個問題呢,不知道,沒試過,有空試一下>
使用<db2jcc.jar>:
jdbc.driverClassName=com.ibm.db2.jcc.DB2Driver
jdbc.url=jdbc:db2:dataBaseName
type3:
驅動:db2java.zip
jdbc.driverClassName=COM.ibm.db2.jdbc.net.DB2Driver
jdbc.url=jdbc:db2://ip:6789/DBNAME
注意:要在資料庫上執行 db2jstrt 6789 (這句啟動了db2jd進程,6789是默認的伺服器偵聽jdbc2連接的埠,也可以設置成另外的任意不沖突的埠。)
type4:
驅動:db2jcc.jar
資料庫字元集必須設置為utf-8
jdbc.driverClassName=com.ibm.db2.jcc.DB2Driver
jdbc.url=jdbc:db2://ip:port/DBNAME
『捌』 JDBC 連接Z/OS DB2,報錯: com.ibm.db2.jcc.b.SqlException: unsupported encoding Cp836 for result s
使用IBM SDK的charsets.jar 替換 你使用的jre/lib/charsets.jar 即可。
下載地址:https://www.ibm.com/developerworks/java/jdk/index.html
見IBM社區的回答:
IBM has a charset support for every CCSID IBM machines deal with.Sun JDK/JRE uses charsets.jar to provided character mapping between UTF-8 and various code pages. Sun has separate international installations and that localized install would not have all conversion classes. So you will need to obtain a full JDK installation.
It is best to use latest IBM JDK. It contains both rt.jar and charsets.jar containing the class file ByteToCharCp836.class.
『玖』 JDBC連接DB2資料庫問題,連接上了但執行查詢出錯!!!
USERS表是建立在那個Schema上的,把Schema的名字也加到SQL語句上,「select * from Schema.USERS」
下面是SQLSTATE=42704的解釋。
SQL0204N "<名稱>" 是一個未定義的名稱。
解釋:
此錯誤由以下之一引起:
o 未在資料庫中定義由 "<名稱>" 標識的對象。
o 在表上未定義由 "<名稱>" 標識的數據分區。
o 正在使用某個數據類型。此錯誤可能是由於下
列原因而發生的:
- 如果 "<名稱>"
是限定名稱,則具有此名稱的數據類型在數據
庫中不存 在。
- 如果 "<名稱>"
是非限定名稱,則用戶的函數路徑不包含期望
的數據類 型所屬於的模式。
- 該數據類型在創建時間戳記早於程序包綁定時
間的資料庫中不存在(適用於靜態語句)。
- 如果數據類型在 CREATE TYPE 語句的 UNDER
子句中,則該類型名可能與正定義的類型相同
,這 是無效的。
o 下列其中一項中正在引用某個函數:
- DROP FUNCTION 語句
- COMMENT ON FUNCTION 語句
- CREATE FUNCTION 語句的 SOURCE 子句
如果 "<名稱>"
是限定名稱,則函數不存在。如果
"<名稱>"
是非限定名稱,則當前函數路徑的任何模式中
都不存 在
此名稱的函數。注意,函數不能以
COALESCE、 NULLIF 或 VALUE
內置函數作為源函數。
o 在 CREATE SECURITY LABEL COMPONENT 語句中 UNDER
子句右邊使用了名為「名稱」的元素,但尚未
將該 元素定義為 ROOT
或者在其他某個元素下方(UNDER)。
o 下列其中一個標量函數指定了「名稱」標識的
安全策略,但在資料庫中未定義該安全策略。
- SECLABEL
- SECLABEL_TO_CHAR
- SECLABEL_BY_NAME
可為任何類型的資料庫對象生成此返回碼。
聯合系統用戶:在資料庫中未定義由 "<名稱>"
標識的對象,或者 "<名稱>" 不是 DROP NICKNAME
語句中的昵稱。
某些數據源不向 "<名稱>"
提供適當的值。在這些情況下,消息標記將具有以下格
式: "OBJECT:<數據源>
TABLE/VIEW",指示指定數據源的實際值未知。
不能處理該語句。
用戶響應:
確保在 SQL 語句中正確指定了對象名(包括任何必需
的限定符),並且它存在。
如果該名稱表示一個數據分區,則查詢目錄表
SYSCAT.DATAPARTITIONS
以找到一個表的所有數據分區。對於 SOURCE
子句中缺少的數據類型或函數,可能是該對象不存
在,或該對象處於某模式中,
『拾』 JDBC連接DB2報錯:com.ibm.db2.jcc.a.SqlException: Failure in loading T2 native library db2jcct2
java.lang.UnsatisfiedLinkError: no db2jcct2 in java.library.path
在類庫中沒有db2jcct2 ,缺少jar包。去下載個吧。如果有就是版本問題或沖突問題。