JDBC学习笔记

[b]连接数据的步骤[/b]
1.注册驱动
2.建立连接
3.创建执行SQL的语句(Statement)
4.执行语句
5.处理执行结果(ResultSet)
6.释放资源
public static void main(String[] args) throws ClassNotFoundException, SQLException{

//1.注册驱动
//DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//System.setProperty("jdbc.drivers","com.mysql.jdbc.Driver : com.oracle.jdbc.Driver");
Class.forName("com.mysql.jdbc.Driver");

//2.建立连接
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/jdbc","root","");

//3.创建语句
Statement st = conn.createStatement();

//4.执行语句
ResultSet rs = st.executeQuery("select * from user");

//5.处理结果
while(rs.next()){
System.out.println(rs.getObject(1)+" "+rs.getObject(2));
}

//6.释放连接
rs.close();
st.close();
conn.close();

}


[b]建立连接的URL格式:[/b]
JDBC:子协议:子名称//主机名:端口号/数据库名?属性1=属性值&...
主机名和端口号如果是本机和默认端口号,就可也省略。

[b]预处理执行sql[/b]

String sql = "select id,name from user where name=?";
//预处理sql,防止sql注入
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, "张三");
//执行语句
ResultSet rs = ps.executeQuery();


[b]插入CLOB数据[/b]
String sql = "insert into clob_test(big_text) values(?)";
PreparedStatement ps = conn.prepareStatement(sql);
File file = new File("filename");
Reader reader = new BufferedReader(new FileReader(file));
//设置大文本流
ps.setCharacterStream(1,reader);
//执行语句
ps.executeUpdate();


[b]读取CLOB数据[/b]
String sql = "select big_test from clob_test";
PreparedStatement ps = conn.prepareStatement(sql);
ResultSet rs = ps.executeQuery();

while(rs.next()){
Clob clob = rs.getClob(1);
Reader reader = clob.getCharacterStream();
//reader = rs.getCharacterStream(1);

//拿到reader就可以做一些事
}


[b]可以返回主键的操作[/b]
String sql = "insert into user(name) values('aa')";
//可以返回主键
PreparedStatement ps = conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);//根据传的不同参数,可以有不同的功能
ps.executeUpdate();

ps.getGeneratedKeys();//获取主键


[b]批处理执行[/b]
 String sql = "insert into user(name) values('aa')";
PreparedStatement ps = conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);

ps.addBatch();
ps.executeBatch();


[b]可滚动的结果集[/b]
 String sql = "select * from user";
//创建可滚动的结果集,第二个参数是关于并发的
PreparedStatement ps = conn.prepareStatement(sql,ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
ResultSet rs = null;
rs = ps.executeQuery();

//绝对定位
rs.absolute(5);
if(rs.previous()){}


[b]获取数据库的元数据(其他元数据获取同理,如ResultSet.getMetaData())[/b]
   Connection conn = null;
DatabaseMetaData dbmd = conn.getMetaData();
dbmd.getDatabaseProductName();//获取数据库名字

[b]获取PreparedStatement 的元数据[/b]
 String sql = "select * from user where a=?,b=?";
PreparedStatement ps = conn.prepareStatement(sql);
ParameterMetaData pmd = ps.getParameterMetaData();
//获取参数个数
int count = pmd.getParameterCount();

//获取第一个参数的信息,mysql没有很好实现这些接口,不同的驱动有不同的实现
pmd.getParameterClassName(1);//参数类名,java.lang.String
pmd.getParameterType(1);//参数类型,12
pmd.getParameterTypeName(1);//参数数据库类型名字,VARCHAR
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值