项目创建以后首先是导入数据库对应的相应数据库驱动包. 接下来就是JDBC的使用代码实例。
1 获取数据库驱动。
Class.forName("数据库驱动类的全路径")。
数据库驱动类的全路径如 下:
mysql : com.mysql.jdbc.Driver。
oracle : oracle.jdbc.driver.OracleDriver。
SQLServer:com.microsoft.jdbc.sqlserver.SQLServerDriver。
2 获取数据库连接。
Connection conn = DriverManager.getConnection("数据库地址","用户名","密码");
数据库地址配置如下:
mysql : jdbc:mysql://IP地址:端口号/数据库名。
oracle : jdbc:oracle:thin:@IP地址:端口号:数据库名。
SQL Server : jdbc:sqlserver://IP地址:端口号; databaseName=数据库名。
3 通过第2步中获取到的连接对象conn, 获取Statement 对象
Statement statement = conn.createStatement();
或者通过conn,获取预编译对象。
PreparedStatement psmt=con.prepareStatement(sql);
如果是sql语句中带有参数建议使用预编译对象。但是需要通过预编译对象设置参数值。
如:psmt.setString(1, idcard);
4 通过Statement对象来执行sql语句,同时返回结果集。
如果sql语句是查询语句,则使用executeQuery(String str)方法,该方法返回ResultSet对象,该对象包装了查询结果。
如果sql语句是增删改语句,则使用executeUpdate(String str) 方法,该方法返回受影响的行数。
如果不知道选以上哪个方法,则选execute(String sql)方法,该方法返回一个boolean类型。如果为true则表示执行了查询语句,如果为 false则表示执行了查询以外的语句。
If(flag){
ResultSetrs = statement .getResultSet();
}else{
Int n =statement .getUpdateCount();
}
sta.setMaxRows(10) 设置Statement执行sql语句最大行数为10。
sta.getMaxRows() 返回这个Statement最大能装sql语句查询的多少行。(0表示不受限制)
5 查看执行完sql语句的返回结果
执行完sql语句后,结果返回在ResultSet对象里面
ResultSet对象里面有一个指针,这个指针默认指向第一行之前。当调用next()方法后,指针指向下一行。
注:在拿数据之前必须先有一个next()方法。
next()方法返回一个boolean类型,如果是true说明指针指向的位置还有数据;如果是false说明指针指向的位置没有数据了。
从ResultSet里面拿数据使用get***(int : n)方法:n为列的位置,从1开始。“***”表示拿出的数据转换成***类型.
6 关闭资源
ResultSet,Statement,Connection 调用close()方法。
ResultSet类:表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。
First();表示将ResultSe的指针指向第一行。
Last( )表示将ResultSe的指针指向最后一行
Next( )表示将指针指向下一行
Previous( )表示将指针指向上一行
Absolute( int n)表示直接将指针指向第n行
Get***( int n) n代表该字段在数据库中位置
Get***( String str) str代表该字段的字段名
JDBC元数据MateData
通过Connection类来获取数据库的信息,但Connection不能直接拿出信息。但可以通过Connection的getMetaData()方法来返回一个DatabaseMetaData 类,这个类里面包含了数据的信息。DatabaseMetaData dbmd = con.getMetaData();
数据库名=dbmd.getDatabaseProductName();
数据库版本号=dbmd.getDatabaseProductVersion();
数据库驱动名=dbmd.getDriverName();
数据库驱动版本号=dbmd.getDriverVersion();
数据库Url=dbmd.getURL();
该连接的登陆名=dbmd.getUserName();
通过ResultSet类来获取表的信息,但ResultSet不能直接返回信息。但可以通过ResultSet的getMetaData()方法来返回一个ResultSetMetaData 类,这个类里面包含了表的信息. ResultSetMetaData meta = rs.getMetaData();
字段个数:meta.getColomnCount();
字段名字:meta.getColumnName();
字段JDBC类型:meta.getColumnType();
字段数据库类型:meta.getColumnTypeName();