jdbc连接数据库的四个对象_优就业
来源:互联网 发布:大数据与教育 编辑:程序博客网 时间:2024/05/16 21:10
DriverManager 驱动类
DriverManager.registerDriver(new com.mysql.jdbc.Driver());不建议使用
原因有2个:
> 导致驱动被注册2次。
> 强烈依赖数据库的驱动jar
解决办法:
Class.forName("com.mysql.jdbc.Driver");
Connection 连接类
static Connection getConnection(String url, String user, String password)
试图建立到给定数据库 URL 的连接。
getConnection("jdbc:mysql://localhost:3306/day06", "root", "root");
URL:SUN公司与数据库厂商之间的一种协议。
jdbc:mysql://localhost:3306/day06
协议 子协议 IP :端口号 数据库
数据库类型
mysql: jdbc:mysql://localhost:3306/day14 或者 jdbc:mysql:///day14(默认本机连接)
oracle: jdbc:oracle:thin:@localhost:1521:sid
getConnection(String url, Properties info)
Properties info = new Properties();//要参考数据库文档 可以用文件代替
info.setProperty("user", "root");//用户名
info.setProperty("password","root");//密码
//获取连接对象返回值connection
Connection conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/day14?user=root&password=root");
Statement 操作数据库类
//创建操作数据库对象
Statement state=conn.createStatement();
String sql="sql语句";
Result rt= state.executeQuery(sql);//返回结果集
问题:存在sql注入
解决办法
使用传入参数方式 防止sql注入
Statement (PreparedStatement)//预编译对象PreparedStatement
特点:
1.性能要高
2.会把sql语句先编译
3.sql语句中的参数会发生变化,过滤掉用户输入的关键字。
Statement state= conn.preparedStatement();
String sql="select * from user where username=? and password=?";
Result rt= state.executeQuery(sql);//返回结果集
state.setString(1,username);
state.setString(2,password);
执行对象返回的结果
ResultSet executeQuery();
int executeUpdate();
boolean execute();
delete from users where id=?
ps.setInt(1,5);
ResultSet 结果集
结果集(客户端存表数据的对象)
//获取数据
next();
getString();
getDouble();
getDate();
总结
利用四个核心对象编写代码
try{
//加载驱动
Class.forName("com.mysql.jdbc.Driver");
//创建连接Connection
Connection conn = DriverManager.getConnection("jdbc:mysql:///day06","root","abc");
//得到执行sql的statement对象
//conn.createStatement();
PreparedStatement ps = conn.prepareStatement("select * from users where name=? and pwd=?");
ps.setString(1,"tom");
ps.setString(2,"123");
//执行语句,并返回结果
ResultSet rs = ps.executeQuery();
//处理结果
while(rs.next()){
User u = new User();
u.setId(rs.getInt(1));
.... }
}
catch(Exception e){
e.printSt... }
finally{
//关闭资源
if(rs!=null)
{rs.close();}
if(ps!=null)
{ps.close();}
if(conn!=null)
{conn.close();}
}
更多IT知识尽在优就业IT培训:www.ujiuye.com
本文为头条号作者发布,不代表今日头条立场。
- jdbc连接数据库的四个对象_优就业
- JDBC(连接数据库的四个主要步骤)
- JDBC连接MySQL数据库关键的四个步骤
- JDBC连接MySQL数据库关键的四个步骤
- jdbc 几种常见的数据库_连接
- JDBC连接数据库_零碎记录
- jdbc数据库的连接
- JDBC数据库的连接
- 数据库的连接JDBC
- JDBC数据库的连接
- 数据库JDBC的连接
- jdbc数据库的连接
- JDBC:数据库的连接
- 数据库的连接JDBC
- 数据库的连接-----jdbc
- 内存数据库timesten 的两种连接方式_附带altibase_oracle的jdbc连接
- JDBC连接数据库中的Statement对象
- jdbc 连接常见的数据库
- 安卓获取和判断网络状态
- 轻量级权限管理系统(renren-security)
- 【基础】Unity:Application的常用方法
- 一步步搞定Android行情K线蜡烛图(带十字光标)
- 欧拉计划 65
- jdbc连接数据库的四个对象_优就业
- 小程序开发资料!!!
- MYSQL数据库优化之SQL及索引优化-学习笔记(2)
- HttpClient,DefaultHttpClient使用详解
- Android源码树常用命令
- DEDECMS获取上级导航名称
- Android中使用AsyncTask实现文件下载以及进度更新提示
- Handler系列之使用
- 解决dubbo问题:forbid consumer