`

实例:简单的JDBC复习+MySql入门学习

阅读更多

万变不离其宗。。持久层怎么变也是JDBC,框架怎么新也是反射机制。。

 

今天刚好复习一下JDBC,顺便对MySql进行一个入门的学习。

 

环境:MySql 5.5 + Navicat for MySql 10.0.5 + MyEclipse 9.0

 

从MySql官方:http://www.mysql.com/ 下载了 mysql-connector-java-5.1.17-bin.jar

 

从MyEclipse的DB Browser中得到测试成功后的

 

驱动类:com.mysql.jdbc.Driver

链接URL:jdbc:mysql://localhost:3306/accp

 

准备的差不多了,实例就是 简单粗暴,直接有效 直接上代码。。

 

---------------------------------------我是华丽的无所不在的分割线-------------------------------------------

 

 

用户实体类:

package com.accp.jdbc.entity;

/**
 * 
 * @author Maxpin on 2011-10-04
 * 
 *         用户实体类
 */
public class Userinfo {
	private int userid; // 编号
	private String loginid; // 用户名
	private String loginpwd; // 密码
	private String username; // 姓名

	/**
	 * 构造方法
	 */
	public Userinfo() {
	}

	/**
	 * @param loginid
	 * @param loginpwd
	 * @param username
	 */
	public Userinfo(String loginid, String loginpwd, String username) {
		this.loginid = loginid;
		this.loginpwd = loginpwd;
		this.username = username;
	}

	/**
	 * @param userid
	 * @param loginid
	 * @param loginpwd
	 * @param username
	 */
	public Userinfo(int userid, String loginid, String loginpwd, String username) {
		this.userid = userid;
		this.loginid = loginid;
		this.loginpwd = loginpwd;
		this.username = username;
	}

	//getter & setter methods 略 

 

 

Dao基类:包含了数据库链接、关闭、CRUD操作及MySql分页查询

package com.accp.jdbc.base;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import com.accp.jdbc.entity.Userinfo;

/**
 * 
 * @author Maxpin on 2011-10-04
 * 
 *         Dao基类:包含了数据库链接、关闭、CRUD操作及MySql分页查询
 */
public class BaseDao {

	// 连接地址
	private static final String url = "jdbc:mysql://localhost:3306/accp";
	// 驱动类
	private static final String driverClass = "com.mysql.jdbc.Driver";
	// 用户名
	private static final String uname = "root";
	// 密码
	private static final String pwd = "admin";

	/**
	 * 获取数据库连接
	 * 
	 * @return 连接对象
	 */
	protected static Connection getConnection() {
		Connection conn = null;
		try {
			Class.forName(driverClass);
			conn = DriverManager.getConnection(url, uname, pwd);
		} catch (ClassNotFoundException e) {
			System.out.println("找不到驱动类");
		} catch (SQLException e) {
			System.out.println("建立连接错误!");
		}
		return conn;
	}

	/**
	 * 关闭数据库连接
	 * 
	 * @param conn
	 *            数据库连接
	 * @param rs
	 *            结果集
	 * @param pstmt
	 *            命令对象
	 */
	public static void closeAll(Connection conn, ResultSet rs, Statement pstmt) {
		try {
			if (null != rs && !rs.isClosed()) {
				rs.close();
				rs = null;
			}
		} catch (SQLException e) {
			System.out.println("关闭结果集出错!");
		}
		try {
			if (null != pstmt && !pstmt.isClosed()) {
				pstmt.close();
				pstmt = null;
			}
		} catch (SQLException e) {
			System.out.println("关闭命令对象出错!");
		}
		try {
			if (null != conn && !conn.isClosed()) {
				conn.close();
				conn = null;
			}
		} catch (SQLException e) {
			System.out.println("关闭链接出错");
		}
	}

	/**
	 * 保存指定用户信息
	 * 
	 * @param user
	 *            用户对象
	 * @throws Exception
	 *             抛出异常
	 */
	public static void saveUserinfo(Userinfo user) throws Exception {
		if (null != user) {
			Connection conn = getConnection();
			PreparedStatement pstmt = null;
			String sql = "insert into USERINFO values(null,?,?,?)";
			try {
				pstmt = conn.prepareStatement(sql);
				pstmt.setString(1, user.getLoginid());
				pstmt.setString(2, user.getLoginpwd());
				pstmt.setString(3, user.getUsername());
				pstmt.executeUpdate();
			} catch (SQLException e) {
				e.printStackTrace();
			} finally {
				closeAll(conn, null, pstmt);
			}
		} else {
			throw new Exception("用户信息不能为空");
		}
	}

	/**
	 * 删除指定用户信息
	 * 
	 * @param user
	 *            用户对象
	 * @throws Exception
	 *             抛出异常
	 */
	public static void deleteUserinfo(Userinfo user) throws Exception {
		if (null != user) {
			Connection conn = getConnection();
			PreparedStatement pstmt = null;
			String sql = "delete from USERINFO where userid = ?";
			try {
				pstmt = conn.prepareStatement(sql);
				pstmt.setInt(1, user.getUserid());
				pstmt.executeUpdate();
			} catch (SQLException e) {
				e.printStackTrace();
			} finally {
				closeAll(conn, null, pstmt);
			}
		} else {
			throw new Exception("用户信息不能为空");
		}
	}

	/**
	 * 更新指定用户信息
	 * 
	 * @param user
	 *            用户对象
	 * @throws Exception
	 *             抛出异常
	 */
	public static void updateUserinfo(Userinfo user) throws Exception {
		if (null != user) {
			Connection conn = getConnection();
			PreparedStatement pstmt = null;
			String sql = "update USERINFO set loginid = ?,loginpwd = ?,username = ? where userid = ?";
			try {
				pstmt = conn.prepareStatement(sql);
				pstmt.setString(1, user.getLoginid());
				pstmt.setString(2, user.getLoginpwd());
				pstmt.setString(3, user.getUsername());
				pstmt.setInt(4, user.getUserid());
				pstmt.executeUpdate();
			} catch (SQLException e) {
				e.printStackTrace();
			} finally {
				closeAll(conn, null, pstmt);
			}
		} else {
			throw new Exception("用户信息不能为空");
		}
	}

	/**
	 * 查询指定用户信息
	 * 
	 * @param id
	 *            用户编号
	 * @return 用户对象
	 * @throws Exception
	 *             抛出异常
	 */
	public static Userinfo queryUserinfo(int id) throws Exception {
		Userinfo user = null;
		Connection conn = getConnection();
		PreparedStatement pstmt = null;
		ResultSet rs = null;
		String sql = "select * from USERINFO where userid = ?";
		try {
			pstmt = conn.prepareStatement(sql);
			pstmt.setInt(1, id);
			rs = pstmt.executeQuery();
			if (rs.next()) {
				user = new Userinfo(id, rs.getString(2), rs.getString(3),
						rs.getString(4));
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			closeAll(conn, rs, pstmt);
		}
		return user;
	}

	/**
	 * 分页查询用户信息列表
	 * 
	 * @param currentPage
	 *            要查询页码
	 * @param pageSize
	 *            每页显示条数
	 * @return 用户对象集合
	 * @throws Exception
	 *             抛出异常
	 */
	public static List<Userinfo> queryUserinfoList(int currentPage, int pageSize)
			throws Exception {
		// 计算当前页索引
		int pageIndex = (currentPage - 1) * pageSize;
		List<Userinfo> userList = new ArrayList<Userinfo>();
		Connection conn = getConnection();
		PreparedStatement pstmt = null;
		ResultSet rs = null;
		// MySql分页可使用limit关键字:select * from tableName limit pageIndex,pageSize
		String sql = "select * from USERINFO limit ?,?";
		try {
			pstmt = conn.prepareStatement(sql);
			pstmt.setInt(1, pageIndex);
			pstmt.setInt(2, pageSize);
			rs = pstmt.executeQuery();
			while (rs.next()) {
				userList.add(new Userinfo(rs.getInt(1), rs.getString(2), rs
						.getString(3), rs.getString(4)));
			}
		} catch (SQLException e) {
			e.printStackTrace();
		} finally {
			closeAll(conn, rs, pstmt);
		}
		return userList;
	}

}

 

 

测试类:

 

package com.accp.jdbc.test;

import java.util.List;

import com.accp.jdbc.base.BaseDao;
import com.accp.jdbc.entity.Userinfo;

/**
 * 
 * @author Maxpin on 2011-10-04
 * 
 *         测试类
 */
public class Test {

	public static void main(String[] args) {
		try {
			
			/*
			 * MySql中的初始数据:(编号、用户名、密码、姓名)
			 * 1 admin 		123123 	管理员
			 * 2 zhangsan 	123123 	张三
			 * 3 lisi 		123123 	李四
			 * 4 wangwu 	123123	 王五
			 * 
			 */
			
			// 测试保存:赵六
			BaseDao.saveUserinfo(new Userinfo("zhaoliu", "123123", "赵六"));
			// 测试更新:赵六
			BaseDao.updateUserinfo(new Userinfo(5, "zhaoliu", "321321", "赵六2"));
			// 测试删除:王五
			BaseDao.deleteUserinfo(new Userinfo(4, null, null, null));
			// 测试查询:管理员
			Userinfo user = BaseDao.queryUserinfo(1);
			System.out.println(user.getUserid() + " " + user.getLoginid() + " "
					+ user.getLoginpwd() + " " + user.getUsername());
			// 测试分页:查询第2页,每页2条。王五已被删除。
			List<Userinfo> userList = BaseDao.queryUserinfoList(2, 2);
			for (Userinfo u : userList) {
				System.out.println(u.getUserid() + " " + u.getLoginid() + " "
						+ u.getLoginpwd() + " " + u.getUsername());
			}
		} catch (Exception e) {
			System.out.println(e.getMessage());
		}
	}

}

 

---------------------------------------我是华丽的无所不在的分割线-------------------------------------------

 

MySql给我的感觉还可以,就是在安装完成后要配置一下my.ini

好在5.5提供了MySQLInstanceConfig.exe可以很方便的进行配置操作。

操作步骤我是参照的 http://www.duote.com/tech/1/2430.html#contentbody 

 

另外:

 

MySql自增列的关键字是:AUTO_INCREMENT

插入数据时,可以选择对该列赋值为 null 即可。

 

MySql分页可使用limit关键字:select * from tableName limit pageIndex,pageSize

分享到:
评论

相关推荐

    燕十八mysql入门.zip

    【燕十八mysql入门.zip】这个压缩包文件是一个针对MySQL数据库管理系统的基础学习资源,由知名教育者燕十八提供。燕十八以其通俗易懂的教学风格在IT教育领域颇受欢迎,他的资料通常深入浅出,适合初学者入门。这个...

    PHP和MySQL Web开发

    - **实例丰富**:“书中的示例非常实用,帮助我快速掌握了如何将理论知识应用于实际项目中。” - **内容全面**:“除了介绍基本语法外,还涵盖了高级主题,如数据库安全、性能优化等。” - **结构清晰**:“章节编排...

    Java全套视频教程900集(java入门到精通)

    Java编程语言是软件开发领域中最广泛使用的编程语言之一,...同时,配合"Java全套视频教程900集(java入门到精通).txt"文本资料,可以更系统地学习和复习所学内容,确保理论与实践相结合,成为一名熟练的Java程序员。

    Java JDK 7学习笔记(国内第一本Java 7,前期版本累计销量5万册)

    基本信息 作者: 林信良 丛书名: 学习笔记 出版社:清华大学出版社 ...appendixb mysql入门 557 b.1 安装、设定mysql 558 b.2 mysql的数据类型 560 b.3 建立数据库、数据表 561 b.4 进行crud操作 562

    PHP从入门到精通(第三版)

    11. 应用实战:通过实例项目演示如何将所学知识应用于实际开发,可能包括搭建一个简单的博客系统或者用户管理系统。 作为一本课件,它还可能包含配套的PPT文件,这些PPT通常会以图文并茂的方式展示核心概念,辅助...

    《PHP从入门到精通(第7版)》附属资料

    它们通常包含每章节的重点内容、实例分析和练习题,有助于巩固理论知识,并引导学习者进行自我检测和复习。PPT课件的结构化特点使其成为整理学习笔记、准备考试或快速回顾的重要参考资料。 程序源码部分是实践环节...

    PHP从入门到精通(第5版)第9章 PPT.zip

    在本资源中,"PHP从入门到精通(第5版)第9章 PPT.zip" 包含了关于PHP编程语言深入学习的材料,特别是针对第9章的内容。PHP是一种广泛使用的开源脚本语言,主要应用于Web开发,可以嵌入到HTML中执行,以创建动态交互...

    多个Java编程实例与应用场景

    内容主要分为以下几个部分: 首先是简单入门程序'Hello World';接着介绍面向对象的编程技巧,如定义类、属性设定、方法调用以及子类的继承等;并解释了通过接口实现行为共享的编码规范;此外,还展示了异常捕获处理...

    技术图书。001需要的不多。。技术图书。

    然后根据自己所处的学习阶段(入门、进阶或高级)来挑选合适的书籍。 2. **作者背景**:了解作者的背景对于评估书籍质量非常重要。一般而言,有多年实践经验的专家撰写的技术图书更值得信赖。 3. **评价和反馈**:...

    20170909学习sql笔记

    总的来说,这个学习资料将为初学者提供一个全面的SQL入门指南,同时也对有一定经验的开发者进行复习和巩固。通过实际操作和理解这些概念,读者将能够有效地管理和操作数据库,提高其在数据分析和业务处理方面的技能...

    java学习资料总结2015新

    - **Java基础知识笔记总结** 是一套全面覆盖 Java 基础知识点的学习资料,非常适合用于系统复习和备考。 - **html、css、javascript、servlet、jsp** 等 Web 开发相关的视频资料也非常重要,这些是构建现代 Web ...

    【数据库原理与应用】课程资料.zip

    6. 自学教材、讲义和笔记:这些材料可能是教师的授课笔记,或者是学生的学习心得,包含了深入的解释和实例,对于自主学习非常有帮助。 学习数据库原理与应用,不仅需要理解数据库的设计思想,还要熟练掌握SQL语言,...

    零基础织梦仿站系列教程百度云盘下载

    3. **织梦实站仿制政府网系列课程**:共17节高清视频,通过实例项目来教授如何具体操作仿制政府类网站的方法。 #### 四、教程核心知识点详解 ##### 4.1 零基础织梦仿站系列教程 - **4.1.1 织梦CMS安装部署** - ...

    Java Web 实训2012-12-9.ppt

    1. **开发环境**:使用JDK 1.6进行编译和解释,MyEclipse作为集成开发工具,Tomcat 6作为JSP/Servlet容器,MySQL 5.1作为数据库服务器,同时需要MySQL的JDBC驱动和Navicat Lite作为数据库管理工具。 2. **MyEclipse...

    python入门到高级全栈工程师培训 第3期 附课件代码

    python入门到高级全栈工程师培训视频学习资料;本资料仅用于学习,请查看后24小时之内删除。 【课程内容】 第1章 01 计算机发展史 02 计算机系统 03 小结 04 数据的概念 05 进制转换 06 原码补码反码 07 物理层和...

    java-start-learning-.rar_Java Servlet JSP

    "servlet和jsp知识复习"可能包含了JSP生命周期、隐含对象和EL(Expression Language)的复习内容,这些都是学习JSP的基础。 Tomcat是Apache软件基金会的开源Java Servlet容器,它实现了Java EE的Web部分,特别是...

    【北大青鸟】第一年 下半学期课程【下载地址】.zip

    在本课程中,可能会涉及关系型数据库管理系统,如MySQL或SQL Server,学习如何创建数据库、表,执行CRUD操作(创建、读取、更新、删除),以及使用索引、视图、存储过程等高级特性。理解数据库设计和优化对于任何...

    Web开发资料.zip

    这样的教材对于系统学习Web开发至关重要,因为它提供了全面的概念解释和实例解析。 再者,第三个文件《Web开发基础》复习大纲(2020).pdf,这通常是对整个课程内容的总结,列出了关键概念和知识点,是复习和准备...

Global site tag (gtag.js) - Google Analytics