Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
注册驱动
Class.forName("com.mysql.jdbc.Driver");
调用类方法forName注册驱动,方法参数为jdbc驱动文件名,驱动文件可在在各大数据库厂商官网下载
获取数据库连接对象
conn = DriverManager.getConnection(url);
url:统一资源定位标志
常见数据库url格式:
Microsoft SQL Server 2005 JDBC Driver
jdbc:sqlserver://<server_name>:<port>默认端口1433,如果服务器使用默认端口则port可以省略
Oracle:
jdbc:oracle:thin:@//<host>:<port>/ServiceName或jdbc:oracle:thin:@<host>:<port>:<SID>
MySql:
jdbc:mysql://<host>:<port>/<database_name>默认端口3306,如果服务器使用默认端口则port可以省略MySQL Connector/J Driver 允许在URL中添加额外的连接属性jdbc:mysql://<host>:<port>/<database_name>?property1=value1&property2=value2
3. 编写SQL(以查询为例)
String sql = "insert into t_user(userId,userName,passWord) values(4,?,?)";
SQL 语句中增删改查条件参数用问号(?)来表示(?在SQL中表示占位符)
4. 获取预编译的数据库操作对象
ps = conn.prepareStatement(sql);
预编译相当于将不含参数的sql语句预先编译一遍,再将参数传入,防止sql注入导致的漏洞
5.将占位符处的参数传送给已经预编译好了的sql语句,
ps.setString(1,"xxxx");
ps.setString(2, "xxxx");
第一个参数是占位符的g编号,编号从1开始数,第二个参数数据类型是String,是出入占位符处的参数,常用的传参函数有:
PreparedStatement类型的对象ps的传参方法有
void setInt(int parameterIndex, int x)
void setLong(int parameterIndex, long x)
void setString(int parameterIndex, String x)
void setBlob (int parameterIndex, Blob x)
void setDate(int parameterIndex, java.sql.Date x, Calendar cal)
6.执行SQL语句 查询sql语句执行的返回类型是结果集,增删改sql语句的返回结果是影响行数
增删改:
count = ps.executeUpdate();
查询:
rs = ps.executeQuery(); //返回查询结果集
7.按照指定格式输出查询结果
while(rs.next()){
int userId = rs.getInt("userId");
String userName = rs.getString("userName");
String passWord = rs.getString("passWord");
System.out.println(userId+"\t"+userName+"\t"+passWord);
}
结果集有个游标,一开始指向结果集第一行的前面
next()函数将游标指向下一行,返回游标,若为空,返回0
获取数据函数:
getString("列名")
getInt("列名")
注:记得释放对象资源
参考代码:
Connection conn = null;
PreparedStatement ps = null;
ResultSet rs = null;
try{
//注册驱动 调用类方法forName注册驱动,方法参数为jdbc驱动文件名,驱动文件可在在各大数据库厂商官网下载
Class.forName("com.mysql.jdbc.Driver");
// 获取数据库连接对象 参数为URL
conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb?characterEncoding=UTF-8","root","123123");
// 编写查询 SQL SQL 语句中的参数用问号(?)来表示(?在SQL中表示占位符)
String sql = "insert into t_user(userId,userName,passWord) values(4,?,?)";
// 获取预编译的数据库操作对象 预编译相当于将不含参数的sql语句预先编译一遍,再将参数传入,防止sql注入导致的漏洞
ps = conn.prepareStatement(sql);
/*将占位符处的参数传送给已经预编译好了的sql语句,
第一个参数是第一个占位符,个数从1开始数,第二个参数数据类型是String,是出入占位符处的参数
PreparedStatement类型的对象ps的传参方法有
void setInt(int parameterIndex, int x)
void setLong(int parameterIndex, long x)
void setString(int parameterIndex, String x)
void setBlob (int parameterIndex, Blob x)
void setDate(int parameterIndex, java.sql.Date x, Calendar cal)
*/
ps.setString(1,"xxxx");
ps.setString(2, "xxxx");
//执行SQL语句 查询sql语句执行的返回类型是结果集,增删改sql语句的返回结果是影响行数
count = ps.executeUpdate();
}catch(Exception e){
//抛出异常
e.printStackTrace();
}finally{
// 关闭资源,注意关闭资源的顺序
try{
if(ps != null){
ps.close();
}
if(conn != null){
conn.close();
}
}catch(Exception e){
e.printStackTrace();
}
}