java连接数据库的两种方法总结
方法一:使用jdbc-odbc桥连接sql server,作为中间媒介连接数据库
- 1.配置数据源:打开控制面版->管理工具->数据源(ODBC)->选用户DSN,按下添加按钮->sql server->写下数据源的名字(假设是test),再写下连接的服务器名(一般默认为local或.)->更改默认的数据库为(勾选你想要连接的数据库)->接下来一直确定就完成了数据源的配置.
- 2.加载驱动:Class.forNmae("sun.jdbc.odbc.JdbcOdbcDriver");
- 3.得到连接:Connection ct=DriverManager.getConnection("jdbc:odbc:test");test是配置数据源的时候的数据源名字
- 4.创建preparedStateMent,这个语句主要是用于发送sql语句到数据库.
- 5.最后关闭资源
代码:
import java.sql.*;
public class preparedStatement {
public static void main(String[] args) {
Connection ct = null;
PreparedStatement ps = null;
ResultSet rs=null;
try {
//加载驱动
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
//得到连接
ct=DriverManager.getConnection("jdbc:odbc:test");
//创建一个PreparedStatement,用于向数据库放松sql语句
ps=ct.prepareStatement("select * from 产品名称表");
//得到结果
rs=ps.executeQuery();//这个方法适用于从表中查找数据
//如果要向表中插入,删除,更新数据需要使用方法executeUpdate();
while(rs.next()){//这里rs.next()一定要使用next()方法,否则有空指针错误
String number=rs.getString(1);
String string=rs.getString(2);
System.out.println(number+" "+string);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
// 关闭资源,记住关闭资源的顺序,根据得到赋值的反顺序进行关闭资源
try {
if(rs!=null){
rs.close();
}
if (ps != null)
ps.close();
if (ct != null)
ct.close();
}
catch(Exception e){
e.printStackTrace();
}
}
}
}
方法二:使用驱动程序直接操作数据库(这个方法更多人使用,但是前期所做的工作更多)
- 1.需要引入jar包,sql server2008只要引入sqljdbc4.jar包就行了。这个包百度上有下载。
这是我下载的网址:http://download.csdn.net/download/a785143175/5163519
导入方法:工具栏project选项->properties->java Build path中选择libraries->点击add Externar jars按钮->然后在你电脑中选中sqljdbc4.jar导入进去- 2.连接数据库一般是使用sql验证,所以需要你自己建立帐号密码。
方法:先用windows验证进入数据库,然后在安全性中点击鼠标右键新建登录名,勾选SQL身份验证,将强制密码过期不选,点击确定。然后断开连接,重新以现在的用户名和密码连接。然后在这个用户名中新建数据库就好。- 3、接下来的代码部分跟odbc类似,有些小小的不同。
代码:
import java.sql.*;
public class jdbc1 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Connection ct = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
//第一步,加载驱动
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
//得到连接
ct=DriverManager.getConnection("jdbc:sqlserver://localhost:1433;databaseName=liuyan","sa","3209554");
//创建PreparedStatement
ps=ct.prepareStatement("select * from userinformation where name='张三丰'");
rs=ps.executeQuery();
//这个方法适用于从表中查找数据
//如果要向表中插入,删除,更新数据需要使用方法executeUpdate();
while(rs.next()){//这里rs.next()一定要使用next()方法,否则有空指针错误
String number=rs.getString(1);
String string=rs.getString(2);
String string2=rs.getString(3);
System.out.println(number+" "+string+" "+string2);
}
} catch (Exception e) {
e.printStackTrace();
}finally{
try {
if(rs!=null){
rs.close();
}
if (ps != null)
ps.close();
if (ct != null)
ct.close();
}
catch(Exception e){
e.printStackTrace();
}
}
}
}
几点注意
我们每次在连接数据库前都必须要引入sql包:import java.sql.*
我们还可以使用?赋值的方法
ps=ct.prepareStatement("select * from 产品名称表 whrer 产品名称=?");
ps.setString(1,"手机");//表示在第一个问号上添加“手机”的字符串.如果是整数用setInt()方法;
总结
经过了一个下午和一个晚上的奋斗,终于将myeclipse和数据库连接成功了。中间出现了好多问题:找不到包(到现在也不知道为什么会找不到),空指针异常,通过端口1433连接到主机失败,远程过程调试失败。感觉都快要崩溃了,好在最后还是连上了。学习新东西的过程就是漫长又磨人的,但学成之后还是充满了成就感。
java连接数据库的两种方法总结的更多相关文章
- Qt连接数据库的两种方法
我曾经想过,无论在哪个平台下开发,都不要再接触SQL Server了,但显然不行.我们是来看世界的,不是来改变世界的,想通就好. 前两天,尝试了一下Qt下远程访问数据库.在macOS下,用Qt 5.1 ...
- ubuntu 安装JAVA jdk的两种方法:
ubuntu 安装jdk 的两种方式: 1:通过ppa(源) 方式安装. 2:通过官网下载安装包安装. 这里推荐第1种,因为可以通过 apt-get upgrade 方式方便获得jdk的升级 使用pp ...
- java循环HashMap两种方法的效率比较
一.循环HashMap的两种方式 方式1: Iterator<Entry<String, String>> entryKeyIterator = entrySetMap.ent ...
- Java对象排序两种方法
转载:https://blog.csdn.net/wangtaocsdn/article/details/71500500 有时候需要对对象列表或数组进行排序,下面提供两种简单方式: 方法一:将要排序 ...
- MySQL之连接数据库的两种方法
方法一: package DB; import java.sql.Connection; import java.sql.DriverManager; public class Conn { // 定 ...
- 谈谈关于PHP连接数据库的两种方法(PDO&Mysqli)
前言:在我们之前学习sql语句的时候都是停留在黑窗口的,怎样才能让mysql与程序代码发生联系呢?此时PDO和Mysqli应运而生,为了解决这个问题 (一)开启其中(pdo或者mysqli)的php扩 ...
- java异常处理的两种方法
一种是try-catch-finally,监视代码段,如果有异常就捕获. 另一种是此处不处理,声明在方法后面,抛给上级.(不处理也是一种处理)
- Java 创建线程的两种方法
Java提供了线程类Thread来创建多线程的程序.其实,创建线程与创建普通的类的对象的操作是一样的,而线程就是Thread类或其子类的实例对象.每个Thread对象描述了一个单独的线程.要产生一个线 ...
- Java构造和解析Json数据的两种方法详解二
在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面接着介绍用org.json构造和解析Jso ...
随机推荐
- jQuery实现 自动滚屏操作
实现自动滚屏思路: 1.滚屏即:文本的往上移动一段距离: 2.那么我们使文本每过一段时间就往上移动一段固定距离,就可实现滚屏: 3.直到文本底部出现在浏览器窗口中,专业点就是 文本移动的距离 + 浏览 ...
- Facade(外观模式或门面模式)
常用的模式之一. 为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 完美地体现了依赖倒转原则和迪米特法则的思想. Facade模式应用场景: 首先 ...
- 最小生成树——Kruscal(克鲁斯卡尔算法)
一.核心思想 将输入的数据由小到大进行排序,再使用并查集算法(传送门)将每个点连接起来,同时求和. 个人认为这个算法比较偏向暴力,有些题可能会超时. 二.例题 洛谷-P3366 题目地址:ht ...
- 树形DP(例题)
没有上司的舞会 题目 Ural大学有N个职员,编号为1~N.他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.每个职员有一个快乐指数.现在有个周年庆宴会,要求与会职 ...
- 【Hutool】Hutool工具类之Http工具——HttpUtil
最简单最直接的上手可以参见参考文档:http://hutool.mydoc.io/?t=216015 Http协议的介绍,请参考web随笔:http://www.cnblogs.com/jiang ...
- AS 3.1 多library合并打包成aar的正确方式(fat-aar)
前言 主要参考fat-aar来合并打包. 但是这个fat-aar很久没维护了,如果直接使用它会有很多问题.由于对gradle脚本也不是太熟,就只能顺着它的意思,将gradle降级成2.2.3的版本. ...
- PHP.48-TP框架商城应用实例-后台23-权限管理-权限验证
权限验证 1.登录控制器 2.通过tp验证码类生成验证码图片 3.在管理员模型增加登录验证规则 4.后台中所有的控制器必须先登录才能访问 思路:在访问任何一个控制器之前都判断一个session即可,= ...
- 成都Uber优步司机奖励政策(3月26日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- LeetCode:35. Search Insert Position(Easy)
1. 原题链接 https://leetcode.com/problems/search-insert-position/description/ 2. 题目要求 给定一个已经排好序的数组和一个目标值 ...
- macOS 10.13 High Sierra PHP开发环境配置
命令:sudo rm /usr/local/mysql sudo rm -rf /usr/local/mysql* sudo rm -rf /Library/StartupItems/MySQLCOM ...