所用的IDE为idea,数据库用的是Navicat for MySQL

好了,开始正题,今天要做person小项目,有以下几个步骤:

  • Navicat for MySQL数据库的构建,以及如何建person表
  • 在idea中导入mysql-connector-java-5.0.8-bin.jar包
  • 创建person小项目的目录
  • 具体代码的书写

第一步,Navicat for MySQL数据库的构建,以及如何person建表

Navicat for MySQL是一套管理和开发MySQL或MariaDB的理想解决方案,支持单一程序,可同时连接到MySQL和MariaDB。这个功能齐备的前端软件为数据库管理、开发和维护提供了直观而强大的图形界面,给MySQL或MariaDB新手以及专业人士提供了一组全面的工具。 —— [ 百度百科 ]

界面如图

 
其中,information_schema,mysql,performance_schema,test这四个数据库是这个软件自带的,我新建了两个数据库,命名规则是“db_object”.

新建person表,字段:id,name,age,description(注意数据类型及是否空值) 
 
必须要强调一下,主键这个东西,因为这个吃了好多亏,出现了各种bug。。 
主键:确定一个字段的唯一标识,一般都设置ID为主键,而且要设置自动递增。(被设置成主键的字段,务必是唯一标识

很搞笑的一点,不管是int型,还是varchar型,长度就是最普通的长度(不用转换成二进制什么的),比如说:varchar的长度是6,那么“小旺财666”就是长度6,即为数据的最大值


第二步,在idea中导入mysql-connector-java-5.0.8-bin.jar包

 
首先要在WEB-INF文件夹新建一个lib文件夹,把相应的jar包拖动到WEB-INF文件夹中,然后鼠标右键选择Add as Library,经过一系列的OK之后,就可以用这个jar包了。


第三步,创建person小项目的目录

 
注意在src中创建文件夹的时候,它可能有点怕生,要和之前的com.test黏在一起,这时候就可以选择Excluded(排斥的)把它们拆散。 
 
如图,dao文件夹是红色的,不能在里面创建Java.class。这时候呢,老套路,Mark Directory As(把目录变为) Cancel Excluded(取消排斥) 
 
依次创建com.test父目录,以及其下的三个子目录dao,entity,test。

-dao目录(Data Access Object), 数据访问对象是第一个面向对象的数据库接口 
-entity目录(实体),实体就是一个特定的软件模块。 
-test目录,最终的试行测试


第四步,具体代码的书写

-PersonDao文件

public class Persondao {
private final static String DRIVER ="com.mysql.jdbc.Driver";
private final static String URL = "jdbc:mysql://localhost:3306/db_person";
private final static String USERNAME = "root";
private final static String PASSWORD = "root";

首先,你必须定义4个私有的静态全局变量。

/**
*添加一个人
* @param person
* @return boolean
*/
public static boolean insert(Person person) {
boolean flag = false;//
try {
Class.forName(DRIVER);//加载数据库驱动
Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
/*
使用jar包中的connection接口,并通过DriveManager类的静态方法getConnection()创建连接对象conn
*/
String sql = "INSERT INTO t_person(name,age,description) VALUES(?,?,?)";//编写sql语句
PreparedStatement ps = conn.prepareStatement(sql);////创建预处理对象ps
ps.setString(1, person.getName());
ps.setInt(2, person.getAge());
ps.setString(3, person.getDescription());
if (ps.executeUpdate() > 0) {
flag = true;
}
ps.close();
conn.close(); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return flag;
}

注意,ps.setString(1,per.getName)这个必须严格按照顺序来,1,2,3在你建好的t_person表中,对应的就是name,age,description


 /**
* 删除一个人
* @param id
* @return
*/
public static boolean delete(int id){
boolean flag = false;
try{
Class.forName(DRIVER);//加载数据库驱动
Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);//建立数据库连接
String sql = "DELETE FROM t_person WHERE id="+id;//编写sql语句
PreparedStatement ps = conn.prepareStatement(sql);//sql执行语句
if(ps.executeUpdate() > 0) {
flag = true;
}
ps.close();
conn.close(); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return flag;
}

 /**
* 根据ID改变一个人
* @param id
* @return
*/
public static boolean update(Person person,int id){
boolean flag = false;
try{
Class.forName(DRIVER);//加载数据库驱动
Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);//连接数据库
String sql = "UPDATE t_person SET name=?,age=?,description=? WHERE id= "+id;//编写sql语句
PreparedStatement ps = conn.prepareStatement(sql);//sql执行语句
ps.setString(1,person.getName());
ps.setInt(2,person.getAge());
ps.setString(3,person.getDescription());
if(ps.executeUpdate() > 0) {
flag = true;
}
ps.close();
conn.close(); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return flag;
}

/**
*根据ID查找一个人
* @param id
* @return
*/
public static Person SelectById(int id){
Person person = null;
ResultSet rs = null;
try{
Class.forName(DRIVER);//加载数据库驱动
Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);//数据库连接
String sql = "SELECT * FROM t_person WHERE id="+id;//编写sql语句
PreparedStatement ps = conn.prepareStatement(sql);//sql执行语句
rs = ps.executeQuery();//在PrepareStatement对象中执行SQL查询,并返回该查询生成的ResultSet对象
while (rs.next())//若当前语句不是最后一行,则执行循环
{
/*
ResultSet实例具有指向当前数据行的指针,指针开始的位置在第一条记录的前面,通过next()方法可将指针下移
*/
person = new Person();
person.setId(rs.getInt("id"));
person.setName(rs.getString("name"));
person.setAge(rs.getInt("age"));
person.setDescription(rs.getString("description"));
}
ps.close();
conn.close(); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return person;
}

 /**
* 搜素所有的人
* @return
*/
public static List<Person> select(){
List<Person> list = new ArrayList<Person>();
ResultSet rs = null;
try{
Class.forName(DRIVER);//加载数据库驱动
Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);//数据库连接
String sql = "SELECT * FROM t_person";//编写sql语句
PreparedStatement ps = conn.prepareStatement(sql);//sql执行语句
rs = ps.executeQuery();
while (rs.next())
{
Person person = new Person();
person.setId(rs.getInt("id"));
person.setName(rs.getString("name"));
person.setAge(rs.getInt("age"));
person.setDescription(rs.getString("description"));
list.add(person);
}
ps.close();
conn.close(); } catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
return list;
}
}

-Person文件

public class Person {
private int id;//主键
private String name;//姓名
private int age;//年龄
private String description;//描述 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 getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public String getDescription() {
return description;
} public void setDescription(String description) {
this.description = description;
}

特别地,在根据ID查找一个人的时候

/**
* 需要把toString()方法重写。
* @return
*/
@Override
public String toString() {
return "Person{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
", description='" + description + '\'' +
'}';
}
}

