accp8.0转换教材第6章连接MySQL理解与练习
JDBC_ODBC,纯java方式连接mysql
1.单词部分
①JDBCjava连接数据库②driver manager驱动③connection连接④statement声明
⑤execute执行⑥query查询⑦result set结果集⑧connectivity连通⑨access存取使用
entity实体
二.预习部分
1.jdbc的主要作用是什么
连接数据库
2.jdbc两种常用的驱动方式
桥连接和纯java连接
3.什么是持久化
将程序中数据在瞬时状态转换为永久状态的操作
4.什么是dao模式该模式的优点有哪些
在我的理解中dao不是一种开发模式 最多也就算一个
数据操作层吧 书上的是通过对业务层提供数据抽象层接口
有利于开发人员分层开发,降低代码的耦合性,进行数据持久化操作
5.java的properties位于哪个包,派生自哪个类
java.until; hashtable类
三.练习部分
1.使用纯java方式连接数据库,并进行异常处理(mysql-connector-java-5.1.0-bin.jar)首先要导包
直接测试类就行了
package workOne;
import java.sql.Connection;
import java.sql.DriverManager;
public class test {
/**
* @param args
*/
//private static Logger logger=Logger.getLogger(test.class.getName());
public static void main(String[] args) {
// TODO Auto-generated method stub
Connection conn=null;
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (Exception e) {
// TODO: handle exception
//logger.error(e);
e.printStackTrace();
}
try {
conn=DriverManager.getConnection(
"jdbc:mysql://localhost:3306/epet","root","123"
);
System.out.println("建立连接成功!");
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
finally{
try {
if(null!=conn){
conn.close();
System.out.println("关闭连接成功!");
}
} catch (Exception e2) {
// TODO: handle exception
e2.printStackTrace();
}
}
}
}
2.实现宠物主人登录的数据访问
首先要创建dao包(basedao和masterdao类):
package Dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class BaseDao {
private String driver="com.mysql.jdbc.Driver";
private String url="jdbc:mysql://localhost:3306/epet";
private String user="root";
private String pass="123";
PreparedStatement pstmt=null;
ResultSet resultSet=null;
Connection conn=null;
//获取连接
public Connection getConnection() {
if(conn==null){
try {
Class.forName(driver);
conn=DriverManager.getConnection(url,user,pass);
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
return conn;
}
public void closeConn(Connection con,Statement stmt,ResultSet rs) {
if(rs!=null){
try {
rs.close();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
if(stmt!=null){
try {
stmt.close();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
if(conn!=null){
try {
conn.close();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}
}
public int DoUpdate(String sql,Object[]param) {
int num=0;
conn=getConnection();
try {
pstmt=conn.prepareStatement(sql);
if(param!=null){
for (int i = 0; i < param.length; i++) {
pstmt.setObject(i+1, param[i]);
}
}
num=pstmt.executeUpdate();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
finally{
closeConn(conn, pstmt, null);
}
return num;
}
public ResultSet DoQuery(String sql,Object [] para) {
conn=getConnection();
try {
pstmt=conn.prepareStatement(sql);
if(para!=null){
for (int i = 0; i < para.length; i++) {
pstmt.setObject(i+1,para[i]);
}
}
resultSet=pstmt.executeQuery();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return resultSet;
}
}
//master dao
package Dao;
import entity.master;
public interface masterDao {
boolean findMaster(master mas);
}
//再创建daoimpl包dao的实现类
package daoImpl;
import java.sql.ResultSet;
import java.sql.SQLException;
import entity.master;
import Dao.BaseDao;
import Dao.masterDao;
public class masterDaoImpl extends BaseDao implements masterDao{
public boolean findMaster(master mas) {
// TODO Auto-generated method stub
String sql="SELECT * FROM `master` WHERE `name`=? AND `password`=?";
Object[]para={mas.getName(),mas.getPass()};
ResultSet rs=DoQuery(sql, para);
boolean flag=false;
//.masterDaoImpl//master ma=new master();
try {
while (rs.next()) {
flag=true;
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return flag;
}
}
//创建三个实体类主人类 宠物种类类 宠物类
//master
package entity;
public class master {
private int id;
private String name;
private int pass;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getPass() {
return pass;
}
public void setPass(int pass) {
this.pass = pass;
}
}
//pet_type宠物种类
package entity;
public class pet_type {
private int id;
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
//宠物类pet
package entity;
public class pet {
private int id;
private int master_id;
private String name;
private int type_id;
private int health;
private int love;
private String adop_time;
private int status;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getMaster_id() {
return master_id;
}
public void setMaster_id(int master_id) {
this.master_id = master_id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getType_id() {
return type_id;
}
public void setType_id(int type_id) {
this.type_id = type_id;
}
public int getHealth() {
return health;
}
public void setHealth(int health) {
this.health = health;
}
public int getLove() {
return love;
}
public void setLove(int love) {
this.love = love;
}
public String getAdop_time() {
return adop_time;
}
public void setAdop_time(String adop_time) {
this.adop_time = adop_time;
}
public int getStatus() {
return status;
}
public void setStatus(int status) {
this.status = status;
}
}
//创建test包main接口
package test;
import java.util.Scanner;
import daoImpl.masterDaoImpl;
import Dao.masterDao;
import entity.master;
public class test {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input=new Scanner(System.in);
System.out.println("-------欢迎光临宠物乐园-------");
System.out.println("请输入登陆名:");
String loginid=input.next();
System.out.println("请输入密码:");
int loginpass=input.nextInt();
master mas=new master();
mas.setName(loginid);
mas.setPass(loginpass);
masterDao masterDao=new masterDaoImpl();
boolean res = masterDao.findMaster(mas);
if(res){
System.out.println("登陆成功!");
}
else{
System.out.println("登录失败!");
}
}
}
3.实现宠物主人登录业务
在第二个练习已经做了第三个
总结:
1.由sun公司提供jdbc的接口规范 jdbc-api 数据库厂商或第三方提供针对 不同数据库的具体实现,这就是jdbc驱动
2.jdbc访问数据库的步骤首先加载驱动,与数据库取得联系,再创建statement或preparedstatement对象,再发送sql语句,并取得返回结果,最后处理
3.preparedstatement接口继承自statement接口。提高代码的可读姓和可维护性,sql语句的执行性能和安全性
4.dao全称data access objects(数据存取对象)
欢迎提问,欢迎指错,欢迎讨论学习信息 有需要的私聊 发布评论即可 都能回复的
原文在博客园http://www.cnblogs.com/a782126844/有需要可以联系扣扣:2265682997
accp8.0转换教材第6章连接MySQL理解与练习的更多相关文章
- accp8.0转换教材第2章初识MySQL
首先安装MySQL: 一.单词部分: ①networking网络②option选择③port端口④firewall防火墙⑤engine引擎 ⑥standard标准⑦character字符⑧collat ...
- accp8.0转换教材第10章Ajax和jQuery理解与练习
C/S (Client/Server)结构,即大家熟知的客户机和服务器结构. B/S(Browser/Server)结构即浏览器和服务器结构. 认识ajax .XMLHttpRequest.使用jqu ...
- accp8.0转换教材第4章MySQL高级查询(二)理解与练习
知识点:EXISTS子查询.NOT EXISTS子查询.分页查询.UNION联合查询 一.单词部分 ①exist存在②temp临时的③district区域 ④content内容⑤temporary暂时 ...
- accp8.0转换教材第11章JAjax加护扩展理解与练习
①杂记:前面有原生态JavaScript实现ajax这里又多了更简单的方法实现ajax ②$.get()方法的常用参数 参数 类型 说明 url String 必选,规定发送地址 data Plain ...
- accp8.0转换教材第3章MySQL高级查询(一)理解与练习
一.单词部分 ①constraint约束②foreign外键③references参考 ④subquery子查询⑤inner内部的⑥join连接 二.预习部分 1.修改表SQL语句的关键字是什么 RE ...
- accp8.0转换教材第1章多线程理解与练习
一.单词部分: ①process进程 ②current当前的③thread线程④runnable可获取的 ⑤interrupt中断⑥join加入⑦yield产生⑧synchronize同时发生 二.预 ...
- accp8.0转换教材第9章JQuery相关知识理解与练习
自定义动画 一.单词部分: ①animate动画②remove移除③validity有效性 ④required匹配⑤pattern模式 二.预习部分 1.简述JavaScript事件和jquery事件 ...
- accp8.0转换教材第8章JavaScript对象及初识面向对象理解与练习
JavaScript数据类型,对象,构造函数,原型对象,初识原型链,对象继承 一.单词部分 ①object父类②constructor构造函数③instance实例④call调用 ⑤apply应用⑥c ...
- accp8.0转换教材第7章JavaScript操作DOM对象理解与练习
程序调试,chrome开发人员工具,DOM操作,节点和节点间的关系,节点信息,操作节点,获取元素 一.单词部分 ①alert警告②prompt提示③parentNode父节点④childNode子节点 ...
随机推荐
- MYBATIS 简单整理与回顾
这两天简单整理了一下MyBatis 相关api和jar包这里提供一个下载地址,免得找了 链接:http://pan.baidu.com/s/1jIl1KaE 密码:d2yl A.简单搭建跑项目 2.进 ...
- xml 和html 语言区别
都是标记语言(ML),一个是超文本标记语言,一个是扩展标记语言. 不同之处: 1可扩展性:HTML不具备扩展性,而XML是原标记语言,可以用于定义新的标记语言. 2侧重点: HTML侧重于如何表现信息 ...
- MyBatis 3 User Guide Simplified Chinese.pdf
MyBatis 3 用户指南 帮助我们把文档做得更好… 如果你发现了本文档的遗漏之处,或者丢失 MyBatis 特性的说明时,那么最好的方法就 是了解一下这个遗漏之处然后把它记录下来. 我们在 wik ...
- 模拟实现简化版List迭代器&嵌入List
1.迭代器(iterators)概念(1)迭代器是一种抽象的设计概念,其定义为:提供一种方法,使他能够按顺序遍历某个聚合体(容器)所包含的所有元素,但又不需要暴露该容器的内部表现方式. (2)迭代器是 ...
- python3 爬 妹子图
Beautiful Soup 是一个可以从HTML或XML文件中提取数据的Python库.它能够通过你喜欢的转换器实现惯用的文档导航,查找,修改文档的方式 Beautiful Soup 4 通过PyP ...
- R语言的高质量图形渲染库Cairo(转)
前言 R语言不仅在统计分析,数据挖掘领域,计算能力强大.在数据可视化上,也不逊于昂贵的商业.当然,背后离不开各种开源软件包的支持,Cairo就是这样一个用于矢量图形处理的类库. Cairo可以创建高质 ...
- 实现分布式队列ZooKeeper的实现
一.背景 有一些时候,多个团队需要共同完成一个任务,比如,A团队将Hadoop集群计算的结果交给B团队继续计算,B完成了自己任务再交给C团队继续做.这就有点像业务系统的工作流一样,一环一环地传下去,直 ...
- R中用黏贴板读取excel数据以及用R生成人名
本人尚在超级菜鸟级别,中间有些代码写的很low,请不要见笑! 1.今天先跟大家分享一个小技巧,用黏贴板将excel中的数据读进R 首先选中要读入R的数据 如图,上面是我分析的病人相关资料,Ctrol+ ...
- 这是假的JS——利用CSS Animation实现banner图非交互循环播放
话不多说,先来张html和css代码截图~ 注意事项: 1.如果想在每张图前进行停顿,可以在keyframes中的每一步前加上一小段与下一张相同的代码: 2.如果想要在实现无违和感的最后一张与第一张的 ...
- Spring MVC 学习笔记一 HelloWorld
Spring MVC 学习笔记一 HelloWorld Spring MVC 的使用可以按照以下步骤进行(使用Eclipse): 加入JAR包 在web.xml中配置DispatcherServlet ...