数据库方言?数据库的方言是什么意思啊
大家好,今天小编来为大家解答数据库方言这个问题,数据库的方言是什么意思啊很多人还不知道,现在让我们一起来看看吧!
数据库语言有哪些
数据定义语言(DDL),例如:CREATE、DROP、ALTER等语句。
数据操作语言(DML),例如:INSERT(插入)、UPDATE(修改)、DELETE(删除)语句。
数据查询语言(DQL),例如:SELECT语句。(一般不会单独归于一类,因为只有一个语句)。
数据控制语言(DCL),例如:GRANT、REVOKE等语句。
事务控制语言(TCL),例如:COMMIT、ROLLBACK等语句。
SQL语言包括四类种主要程序设计语言类别的语句:数据定义语言(DDL),数据操作语言(DML)及数据控制语言(DCL)还有事务控制语言(TCL)。
数据库语言以记录集合作为操作对象
所有SQL语句接受集合作为输入,返回集合作为输出,这种集合特性允许一条SQL语句的输出作为另一条SQL语句的输入,所以SQL语句可以嵌套,这使他具有极大的灵活性和强大的功能,在多数情况下,在其他语言中需要一大段程序实现的功能只需要一个SQL语句就可以达到目的,这也意味着用SQL语言可以写出非常复杂的语句。
以上内容参考:百度百科-数据库语言
数据库的方言是什么意思啊
C3P0:com.mchange.v2.c3p0.ComboPooledDataSource
<c3p0-config>
<default-config>
<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3-->
<property name="acquireIncrement">3</property>
<!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30-->
<property name="acquireRetryAttempts">30</property>
<!--两次连接中间隔时间,单位毫秒。Default: 1000-->
<property name="acquireRetryDelay">1000</property>
<!--连接关闭时默认将所有未提交的操作回滚。Default: false-->
<property name="autoCommitOnClose">false</property>
<!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么
属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试
使用。Default: null-->
<property name="automaticTestTable">Test</property>
<!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效
保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试
获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->
<property name="breakAfterAcquireFailure">false</property>
<!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出
SQLException,如设为0则无限期等待。单位毫秒。Default: 0-->
<property name="checkoutTimeout">100</property>
<!--通过实现ConnectionTester或QueryConnectionTester的类来测试连接。类名需制定全路径。
Default: com.mchange.v2.c3p0.impl.DefaultConnectionTester-->
<property name="connectionTesterClassName"></property>
<!--指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可
Default: null-->
<property name="factoryClassLocation">null</property>
<!--Strongly disrecommended. Setting this to true may lead to subtle and bizarre bugs.
(文档原文)作者强烈建议不使用的一个属性-->
<property name="forceIgnoreUnresolvedTransactions">false</property>
<!--每60秒检查所有连接池中的空闲连接。Default: 0-->
<property name="idleConnectionTestPeriod">60</property>
<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3-->
<property name="initialPoolSize">3</property>
<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0-->
<property name="maxIdleTime">60</property>
<!--连接池中保留的最大连接数。Default: 15-->
<property name="maxPoolSize">15</property>
<!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements
属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。
如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
<property name="maxStatements">100</property>
<!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0-->
<property name="maxStatementsPerConnection"></property>
<!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能
通过多线程实现多个操作同时被执行。Default: 3-->
<property name="numHelperThreads">3</property>
<!--当用户调用getConnection()时使root用户成为去获取连接的用户。主要用于连接池连接非c3p0
的数据源时。Default: null-->
<property name="overrideDefaultUser">root</property>
<!--与overrideDefaultUser参数对应使用的一个参数。Default: null-->
<property name="overrideDefaultPassword">password</property>
<!--密码。Default: null-->
<property name="password"></property>
<!--定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:
测试的表必须在初始数据源的时候就存在。Default: null-->
<property name="preferredTestQuery">select id from test where id=1</property>
<!--用户修改系统配置参数执行前最多等待300秒。Default: 300-->
<property name="propertyCycle">300</property>
<!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的
时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable
等方法来提升连接测试的性能。Default: false-->
<property name="testConnectionOnCheckout">false</property>
<!--如果设为true那么在取得连接的同时将校验连接的有效性。Default: false-->
<property name="testConnectionOnCheckin">true</property>
<!--用户名。Default: null-->
<property name="user">root</property>
<!--早期的c3p0版本对JDBC接口采用动态反射代理。在早期版本用途广泛的情况下这个参数允许用户恢复到动态反射代理以解决不稳定的故障。最新的非反射代理更快并且已经开始广泛的被使用,所以这个参数未必有用。现在原先的动态反射与新的非反射代理同时受到支持,但今后可能的版本可能不支持动态反射代理。Default: false。
jdbc:mysql://ip地址:3306/数据库名字?useUnicode=true&characterEncoding=utf-8
2.C3P0连接配置
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration
PUBLIC"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
< hibernate-configuration>
< session-factory>
<!?JDBC驱动程序-->
< property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<!--连接数据库的URL-->
< property name="connection.url">
jdbc:mysql://localhost:3306/schoolproject
</property>
< property name="connection.useUnicode">true</property>
< property name="connection.characterEncoding">UTF-8</property>
<!--连接的登录名-->
< property name="connection.username">root</property>
<!--登录密码--
<property name="connection.password"></property>
<!-- C3P0连接池设定-->
< property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider
</property>
< property name="hibernate.c3p0.max_size">20</property>
< property name="hibernate.c3p0.min_size">5</property>
< property name="hibernate.c3p0.timeout">120</property>
< property name="hibernate.c3p0.max_statements">100</property>
< property name="hibernate.c3p0.idle_test_period">120</property>
< property name="hibernate.c3p0.acquire_increment">2</property>
<!--是否将运行期生成的SQL输出到日志以供调试-->
< property name="show_sql">true</property>
<!--指定连接的语言-->
< property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!--映射Student这个资源-->
< mapping resource="com/wqbi/model/pojo/student.hbm.xml"/>
</session-factory>
</hibernate-configuration>
proxool连接池
(1)先写proxool的配置文件,文件名:proxool.xml(一般放在与hibernate.cfg.xml文件在同一个目录中)本例配置的是MYSQL数据库,数据库的名字为schoolproject
<?xml version="1.0" encoding="UTF-8"?>
<!-- the proxool configuration can be embedded within your own application's.
Anything outside the"proxool" tag is ignored.-->
< something-else-entirely>
<proxool>
<!--连接池的别名-->
<alias>DBPool</alias>
<!--proxool只能管理由自己产生的连接-->
<driver-url>
jdbc:mysql://localhost:3306/schoolproject?useUnicode=true&characterEncoding=UTF8
</driver-url>
<!?JDBC驱动程序-->
<driver-class>com.mysql.jdbc.Driver</driver-class>
<driver-properties>
<property name="user" value="root"/>
<property name="password" value=""/>
</driver-properties>
<!-- proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回
收,超时的销毁-->
<house-keeping-sleep-time>90000</house-keeping-sleep-time>
<!--指因未有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的
用户连接就不会被接受-->
<maximum-new-connections>20</maximum-new-connections>
<!--最少保持的空闲连接数-->
<prototype-count>5</prototype-count>
<!--允许最大连接数,超过了这个连接,再有请求时,就排在队列中等候,最大的
等待请求数由maximum-new-connections决定-->
<maximum-connection-count>100</maximum-connection-count>
<!--最小连接数-->
<minimum-connection-count>10</minimum-connection-count>
</proxool>
</something-else-entirely>
(2)配置hibernate.cfg.xml文件
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration
PUBLIC"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
< hibernate-configuration>
< session-factory>
< property name="hibernate.connection.provider_class">
org.hibernate.connection.ProxoolConnectionProvider
</property>
<property name="hibernate.proxool.pool_alias">DBPool</property>
<property name="hibernate.proxool.xml">proxoolconf.xml</property>
<!--是否将运行期生成的SQL输出到日志以供调试-->
<property name="show_sql">true</property>
<!--指定连接的语言-->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!--映射Student这个资源-->
<mapping resource="com/wqbi/model/pojo/student.hbm.xml"/>
</session-factory>
</hibernate-configuration>
(1) hibernate.connection.provider_class定义Hibernate的连接加载类,这里Proxool连接池是用这个,不同的连接池有不同的加载类,可以查阅Hibernate文档获取相关信息
(2) hibernate.proxool.pool_alias这里就是用我们上面提到的连接池的别名
(3) hibernate.proxool.xml是向Hibernate声明连接池的配置文件位置,可以用相对或绝对路径,用相对路径时要注意一定在要Path范围内!不然会抛出异常。
(4) dialect是声明SQL语句的方言
(5) show_sql定义是否显示Hibernate生成的SQL语言,一般在调试阶段设为true,完成后再改成false,这样有利于调试。
(6)<mapping>资源文件映射
什么是数据库
什么是数据库?
数据库是以某种文件结构存储的一系列信息表,这种文件结构使您能够访问这些表、选择表中的列、对表进行排序以及根据各种标准选择行。数据库通常有多个索引与这些表中的许多列相关联,所以我们能尽可能快地访问这些表。
以员工记录为例,您可以设想一个含有员工姓名、地址、工资、扣税以及津贴等内容的表。让我们考虑一下这些内容可能如何组织在一起。您可以设想一个表包含员工姓名、地址和电话号码。您希望保存的其它信息可能包括工资、工资范围、上次加薪时间、下次加薪时间、员工业绩评定等内容。
这些内容是否应保存在一个表格中?几乎可以肯定不应该如此。不同类别的员工的工资范围可能没有区别;这样,您可以仅将员工类型储存在员工记录表中,而将工资范围储存在另一个表中,通过类型编号与这个表关联。考虑以下情况:
Key Lastname SalaryType SalaryType Min Max
1 Adams 2 1 30000 45000
2 Johnson 1 2 45000 60000
3 Smyth 3 3 60000 75000
4 Tully 1
5 Wolff 2
SalaryType列中的数据引用第二个表。我们可以想象出许多种这样的表,如用于存储居住城市和每个城市的税值、健康计划扣除金额等的表。每个表都有一个主键列(如上面两个表中最左边的列)和若干数据列。在数据库中建立表格既是一门艺术,也是一门科学。这些表的结构由它们的范式指出。我们通常说表属于1NF、2NF或 3NF。
第一范式:表中的每个表元应该只有一个值(永远不可能是一个数组)。(1NF)
第二范式:满足 1NF,并且每一个非主键列完全依赖于主键列。这表示主键和该行中的剩余表元之间是 1对 1的关系。(2NF)
第三范式:满足 2NF,并且所有非主键列是互相独立的。任何一个数据列中包含的值都不能从其他列的数据计算得到。(3NF)
现在,几乎所有的数据库都是基于“第三范式(3NF)”创建的。这意味着通常都有相当多的表,每个表中的信息列都相对较少。
从数据库中获取数据
假设我们希望生成一个包含员工及其工资范围的表,在我们设计的一个练习中将使用这个表。这个表格不是直接存在在数据库中,但可以通过向数据库发出一个查询来构建它。我们希望得到如下所示的一个表:
Name Min Max
Tully$30,000.00$45,000.00
Johnson$30,000.00$45,000.00
Wolff$45,000.00$60,000.00
Adams$45,000.00$60,000.00
Smyth$60,000.00$75,000.00
我们发现,获得这些表的查询形式如下所示
SELECT DISTINCTROW Employees.Name, SalaryRanges.Min,
SalaryRanges.Max FROM Employees INNER JOIN SalaryRanges ON Employees.SalaryKey= SalaryRanges.SalaryKey
ORDER BY SalaryRanges.Min;
这种语言称为结构化查询语言,即 SQL,而且它是几乎目前所有数据库都可以使用的一种语言。SQL-92标准被认为是一种基础标准,而且已更新多次。
数据库的种类
PC上的数据库,如 dBase、Borland Paradox、Microsoft Access和 FoxBase。
数据库服务器:IBM DB/2、Microsoft SQL Server、 Oracle、Sybase、SQLBase和 XDB。
所有这些数据库产品都支持多种相对类似的 SQL方言,因此,所有数据库最初看起来好象可以互换。每种数据库都有不同的性能特征,而且每一种都有不同的用户界面和编程接口。
ODBC
如果我们能够以某种方式编写不依赖于特定厂商的数据库的代码,并且能够不改变自己的调用程序即可从这些数据库中得到相同的结果,那将是一件很好的事。如果我们可以仅为所有这些数据库编写一些封装,使它们具有相似的编程接口,这种对数据库编程独立于供应商的特性将很容易实现。
什么是 JDBC?
JDBC是对 ODBC API进行的一种面向对象的封装和重新设计,它易于学习和使用,并且它真正能够使您编写不依赖厂商的代码,用以查询和操纵数据库。尽管它与所有 Java API一样,都是面向对象的,但它并不是很高级别的对象集.
除 Microsoft之外,多数厂商都采用了 JDBC,并为其数据库提供了 JDBC驱动程序;这使您可轻松地真正编写几乎完全不依赖数据库的代码。另外,JavaSoft和 Intersolv已开发了一种称为 JDBC-ODBC Bridge的产品,可使您连接还没有直接的 JDBC驱动程序的数据库。支持 JDBC的所有数据库必须至少可以支持 SQL-92标准。这在很大程度上实现了跨数据库和平台的可移植性。
安装和使用 JDBC
JDBC的类都被归到 java.sql包中,在安装 Java JDK 1.4时会自动安装。然而,如果您想使用 JDBC-ODBC桥。JDBC-ODBC驱动程序可从 Sun的 Java网站(http://java.sun.com/)轻松地找到并下载。在您扩充并安装了这个驱动程序后,必须执行下列步骤:
将\jdbc-odbc\classes;路径添加到您的 PATH环境变量中。
将\jdbc-odbc\classes;路径添加到您的 CLASSPATH环境变量中。
JDBC驱动程序的类型
Java程序连接数据库的方法实际上有四种:
1. JDBC-ODBC桥和 ODBC驱动程序--在这种方式下,这是一个本地解决方案,因为 ODBC驱动程序和桥代码必须出现在用户的每台机器中。从根本上说这是一个临时解决方案。
2.本机代码和 Java驱动程序--它用另一个本地解决方案(该平台上的 Java可调用的本机代码)取代 ODBC和 JDBC-ODBC桥。
3. JDBC网络的纯 Java驱动程序--由 Java驱动程序翻译的 JDBC形成传送给服务器的独立协议。然后,服务器可连接任何数量的数据库。这种方法使您可能从客户机 Applet中调用服务器,并将结果返回到您的 Applet。在这种情况下,中间件软件提供商可提供服务器。
4.本机协议 Java驱动程序-- Java驱动程序直接转换为该数据库的协议并进行调用。这种方法也可以通过网络使用,而且可以在 Web浏览器的 Applet中显示结果。在这种情况下,每个数据库厂商将提供驱动程序。
如果您希望编写代码来处理 PC客户机数据库,如 dBase、Foxbase或 Access,则您可能会使用第一种方法,并且拥有用户机器上的所有代码。更大的客户机-服务器数据库产品(如 IBM的 DB2)已提供了第 3级别的驱动程序。
两层模型和三层模型
当数据库和查询它的应用程序在同一台机器上,而且没有服务器代码的干预时,我们将生成的程序称为两层模型。一层是应用程序,而另一层是数据库。在 JDBC-ODBC桥系统中通常是这种情况。
当一个应用程序或 applet调用服务器,服务器再去调用数据库时,我们称其为三层模型。当您调用称为“服务器”的程序时通常是这种情况。
编写 JDBC代码访问数据库
用 ODBC注册您的数据库
连接数据库
所有与数据库有关的对象和方法都在 java.sql包中,因此在使用 JDBC的程序中必须加入"import java.sql.*"。 JDBC要连接 ODBC数据库,您必须首先加载 JDBC-ODBC桥驱动程序
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
该语句加载驱动程序,并创建该类的一个实例。然后,要连接一个特定的数据库,您必须创建 Connect类的一个实例,并使用 URL语法连接数据库。
String url="jdbc:odbc:Northwind";
Connection con= DriverManager.getConnection(url);
请注意,您使用的数据库名是您在 ODBC设置面板中输入的“数据源”名称。
URL语法可能因数据库类型的不同而变化极大。
jdbc:subprotocol:subname
第一组字符代表连接协议,并且始终是 jdbc。还可能有一个子协议,在此处,子协议被指定为 odbc。它规定了一类数据库的连通性机制。如果您要连接其它机器上的数据库服务器,可能也要指定该机器和一个子目录:
jdbc:bark//doggie/elliott
最后,您可能要指定用户名和口令,作为连接字符串的一部分:
jdbc:bark//doggie/elliot;UID=GoodDog;PWD=woof
访问MSSQL Server方法:(驱动程序需要:msutil.jar,msbase.jar,mssqlServer.jar)
DBDriver=com.microsoft.jdbc.sqlserver.SQLServerDriver
URL=jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=demo
username=sa
password=
maxcon=10
mincon=1
poolName=SkyDev
利用我们开发的数据库类,使用方法如下:
DbObject DbO= new DbObject(new SqlServerConnectionFactory("localhost",
1433,"demo","sa",""));
Connection con= DbO.getConnection();
//类代码(不含连接工厂实现)
package skydev.modules.data;
public final class SqlServerConnectionFactory
extends ConnectionFactory{
private final String dbDriver=
"com.microsoft.jdbc.sqlserver.SQLServerDriver";
private String host;
private int port;
private String databaseName;
public SqlServerConnectionFactory(){
super.setDriverName(dbDriver);
}
/**
*
*@param host数据库所在的主机名:如"localhost"
*@param port SQL服务器运行的端口号,如果使用缺省值 1433,传入一个负数即可
*@param databaseName数据库名称
*@param userName用户名
*@param password口令
*/
public SqlServerConnectionFactory(String host,
int port,
String databaseName,
String userName,
String password){
this.setHost(host);
this.setPort(port);
this.setDatabaseName(databaseName);
this.setUserName(userName);
this.setPassword(password);
init();
}
private void init(){
super.setDriverName(dbDriver);
super.setUrl("jdbc:microsoft:sqlserver://"+ host.trim()+":"+
new Integer(port).toString()+";DatabaseName="+
databaseName.trim());
//super.setUrl("jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=demo");
}
……
//------------------------------------------------------------------------------------
访问MySQL的方法:
DBDriver=com.mysql.jdbc.Driver
URL=jdbc:mysql://localhost/demo
username=
password=
maxcon=5
mincon=1
poolName=zhengmao
访问数据库
一旦连接到数据库,就可以请求表名以及表列的名称和内容等信息,而且您可以运行 SQL语句来查询数据库或者添加或修改其内容。可用来从数据库中获取信息的对象有:
DatabaseMetaData有关整个数据库的信息:表名、表的索引、数据库产品的名称和版本、数据库支持的操作。
ResultSet关于某个表的信息或一个查询的结果。您必须逐行访问数据行,但是您可以任何顺序访问列。
ResultSetMetaData有关 ResultSet中列的名称和类型的信息。
尽管每个对象都有大量的方法让您获得数据库元素的极为详细的信息,但在每个对象中都有几种主要的方法使您可获得数据的最重要信息。然而,如果您希望看到比此处更多的信息,建议您学习文档以获得其余方法的说明。
ResultSet
ResultSet对象是 JDBC中最重要的单个对象。从本质上讲,它是对一个一般宽度和未知长度的表的一种抽象。几乎所有的方法和查询都将数据作为 ResultSet返回。ResultSet包含任意数量的命名列,您可以按名称访问这些列。它还包含一个或多个行,您可以按顺序自上而下逐一访问。在您使用 ResultSet之前,必须查询它包含多少个列。此信息存储在 ResultSetMetaData对象中。
//从元数据中获得列数
ResultSetMetaData rsmd;
rsmd= results.getMetaData();
numCols= rsmd.getColumnCount();
当您获得一个 ResultSet时,它正好指向第一行之前的位置。您可以使用 next()方法得到其他每一行,当没有更多行时,该方法会返回 false。由于从数据库中获取数据可能会导致错误,您必须始终将结果集处理语句包括在一个 try块中。
您可以多种形式获取 ResultSet中的数据,这取决于每个列中存储的数据类型。另外,您可以按列序号或列名获取列的内容。请注意,列序号从 1开始,而不是从 0开始。ResultSet对象的一些最常用方法如下所示。
getInt(int);将序号为 int的列的内容作为整数返回。
getInt(String);将名称为 String的列的内容作为整数返回。
getFloat(int);将序号为 int的列的内容作为一个 float型数返回。
getFloat(String);将名称为 String的列的内容作为 float型数返回。
getDate(int);将序号为 int的列的内容作为日期返回。
getDate(String);将名称为 String的列的内容作为日期返回。
next();将行指针移到下一行。如果没有剩余行,则返回 false。
Close();关闭结果集。
getMetaData();返回 ResultSetMetaData对象。
ResultSetMetaData
您使用 getMetaData()方法从 ResultSet中获取 ResultSetMetaData对象。您可以使用此对象获得列的数目和类型以及每一列的名称。
getColumnCount();返回 ResultSet中的列数。
getColumnName(int);返回列序号为 int的列名。
getColumnLabel(int);返回此列暗含的标签。
isCurrency(int);如果此列包含带有货币单位的一个数字,则返回 true。
isReadOnly(int);如果此列为只读,则返回 true。
isAutoIncrement(int);如果此列自动递增,则返回 true。这类列通常为键,而且始终是只读的。
getColumnType(int);返回此列的 SQL数据类型。这些数据类型包括
BIGINT
BINARY
BIT
CHAR
DATE
DECIMAL
DOUBLE
FLOAT
INTEGER
LONGVARBINARY
LONGVARCHAR
NULL
NUMERIC
OTHER
REAL
SMALLINT
TIME
TIMESTAMP
TINYINT
VARBINARY
VARCHAR
DatabaseMetaData
DatabaseMetaData对象可为您提供整个数据库的信息。您主要用它获取数据库中表的名称,以及表中列的名称。由于不同的数据库支持不同的 SQL变体,因此,也有多种方法查询数据库支持哪些 SQL方法。
getCatalogs()返回该数据库中的信息目录列表。使用 JDBC-ODBC Bridge驱动程序,您可以获得用 ODBC注册的数据库列表。这很少用于 JDBC-ODBC数据库。
getTables(catalog, schema,tableNames, columnNames)返回表名与 tableNames相符而且列名与 columnNames相符的所有表的说明。
getColumns(catalog, schema,tableNames, columnNames)返回表名与 tableNames相符而且列名与 columnNames相符的所有表列说明。
getURL();获得您所连接的 URL名称。
getDriverName();获得您所连接的数据库驱动程序的名称。
获取有关表的信息
您可以使用 DataBaseMetaData的 getTables()方法来获取数据库中表的信息。这个方法有如下4个 String参数:
results=dma.getTables(catalog, schema, tablemask, types[]);
其中参数的意义是:
Catalog要在其中查找表名的目录名。对于 JDBC-ODBC数据库以及许多其他数据库而言,可将其设置为 null。这些数据库的目录项实际上是它在文件系统中的绝对路径名称。
Schema要包括的数据库“方案”。许多数据库不支持方案,而对另一些数据库而言,它代表数据库所有者的用户名。一般将它设置为 null。
Tablemask一个掩码,用来描述您要检索的表的名称。如果您希望检索所有表名,则将其设为通配符%。请注意,SQL中的通配符是%符号,而不是一般 PC用户的*符号。
types[]这是描述您要检索的表的类型的 String数组。数据库中通常包括许多用于内部处理的表,而对作为用户的您没什么价值。如果它是空值,则您会得到所有这些表。如果您将其设为包含字符串“TABLES”的单元素数组,您将仅获得对用户有用的表格。
一个简单的 JDBC程序
我们已经学习了 JDBC的所有基本功能,现在我们可以编写一个简单的程序,该程序打开数据库,打印它的表名以及某一表列的内容,然后对该数据库执行查询。此程序如下所示:
package skydevkit;
import java.sql.*;
public class JdbcOdbc_test{
ResultSet results;
ResultSetMetaData rsmd;
DatabaseMetaData dma;
Connection con;
public JdbcOdbc_test() throws SQLException{
String url="jdbc:odbc:Northwind";
try{
//加载 JDBC-ODBC桥驱动程序
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
con= DriverManager.getConnection(url);//连接数据库
dma= con.getMetaData();//获取数据库的元数据
System.out.println("Connected to:"+ dma.getURL());
System.out.println("Driver"+ dma.getDriverName());
} catch(Exception e){
System.out.println(e);
}
try{
Statement stmt= con.createStatement();
results= stmt.executeQuery("select* from客户;");
ResultSetMetaData resultMetaData= results.getMetaData();
int cols= resultMetaData.getColumnCount();
String resultRow="";
for(int i= 1; i< cols; i++){
resultRow+= resultMetaData.getColumnName(i)+";";
}
System.out.println(resultRow);
while(results.next()){
resultRow="";
for(int i= 1; i< cols; i++){
try{
resultRow+= results.getString(i)+";";
} catch(NullPointerException e){
System.out.println(e.getMessage());
}
}
System.out.println(resultRow);
}
} catch(Exception e){
System.out.println("query exception");
} finally{
results.close();
}
}
}
补充高级内容
关于调用SQLServer存储过程的例子:(用到了我们开发的数据库连接类)
CREATE PROCEDURE [dbo].[sp_getStudentByName](@name char(10))
AS
Select* from Students where [Name]=@name
GO
DbObject DbO= new DbObject(new SqlServerConnectionFactory("localhost",
1433,"demo","sa",""));
Connection con= DbO.getConnection();
CallableStatement pstmt= null;
System.out.println("TestDB1()............");
/* try{
pstmt= con.prepareCall("{call sp_getStudentById(?)}");
pstmt.setInt(1, 1);
}*/
try{
pstmt= con.prepareCall("{call sp_getStudentByName(?)}");//注意参数如何传递
pstmt.setString(1,"Tom");
}
……
使用输出参数:
CREATE PROCEDURE [dbo].[sp_insertStudent](@name char(10),@age int,@id int OUTPUT) AS
insert into Students([Name],[Age]) values(@name,@age)
select@id=@@IDENTITY
GO
try{
pstmt= con.prepareCall("{call sp_insertStudent(?,?,?)}");
pstmt.setString(1,"zengqingsong");
pstmt.setInt(2, 22);
pstmt.registerOutParameter(3, Types.INTEGER);
pstmt.executeUpdate();
int id= pstmt.getInt(3);
System.out.println(id);
}
使用返回参数的例子:
CREATE PROCEDURE [dbo].[sp_insertStudent](@name char(10),@age int,@id int OUTPUT) AS
insert into Students([Name],[Age]) values(@name,@age)
select@id=@@IDENTITY–测试输出参数
return 30–测试返回30
GO
try{
pstmt= con.prepareCall("{?=call sp_insertStudent(?,?,?)}");
pstmt.setString(2,"zengqingsong");
pstmt.setInt(3, 22);
pstmt.registerOutParameter(4, Types.INTEGER);
pstmt.registerOutParameter(1, Types.INTEGER);
int ret= pstmt.executeUpdate();//执行影响的行数
int ret2= pstmt.getInt(1);//返回参数(输出参数)
int id= pstmt.getInt(4);//输出参数
System.out.println(ret);
System.out.println(ret2);
System.out.println(id);
END,本文到此结束,如果可以帮助到大家,还望关注本站哦!