JDBC(Java Data Base Connectivity)

JDBC是一组用Java编写的类和接口

  • 使用JDBC的好处:

    • 1.Java的开发人员完全不需要关心数据库的连接方式和实现手段
    • 2.提高代码的可维护性,是一种组件化思想
    • 3.代码的执行效率很高 速度很快
  • JDBC的缺点
    • 1.代码繁琐(最大毛病)
    • 2.维护代价高

编写JDBC

增删改(都差不多 就写一个了)

1.获取连接

下面的四个信息,只有当开发者在更换数据库时候需要改,其他所有的都不需要改

String url = "jdbc:mysql://localhost:3306/j0302";

String username = "root";

String password = "1234";

String driver = "com.mysql.jdbc.Driver"; // 驱动

    Student student = new Student();
student.setName("王五");
student.setAddress("上海"); Connection conn = null;
PreparedStatement stmt = null; try { //加载驱动
//Java反射技术
Class.forName(driver); //创建一个数据库连接 conn = DriverManager.getConnection(url, username, password);
  1. 执行SQL语句

         //正常sql

// stmt = conn.prepareStatement("insert into student values (null ,'lisi','beijing')");

        //字符串拼接实现sql缺点:麻烦,难以维护;不安全,完全无法避免SQL注入

// stmt = conn.prepareStatement("insert into student values (null,'"+student.getName()+"','"+student.getName()+"')");

        stmt = conn.prepareStatement("insert  into student(name,address) values (?,?)");

        //给上述sql的占位符赋值
stmt.setString(1,student.getName());
stmt.setString(2,student.getAddress()); //增删改都使用该方法
int i = stmt.executeUpdate(); //i代表这次sql语句执行
System.out.println(i); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}finally { //3.关闭资源 try {
if (stmt != null) {
stmt.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if (conn != null) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}

public class QueryClass {

public static void main(String[] args) {

    String url = "jdbc:mysql://localhost:3306/j0302";
String username = "root";
String password = "1234";
String driver = "com.mysql.jdbc.Driver"; //jdbc查询的写法 //jdbc查询的目的:就是为了获取相应对象的list
Connection conn = null;
PreparedStatement stmt = null;
ResultSet rs = null; List<Student> list = new ArrayList();
try {
Class.forName(driver);
conn = DriverManager.getConnection(url, username, password); String sql = "select * from student";
stmt = conn.prepareStatement(sql); //执行查询返回一个结果集 rs = stmt.executeQuery();
//rs.next()用来获取下一行数据
while (rs.next()){ int sid = rs.getInt("sid");
System.out.println(sid); String name = rs.getString("name");
System.out.println(name); String address = rs.getString("address");
System.out.println(address); //每次循环都要创建一个新的stu 用来存储数据
Student stu = new Student();
stu.setId(sid);
stu.setName(name);
stu.setAddress(address); list.add(stu); } } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}finally {
try {
if (conn != null) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
} try {
if (stmt != null) {
stmt.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
try {
if (rs != null) {
rs.close();
}
} catch (SQLException e) {
e.printStackTrace();
} } }

工具及工程:

JDBC工程

链接:https://pan.baidu.com/s/1-aUnJ9udezZufcO8YT38hA

提取码:2e78

JDBC优化

链接:https://pan.baidu.com/s/1OR2zfxPvVgfk5WQZZ-C0Rw

提取码:zkv3

2019.3.28 JDBC相关的更多相关文章

  1. Alpha冲刺(5/10)——2019.4.28

    所属课程 软件工程1916|W(福州大学) 作业要求 Alpha冲刺(5/10)--2019.4.28 团队名称 待就业六人组 1.团队信息 团队名称:待就业六人组 团队描述:同舟共济扬帆起,乘风破浪 ...

  2. 「FFT」题单(upd 2019.4.28)

    持续更新(last upd 2019.4.28) ZJOI2014 力 [题目链接] 解法 对原式进行转换,然后卷积FFT套上去求解就可以了. 推导过程简洁版: \[F_i=\sum_{j<i} ...

  3. 2019.3.28&2019.3.30考试

    2019.3.28 : 肥肠爆芡,因为这场考试的题太屑了,所以我咕咕了 Upd on 2019.3.30 压进来一篇(因为都没啥意义) 2019.3.30 : 全机房读错题+没有大样例=T2全体爆炸 ...

  4. 2019.2.28&2019.3.1 考试

    因为没A/改几道题,就一起写了 题目在LOJ上都能找到 2019.2.28 100+20+12 前两个小时一直在睡觉+想题也没思路,我太菜了 T1 洗衣服 分开处理出洗衣服和烘干的时间,然后一边正着排 ...

  5. 梦想MxWeb3D协同设计平台 2019.02.28更新

    梦想MxWeb3D协同设计平台 2019.02.28更新 SDK开发包下载地址: http://www.mxdraw.com/ndetail_10130.html 在线演示网址: http://www ...

  6. Beta冲刺(7/7)——2019.5.28

    所属课程 软件工程1916|W(福州大学) 作业要求 Beta冲刺(7/7)--2019.5.28 团队名称 待就业六人组 1.团队信息 团队名称:待就业六人组 团队描述:同舟共济扬帆起,乘风破浪万里 ...

  7. AI2(App Inventor 2)离线版服务器(2019.04.28更新)

    我们的目标:搭建一个本地多用户的App Inventor 2 服务器   演示: http://ai2.fsyz.net  [旧 win]     http://ai2n.fsyz.net [新 Ce ...

  8. 02 JDBC相关

    ====================================================================================JDBC JAVA Databa ...

  9. JDBC相关总结

    JDBC statement的相关总结 1.Statement.PreparedStatement和CallableStatement都是接口(interface). 2.Statement继承自Wr ...

随机推荐

  1. 怎样去阅读一份php源代码

    一份好的源代码例如 dz的论坛,wind论坛,帝国cms,dedecms等,都具有自己的一套设计思路和设计模式,所以在看某个产品之前就要做好心理准备,可以把自己的经验和这些产品做对比,但千万别一直用自 ...

  2. [GO]copy的使用

    package main import "fmt" func main() { srcslice := [],} dstslice := [],,,,,} copy(dstslic ...

  3. poj3080 Blue Jeans(暴枚+kmp)

    Description The Genographic Project is a research partnership between IBM and The National Geographi ...

  4. MongoDB整理笔记のReplica oplog

    主从操作日志oplog MongoDB的Replica Set架构是通过一个日志来存储写操作的,这个日志就叫做"oplog".oplog.rs是一个固定长度的capped coll ...

  5. Spring Websocket与sockJS结合实现

    首先了解Stomp协议:简单的消息文本协议 采用广播机制与队列,可以和Activemq结合使用 Stomp协议学习与实战 http://diaocow.iteye.com/blog/1725186 S ...

  6. .net Stream篇(七)

    NetworkStream 目录: NetworkStream的作用 简单介绍下TCP/IP 协议和相关层次 简单说明下 TCP和UDP的区别 简单介绍下套接字(Socket)的概念 简单介绍下Tcp ...

  7. 小度wifi在window server2008R2系统下创建不了

    小度wifi在window server2008R2系统下创建的时候会一直显示正在创建,然后又消失的情况.这是因为win server 2008下默认的无线lan服务没开启 解决方法: 在“服务管理器 ...

  8. mvc+EF - 有用文章

    Mvc全局过滤器与Action排除:http://blog.csdn.net/shuaihj/article/details/53020428 MVC 自定义AuthorizeAttribute实现权 ...

  9. SQLServer备份恢复助手(太强大了!)

    下载地址: http://download.csdn.net/detail/gguozhenqian/8105779

  10. react.js学习之路四

    针对学习react.js中,我感觉最大的疑惑点就是bind(this)的绑定和指向问题了,我被这个问题弄的头昏,有时候调用组件的时候,直接显示undefined,不存在这个组件,当时的心情是崩溃的,整 ...