黑马程序员日记-12

原创 2015年11月19日 14:55:37

------- Android培训java培训 期待与您交流! ----------

JAVA 数据库连接四大件:driverurl、userpassword

连接过程:

String driver = “com.mysql.jdbc.Driver”;

String url = “jdbc:mysql://127.0.0.1:3306/目标数据库名”;

String user = “数据库登录名”;

String password = “数据库密码”;

 

Class.forName(driver);

Connection conn = DriverManager.getConnection(url,user,password);

 

DriverManager内部是一个驱动列表,可以同时注册很多驱动(中间用冒号分割)

 

注册驱动三种方法:

1) DriverManager.registerDriver(new com,mysql.jdbc.Driver());

会造成代码依赖:如果MySQLJAR包不存在代码就不能通过编译

会在DriverManager中产生两个相同的驱动实例

2) System.setProperty("jdbc.drivers","com,mysql.jdbc.Driver");

通过属性赋值方式注册驱动,很少使用

3) Class.forName("com,mysql.jdbc.Driver");

* forName()方法把类装载到Java虚拟机中,不一定创建实例。类装载到Java虚拟机中后,调用类的静态代码块(类的初始化),将其注册到DriverManager

推荐使用这种方式

 

关闭数据库连接要注意关闭顺序与获取顺序相反

/**

 * 关闭连接

 */

  public static void close(Connection conn,PreparedStatement pstmt,ResultSet rs) {
        if(rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            rs = null;
        }
        if(pstmt != null) {
            try {
                pstmt.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            pstmt = null;
        }
        if(conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            conn = null;
        }
    }


 

查询过程:

1) Statement查询

Statement stmt = conn.createStatement();
String sql = "select * from 表名";
ResultSet rs = stmt.executeQuery(sql);
while (rs.next()) { 		
System.out.println(rs.getString("列名") + "\t" + rs.getString("列名"));
}
rs.close();
conn.close();


2) preparedStatement查询

PreparedStatement pstmt = null;

String sql = "select * from cars";

String sql_1 = "insert into cars values (?,?,?,? )";

/*

查询车辆信息

*/

pstmt = conn.prepareStatement(sql);

pstmt.executeQuery(sql);

/*

插入车辆信息

*/

PreparedStatement pstmt = null;
String sql = "select * from cars";
String sql_1 = "insert into cars values (?,?,?,? )";
/*
* 查询车辆信息
*/
pstmt = conn.prepareStatement(sql);
pstmt.executeQuery(sql);
/*
* 插入车辆信息
*/
pstmt = conn.prepareStatement(sql_1);
pstmt.setString(1, "蒙B123456");
pstmt.setString(2, "张三");
pstmt.setString(3, "灰色");
pstmt.setInt(4, 12000);
pstmt.executeUpdate();
Preparedstatement查询时pstmt.executeUpdate();//执行语句中不能有sql参数,否则会有sql语句为空的Exception


 

版权声明:本文为博主原创文章,未经博主允许不得转载。

黑马程序员_Java学习日记12_IO流1

----------------------android培训、java培训、期待与您交流! --------------------- 1.IO流概述(Input,Output) IO流用来...

黑马程序员_学习日记12_面试基本知识点收集

面试题: 1、你怎么理解变量 常用类型,列出几个 2、访问修饰符修饰符的作用域 3、sql联表查询 sql语句 orderby,group by,join 4、html如何提交表单 表单...

黑马程序员_Java学习日记num12

------- android培训、java培训、期待与您交流! ---------- 学习内容:正则表达式概述。正则表达式的匹配;切割;替换;获取 一、正则表达式概述 正则表达式:符合一定规则的表...

黑马程序员_学习日记12_非表单元素视图状态保存

---------------------- Windows Phone 7手机开发、.Net培训、期待与您交流! ----------------------   我们通过一个DIV来实现一个数...

黑马程序员_日记12_多线程(二)

——- android培训、java培训、期待与您交流! ———-线程的运行状态线程的运行状态在这里我们划分为五种状态。 依次为:被创建,运行,冻结,消亡,阻塞。 它们的关系见下图: 如上图所示...

黑马程序员_学习日记73_725ASP.NET(禁用Cookie、ASP.NET中的重要对象、JavaScript实现AJAX、两种Json格式的序列化方法、JQuery中实现ajax的五种方法)

一、禁用Cookie 禁用cookie 在webconfig中禁用了cookie,session还可以使用,sessionId通过url传递。 如果在浏览器中禁用cookie,这时ses...

黑马程序员_JAVA学习日记_JAVA中API:集合框架1(Collection,List,Set及其子类和迭代器的应用)

黑马程序员-学习日记   黑马程序员_JAVA中集合框架1(Collection,List,Set及其子类和迭代器的应用)   ------- android培训、java培训、期待与您交流!...

黑马程序员java基础学习日记——做题遇到GBK查资料发现了个有趣的文章——ASCII、Unicode、GBK和UTF-8字符编码的区别联系

------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! ------- 很久很久以前,有一群人,他们决定用8个可以开合的晶体管来组合成不同的状态,以表示世界上的万...

黑马程序员 学习日记(九)

Java中的多线程
  • jwx555
  • jwx555
  • 2014年07月17日 23:04
  • 250
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:黑马程序员日记-12
举报原因:
原因补充:

(最多只允许输入30个字)