-test

public class test {

    public static void main(String[] args){
// Person person = new Person();
// person.setAge(0);
// person.setName("吴晓阳");
// person.setDescription("是个傻逼");
// System.out.println(Persondao.insert(person));//增加一个人
// System.out.println(Persondao.delete(2));//删除一个人
// System.out.println(Persondao.update(person,4));
// Person person =Persondao.SelectById(4);
// System.out.println(person);
List<Person> list = Persondao.select();//查找列表
for(int i=0;i<list.size();i++){
System.out.println(list.get(i));
} }
}

MySql保留的关键字

 
 
请特别注意,在写sql语句的时候,之前在Navicat定义的字段名称不能与上述关键词相同,会报错的。。

person小项目的更多相关文章

  1. 用struts2标签如何从数据库获取数据并在查询页面显示。最近做一个小项目,需要用到struts2标签从数据库查询数据,并且用迭代器iterator标签在查询页面显示,可是一开始,怎么也获取不到数据,想了许久,最后发现,是自己少定义了一个变量,也就是var变量。

    最近做一个小项目,需要用到struts2标签从数据库查询数据,并且用迭代器iterator标签在查询页面显示,可是一开始,怎么也获取不到数据,想了许久,最后发现,是自己少定义了一个变量,也就是var变 ...

  2. IOS-小项目(饿了么 网络部分 简单实现)

    在介绍小项目之前,在此说明一下此代码并非本人所写,我只是随笔的整理者. 在介绍之前先展现一下效果图. 看过效果图大家应该很熟悉了,就是饿了么的一个界面而已,值得注意的是,实现时并没有采用本地连接,而是 ...

  3. Andriod小项目——在线音乐播放器

    转载自: http://blog.csdn.net/sunkes/article/details/51189189 Andriod小项目——在线音乐播放器 Android在线音乐播放器 从大一开始就已 ...

  4. 模拟XShell的小项目

    不知道大家有没有用过XShell这款工具,这款工具通过windows可以远程操作处于开机状态的linux操作系统,也就是说把你的电脑和一台服务器连入网络,你通过输入服务器所在的IP地址建立一个会话就可 ...

  5. 小项目特供 贪吃蛇游戏(基于C语言)

    C语言写贪吃蛇本来是打算去年暑假写的,结果因为ACM集训给耽搁了,因此借寒假的两天功夫写了这个贪吃蛇小项目,顺带把C语言重温了一次. 是发表博客的前一天开始写的,一共写了三个版本,第一天写了第一版,第 ...

  6. 【PHP小项目使用MVC架构】

    小项目名称是雇员管理系统. mvc是一种项目的开发模式,中文名称为模式视图控制器,是强制程序员将数据的输入.处理.输出分开的一种开发模式. 在这个小项目中,控制器使用service作为后缀名. 项目u ...

  7. MOGRE学习笔记(3)--MOGRE小项目练习

    学习OGRE有一段时间了,领导为了检测学习效果,根据已有C++项目,弄一个类似的用c#语言编写的小项目. 配置:win7,DirectX2009,vs2010. 项目要求: 1.有Ogre窗口(尺寸1 ...

  8. Web前端开发:SQL Jsp小项目(一)

    Jsp的学习算是告一段落,针对这段时间的学习,写了一个Jsp小项目来巩固学到的知识. 框架示意图 User list process UserAdd process 需要的界面效果: 需要工具:Ecl ...

  9. Ado.Net小练习02(小项目CUID

    前台界面: 后台代码: namespace ado.net小项目cuid {     public partial class Form1 : Form     {         //连接字符串   ...

  10. testservice小项目总结

    关于自做小项目testservice的总结: 1.Activity与Service的绑定及之间的通信: 1)关于Activity和Service的生命周期的理解: 2)bindService方法中Se ...

随机推荐

  1. .NET 海量数据处理,并处理事务问题

    1.下面是一个C#的控制台以代码来说明处理 using System.Data.SqlClient; class Program { static void Main() { string conne ...

  2. hdu5880 Family View

    地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=5880 题目: Family View Time Limit: 3000/1000 MS (Ja ...

  3. RedHot 不能联网 ifconfig命令只显示lo 不显示eth0的解决方法!

    1.修改eth0 具体步骤如下 vi /etc/sysconfig/network-scripts/ifcfg-eth0, i,进入insert编辑模式,具体参数设置如下: DEVICE=eth0 B ...

  4. C#反射——模仿ParameterInterceptor(ashx处理程序)

    反射工具类请参见:https://www.cnblogs.com/threadj/p/10535796.html using System; using System.Collections.Gene ...

  5. Tomcat java.lang.OutOfMemoryError: PermGen space error

    Often time, Tomcat may hits the following java.lang.OutOfMemoryError: PermGen space error. java.lang ...

  6. PhpStorm提高效率的使用方法及设置(快捷键)

    原文链接:https://my.oschina.net/chunto/blog/262954 快捷键: CTRL + D  复制当前行到下一行 或 复制选中内容到选中内容之后 CTRL + Y  删除 ...

  7. 【找不到符号】Maven打包找不到符号的问题排查

    当碰到maven错误:找不到符号问题时,通常第一反应应该是执行eclipse的Project -> Clean … -> Clean all projects,然后再执行maven cle ...

  8. 论文笔记——N2N Learning: Network to Network Compression via Policy Gradient Reinforcement Learning

    论文地址:https://arxiv.org/abs/1709.06030 1. 论文思想 利用强化学习,对网络进行裁剪,从Layer Removal和Layer Shrinkage两个维度进行裁剪. ...

  9. 关于JS和JSON

    讲得不准确! 看网课,JS也算是面向对象的一门语言,不过其是解释性的脚本语言. JSON是把用JS的表示法将数据包装起来进行传递用的. JS语法是松散型的,没有int String这些像JAVA里的类 ...

  10. Cuda 9.2 CuDnn7.0 官方文档解读

    目录 Cuda 9.2 CuDnn7.0 官方文档解读 准备工作(下载) 显卡驱动重装 CUDA安装 系统要求 处理之前安装的cuda文件 下载的deb安装过程 下载的runfile的安装过程 安装完 ...