用Java代码操作数据库,可以用JDBC。首先要加载驱动,之后建立连接,再然后就可以对数据库进行操作。

1.建立连接。此处用的是MySQL数据库

 public class DBUtil {

     public static String URL = "jdbc:mysql://localhost:3306/JDBCDEmo";
public static String USER = "root";
public static String PASSWORD = "abc123_"; private static Connection conn; static{
try {
//或得去驱动
Class.forName("com.mysql.jdbc.Driver");
//得到数据库的连接
conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} public static Connection getConnection(){
return conn;
} }

2. 建立连接以后,就可以用相应的方法就行CRUD了public class BoyDao {

public void addBoy(Boy by) {
      
//或得连接,编写sql语句,?号代表要插入额数据
Connection conn = DBUtil.getConnection();
String sql = "INSERT INTO Boy" + " (user_name, sex, age, birthday, email, mobile, create_user, "
+ "create_date, update_user, update_date, isdel)"
+ " values(?, ?, ?, ?, ?, ?, ?, current_date(), ?, current_date(), ?)";
try {
1.PreparedStatement是预编译的,对于批量处理可以大大提高效率. 也叫JDBC存储过程
2.使用 Statement 对象。在对数据库只执行一次性存取的时侯,用 Statement 对象进行处理。PreparedStatement 对象的开销比Statement大,对于一次性操作并不会带来额外的好处。
3.statement每次执行sql语句,相关数据库都要执行sql语句的编译,preparedstatement是预编译得, preparedstatement支持批处理
关于是使用PrepareStatement还是普通的statement 请参考这里 http://www.cnblogs.com/0banana0/articles/2029863.html
PreparedStatement pst = conn.prepareStatement(sql);
pst.setString(1, by.getUser_name());
pst.setInt(2, by.getSex());
pst.setInt(3, by.getAge());
pst.setDate(4, new Date(by.getBirthday().getTime()));
pst.setString(5, by.getEmail());
pst.setString(6, by.getMobile());
pst.setString(7, by.getCreate_user());
pst.setString(8, by.getUpdate_user());
pst.setInt(9, by.getIsdel());
pst.execute();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

//修改
public void updateBoy(Boy by){
Connection conn = DBUtil.getConnection();
String sql = "Update Boy set " + " user_name = ?, sex = ?, age = ?, birthday = ?, email = ?, mobile = ?, create_user = ?, "
+ "create_date = current_date(), update_user = ?, update_date = current_date(), isdel = ?"
+ " where id = ?";
try {
PreparedStatement pst = conn.prepareStatement(sql);
pst.setString(1, by.getUser_name());
pst.setInt(2, by.getSex());
pst.setInt(3, by.getAge());
pst.setDate(4, new Date(by.getBirthday().getTime()));
pst.setString(5, by.getEmail());
pst.setString(6, by.getMobile());
pst.setString(7, by.getCreate_user());
pst.setString(8, by.getUpdate_user());
pst.setInt(9, by.getIsdel());
pst.setInt(10, by.getId());
pst.execute();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} public void deleteBoy(Boy by) throws Exception{
Connection conn = DBUtil.getConnection();
String sql ="DELETE FROM Boy" + " where id = ?";
PreparedStatement pst = conn.prepareStatement(sql);
pst.setInt(1, by.getId());
pst.execute();
} public List<Boy> queray() {
List<Boy> list = new ArrayList<>();
try {
Connection conn = DBUtil.getConnection();
Statement sm = conn.createStatement();
  
    //需要获得 结果操作集,之后就可以得到查询出来的结果 .next()是判断有没有结果,并把操作集的指针移到下一个操作集上。其实查询出来的结果可以看做是数据库中的一行一行的数据,那么刚开始的时候指针指向数据表的上一行,好比一个空的头指针,所以要移到下一个,以判断到底有没有数据。
ResultSet rs = sm.executeQuery("SELECT user_name FROM Boy");
while (rs.next()) {
String name = rs.getString("user_name");
Boy by = new Boy();
by.setUser_name(name);
list.add(by);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} return list; }
}

数据库操作,jdbc的CRUD的更多相关文章

  1. 第20章 数据库操作----JDBC概述

    JDBC是一种可用于执行SQL语句的Java API(Application Programming Interface,应用程序设计接口),是连接数据库和Java应用程序的纽带. 1.JDBC-OD ...

  2. java 的数据库操作--JDBC

    一.java与数据库的交互 1.jdbc:java data base connectivity,java数据库连接.java的JDBC操作主要通过操作两个类进行连接操作:Connection 和 S ...

  3. db2 数据库操作JDBC .addBatch() 方法执行时,报错排查结果

    今天调试db2数据的存储时,jdbc使用addBatch方法时,抛出异常,异常信息如下: [jcc][1091][10404][3.62.56] 数据转换无效:参数实例  对于所请求的转换无效. ER ...

  4. java:数据库操作JDBC

    JDBC详解:https://www.cnblogs.com/erbing/p/5805727.html JDBC存储过程,事务管理,数据库连接池,jdbc的封装框架:https://www.cnbl ...

  5. jdbc mysql crud dao模型 sql注入漏洞 jdbc 操作大文件

    day17总结 今日内容 l JDBC 1.1 上次课内容总结 SQL语句: 1.外键约束:foreign key * 维护多个表关系! * 用来保证数据完整性! 2.三种关系: * 一对多: * 一 ...

  6. 【JDBC】CRUD操作

    JDBC的CRUD操作 向数据库中保存记录 修改数据库中的记录 删除数据库中的记录 查询数据库中的记录 保存代码的实现 package demo1; import java.sql.Connectio ...

  7. [总结] JDBC数据库操作

    1.加载驱动--告诉驱动管理将使用哪一个数据库的驱动包. class.forName("com.mysql.jdbc.Driver"); 2.操作JDBC ADI完成数据库动作 D ...

  8. 使用JdbcTemplate简化JDBC操作 实现数据库操作

    使用Spring JDBC框架方遍简单的完成JDBC操作,满足性能的需求且灵活性高. Spring JDBC框架由4个部分组成,即core.datasource.object.support. org ...

  9. 【Java框架型项目从入门到装逼】第九节 - 数据库建表和CRUD操作

    1.新建学生表 这节课我们来把和数据库以及jdbc相关的内容完成,首先,进行数据库建表.数据库呢,我们采用MySQL数据库,我们可以通过navcat之类的管理工具来轻松建表. 首先,我们得建一个数据库 ...

  10. JDBC数据库操作

    JDBC:   创建SQL语句对象    Statement statement = (Statement) con.createStatement() ;   调用执行     statement. ...

随机推荐

  1. [LeetCode] Plus One Linked List 链表加一运算

    Given a non-negative number represented as a singly linked list of digits, plus one to the number. T ...

  2. [LeetCode] Coin Change 硬币找零

    You are given coins of different denominations and a total amount of money amount. Write a function ...

  3. java web后台开发SSM框架(Spring+SpringMVC+MyBaitis)搭建与优化

    一.ssm框架搭建 1.1创建项目 新建项目后规划好各层的包. 1.2导入包 搭建SSM框架所需包百度云链接:http://pan.baidu.com/s/1cvKjL0 1.3整合spring与my ...

  4. underscore 源码解读之 bind 方法的实现

    自从进入七月以来,我的 underscore 源码解读系列 更新缓慢,再这样下去,今年更完的目标似乎要落空,赶紧写一篇压压惊. 前文 跟大家简单介绍了下 ES5 中的 bind 方法以及使用场景(没读 ...

  5. sed awk grep三剑客常用

    sed的常用用法: awk的常用用法: grep的常用用法: 除了列出符合行之外,并且列出后10行. grep -A 10 Exception kzfinance-front.log 除了列出符合行之 ...

  6. 【BZOJ 4580】【Usaco2016 Open】248

    http://www.lydsy.com/JudgeOnline/problem.php?id=4580 区间dp,f(i,j)表示区间[i,j]全部合成一个数,这个数是多少. 可以归纳证明[i,j] ...

  7. Shiro-集成Spring

    集成Spring 加入Spring 和Shiro的jar 包 配置Spring 及SpringMVC 参照:1.3.2\shiro-root-1.3.2-source-release\shiro-ro ...

  8. cavans 详解

    http://blog.csdn.net/clh604/article/details/8536059

  9. JS操作Unicode编码的emoji表情显示在页面

    前言:项目中用到了emoji表情,后端传递数据时直接是以Unicode形式,在页面总是无法展示,找尽各种方法总算是试出了一种,虽然达到效果但是并不是特别理解其中的原理并且无比笨拙,贴在这用作笔记,如果 ...

  10. Pitfalls: C++ 中的index运算符

    名可名, 非常名 在调一个题目的过程中发现了一个之前从未意识到的问题. 考虑如下代码 vector<int> a; int f(int x){ a.push_back(x); return ...