用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. Eclipse CDT: Shortcut to switch between .h and .cpp

    ctrl+ tab  is the default shortcut.You can change it in Window → Preferences → General → Keys: Toggl ...

  2. Nuget 命令 NuGet 管理项目库

    因为可视化库程序包管理器的局限性,有很多需要的功能在界面中无法完成. 以下技巧均需要在"程序包管理器控制台"中使用命令来完成. 一.改变项目目标框架后,更新程序包 当改变项目的目标 ...

  3. [LeetCode] Closest Binary Search Tree Value II 最近的二分搜索树的值之二

    Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ...

  4. [LeetCode] Path Sum 二叉树的路径和

    Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that adding up all ...

  5. 用vue.js学习es6(三):数组、对象和函数的解构

    一.数组的解构: 以前的方式: var arr = [1,2,3]; console.log(arr[0]); //1 console.log(arr[1]); //2 现在的方式: var [a,b ...

  6. 函数:MySQL中字符串匹配函数LOCATE和POSITION使用方法

    1. 用法一 LOCATE(substr,str) POSITION(substr IN str) 函数返回子串substr在字符串str中第一次出现的位置.如果子串substr在str中不存在,返回 ...

  7. Xtrabackup原理及使用innobackupex进行MySQL数据库备份恢复

    Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具. Xtrabackup中主要包含两个工 ...

  8. Theano conv2d的border_mode

    文档是这么写的: border_mode: str, int or tuple of two int Either of the following: ``'valid'``: apply filte ...

  9. 冰冻三尺非一日之寒--web框架Django

    1.JS 正则    test   - 判断字符串是否符合规定的正则        rep = /\d+/;        rep.test("asdfoiklfasdf89asdfasdf ...

  10. JFinalConfig配置

    package com.sandu.common.config; import com.jfinal.config.Constants; import com.jfinal.config.Handle ...