java jdbc连接和使用

jdbc
导入驱动
//jar是已经打包好的class文件集,可以引用到其他工程中
//Build Path中add external jars导入
连接JDBC
1. 加载驱动
Class.from("com.mysql.jdbc.Driver");
创建连接
//导包使用 java.sql.*; String jdbc="jdbc:mysql://localhost:3306/student?user=root&password=&characterEncoding=utf-8";//student是表名 Connection conn = DriverManager.getConnection(jdbc);
2. 注意 数据库打开之后一定要记得关。
conn.close();
1. 执行SQL语句 (创建表,插入,删除,更新)
使用Statemant
Statemant st = conn.createStatemant(); int row = st.executeUpdate(sql语句);//不能做查询操作。
使用PrepareStatement
可以使用?占位符来代替你需要传递的参数
String sql = "insert into " + TABLENAME + "(name,subject,score) values(?,?,?)"; PrepareStatement pt = conn.prepareStatement(sql); //给每一位占位符设置值,下标从1开始 pt.setString(1,score.getName()); pt.setString(2.score.getSubject()); pt.setDouble(3,score.getScore()); //使用无参的方法 pt.executeUpdate();
1.查询操作
static List<Score> queryScore(Connection pconn, Score pScore)
throws SQLException {
ArrayList<Score> mlist = new ArrayList<>();
String sql = "select * from " + TABLENAME + " where name = ?";
PreparedStatement ps = pconn.prepareStatement(sql);
ps.setString(1, pScore.getName());
ResultSet rs = ps.executeQuery();
while (rs.next()) {
// 这里可以通过rs获取所有结果
String subject = rs.getString("subject");
int id = rs.getInt("id");
double score = rs.getDouble("score");
mlist.add(new Score(id, pScore.getName(), subject, score));
}
return mlist;
}
下面是一个小程序
//建立数据库连接类
public class DAO {
// 放问数据库的链接地址
static String jdbc = "jdbc:mysql://localhost:3306/student?user=root&password=&characterEncoding=utf-8";
// 打开链接
public static Connection connection() {
// 使用JDBC的步骤
// 1. 加载JDBC驱动
try {
// 类的全名 包名+类名
Class.forName("com.mysql.jdbc.Driver");
// 2. 连接数据库
Connection conn = DriverManager.getConnection(jdbc);
return conn;
} catch (Exception e) {
System.out.println("驱动加载失败");
return null;
}
}
}
//分数类
public class Score {
String name;
String id;
String subject;
double score;
public Score(String name, String subject, double score) {
super();
this.name = name;
this.subject = subject;
this.score = score;
}
@Override
public String toString() {
return "Score [name=" + name + ", id=" + id + ", subject=" + subject
+ ", score=" + score + "]";
}
public Score(String name, String id, String subject, double score) {
super();
this.name = name;
this.id = id;
this.subject = subject;
this.score = score;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getSubject() {
return subject;
}
public void setSubject(String subject) {
this.subject = subject;
}
public double getScore() {
return score;
}
public void setScore(double score) {
this.score = score;
}
}
//实现类
public class Test {
public static String TABLENAME = "score";
public static void main(String[] args) {
try {
Connection conn = DAO.connection();
if (conn != null) {
System.out.println("链接上了");
// createTable(conn);
// 插入一条记录
// Score score = new Score("李四 ", "Android", 98);
// System.out.println(addScore2(conn, score));
// deleteScore(conn, score);
// updateScore(conn, score);
List<Score> list = queryScoreByName(conn, "王五"); //queryAllScore(conn);
for (Score score : list) {
System.out.println(score);
}
conn.close();
} else {
System.out.println("链接失败 ");
}
} catch (SQLException e) {
e.printStackTrace();
}
}
// 创建一张表
public static boolean createTable(Connection conn) {
// 开始执行sql语句
String sql = "create table "
+ TABLENAME
+ "(id integer primary key auto_increment,name varchar(3) not null,subject varchar(20) not null,score double)";
// 要执行一条语句,需要一个执行的类 Statement
try {
Statement st = conn.createStatement();
int result = st.executeUpdate(sql);
System.out.println(result);
if (result != -1)
return true;
} catch (SQLException e) {
e.printStackTrace();
}
return false;
}
// 添加一条记录
public static boolean addScore(Connection conn, Score score)
throws SQLException {
String sql = "insert into " + TABLENAME
+ "(name,subject,score) values('" + score.getName() + "','"
+ score.getSubject() + "'," + score.getScore() + ")";
System.out.println(sql);
Statement st = conn.createStatement();
int row = st.executeUpdate(sql);
if (row > 0)
return true;
return false;
}
// 添加一条记录2
public static boolean addScore2(Connection conn, Score score)
throws SQLException {
// 占位符?来代替需要设置的参数
String sql = "insert into " + TABLENAME
+ "(name,subject,score) values(?,?,?)";
PreparedStatement ps = conn.prepareStatement(sql);
// 必须给定?所代表的值
ps.setString(1, score.getName());
ps.setString(2, score.getSubject());
ps.setDouble(3, score.getScore());
// 调用无参的方法
int row = ps.executeUpdate();
if (row > 0)
return true;
return false;
}
public static boolean deleteScore(Connection conn, Score score)
throws SQLException {
String sql = "delete from " + TABLENAME + " where name=? and subject=?";
// 创建PrepareStatement
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, score.getName());
ps.setString(2, score.getSubject());
// ps.setDouble(3, score.getScore());
// 执行
int row = ps.executeUpdate();
System.out.println(row);
if (row > 0)
return true;
return false;
}
public static boolean updateScore(Connection conn, Score score)
throws SQLException {
// 修改 score人他的科目的成绩
String sql = "update " + TABLENAME
+ " set score=? where name=? and subject=?";
PreparedStatement ps = conn.prepareStatement(sql);
ps.setDouble(1, score.getScore());
ps.setString(2, score.getName());
ps.setString(3, score.getSubject());
int row = ps.executeUpdate();
System.out.println(row);
if (row > 0)
return true;
return false;
}
public static List<Score> queryAllScore(Connection conn)
throws SQLException {
String sql = "select * from " + TABLENAME;
// 开始查询
Statement st = conn.createStatement();
ResultSet rs = st.executeQuery(sql);
List<Score> list = new ArrayList<Score>();
while (rs.next()) {
// 这里可以通过rs获取所有结果
String id = rs.getString("id");
String name = rs.getString("name");
String subject = rs.getString("subject");
double score = rs.getDouble("score");
list.add(new Score(name, id, subject, score));
}
// 结束
return list;
}
public static List<Score> queryScoreByName(Connection conn, String name)
throws SQLException {
String sql = "select * from " + TABLENAME + " where name=?";
PreparedStatement pt = conn.prepareStatement(sql);
pt.setString(1, name);
ResultSet rs = pt.executeQuery();
List<Score> list = new ArrayList<>();
while (rs.next()) {
String subject = rs.getString("subject");
String id = rs.getString("id");
double score = rs.getDouble("score");
list.add(new Score(name, id, subject, score));
}
return list;
}
# java
# jdbc
# jdbc详解及实例
# jdbc实例代码
# Java多线程编程之使用Exchanger数据交换实例
# Java利用剪贴板实现交换程序间数据的方法
# java常见的字符串操作和日期操作汇总
# 浅谈java中的对象、类、与方法的重载
# Java删除文件、目录及目录下所有文件的方法实例
# Java利用正则表达式提取数据的方法
# Java 定时器(Timer)及线程池里使用定时器实例代码
# java 内部类(匿名类
# 匿名对象
# 静态内部类)详解及实例
# java 线程锁详细介绍及实例代码
# Java 实现汉字转换为拼音的实例
# java 交换两个数据的方法实例详解
# 可以通过
# 加载
# 是一个
# 上了
# 来代替
# 可以使用
# 能做
# 每一位
# 李四
# 连接数据库
# 王五
# 是表名
# createStatemant
# DriverManager
# getConnection
# int
# SQL
# Statemant
# conn
# close
相关文章:
购物网站制作公司有哪些,哪个购物网站比较好?
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
图册素材网站设计制作软件,图册的导出方式有几种?
如何快速查询网站的真实建站时间?
如何选择服务器才能高效搭建专属网站?
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
免费网站制作appp,免费制作app哪个平台好?
广州商城建站系统开发成本与周期如何控制?
高防服务器租用指南:配置选择与快速部署攻略
C#如何序列化对象为XML XmlSerializer用法
制作网站的模板软件,网站怎么建设?
如何用已有域名快速搭建网站?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
建站DNS解析失败?如何正确配置域名服务器?
济南企业网站制作公司,济南社保单位网上缴费步骤?
如何使用Golang安装API文档生成工具_快速生成接口文档
如何快速搭建高效可靠的建站解决方案?
建站之星如何助力网站排名飙升?揭秘高效技巧
如何通过可视化优化提升建站效果?
如何选择域名并搭建高效网站?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
如何在阿里云完成域名注册与建站?
如何在IIS中配置站点IP、端口及主机头?
制作门户网站的参考文献在哪,小说网站怎么建立?
如何基于云服务器快速搭建网站及云盘系统?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
制作表格网站有哪些,线上表格怎么弄?
中山网站制作网页,中山新生登记系统登记流程?
Python如何创建带属性的XML节点
常州自助建站工具推荐:低成本搭建与模板选择技巧
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
建站之星如何快速生成多端适配网站?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
如何通过宝塔面板实现本地网站访问?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
如何用wdcp快速搭建高效网站?
山东云建站价格为何差异显著?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
如何高效利用200m空间完成建站?
网站图片在线制作软件,怎么在图片上做链接?
微信小程序 五星评分(包括半颗星评分)实例代码
c++ stringstream用法详解_c++字符串与数字转换利器
建站之星收费标准详解:套餐费用及年费价格表一览
简单实现Android验证码
如何在Tomcat中配置并部署网站项目?
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
*请认真填写需求信息,我们会在24小时内与您取得联系。