Java操作SQLServer

依赖

<dependency>
       <groupId>com.microsoft.sqlserver</groupId>
       <artifactId>mssql-jdbc</artifactId>
       <version>7.4.1.jre8</version>
</dependency>

DBUtil.java

package Database;
import java.sql.*;

public class DBUtil {

    //这里可以设置数据库名称
    private final static String URL = "jdbc:sqlserver://localhost:1433;DatabaseName=People";
    private static final String USER="sa";
    private static final String PASSWORD="123456";
    
    private static Connection conn=null;
    //静态代码块(将加载驱动、连接数据库放入静态块中)
    static{
        try {
            //1.加载驱动程序
            Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
            //2.获得数据库的连接
            conn=(Connection)DriverManager.getConnection(URL,USER,PASSWORD);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
    
    //对外提供一个方法来获取数据库连接
    public static Connection getConnection(){
        return conn;
    }
    
    
    //测试用例
    public static void main(String[] args) throws Exception{
        
        //3.通过数据库的连接操作数据库,实现增删改查
        Statement stmt = conn.createStatement();
        //ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句   ,返回一个结果集(ResultSet)对象。
        ResultSet rs = stmt.executeQuery("select id,name,age from BasicInfo");
        while(rs.next()){//如果对象中有数据,就会循环打印出来
            System.out.println(rs.getInt("id")+","+rs.getString("name")+","+rs.getInt("age"));
        }
    }

}

模型类Person

package Database;

public class Person {
    private int id;
    private String name;
    private int age;
    
    public int getId(){return this.id;}
    public void setId(int id){this.id = id;}
    
    public String getName(){return this.name;}
    public void setName(String name){this.name = name;}
    
    public int getAge(){return this.age;}
    public void setAge(int age){this.age = age;}
}

PersonDao.java

package Database;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;

public class PersonDao {

    //------------------------------------------add--------------------------------------------------------
    public void addPerson(Person person)throws SQLException{
        //首先拿到数据库的连接
        Connection conn=DBUtil.getConnection();
        String sql="" + 
                "insert into BasicInfo"+
                "(id,name,age) "+
                "values(?,?,?)";//参数用?表示,相当于占位符;
        
        //预编译sql语句
        PreparedStatement psmt = conn.prepareStatement(sql);
        
        //先对应SQL语句,给SQL语句传递参数
        psmt.setInt(1, person.getId());
        psmt.setString(2, person.getName());
        psmt.setInt(3, person.getAge());
        
        //执行SQL语句
        psmt.execute();
        /**
         * prepareStatement这个方法会将SQL语句加载到驱动程序conn集成程序中,但是并不直接执行
         * 而是当它调用execute()方法的时候才真正执行;
         * 
         * 上面SQL中的参数用?表示,相当于占位符,然后在对参数进行赋值。
         * 当真正执行时,这些参数会加载在SQL语句中,把SQL语句拼接完整才去执行。
         * 这样就会减少对数据库的操作
         */
    }
    //------------------------------------------add--------------------------------------------------------
    //------------------------------------------update--------------------------------------------------------
    
    public void updatePerson(Person person)throws SQLException{
        //首先拿到数据库的连接
        Connection conn=DBUtil.getConnection();
        String sql="" + 
                "update BasicInfo set name = ?,age = ? where id = ?";//参数用?表示,相当于占位符
        
        //预编译sql语句
        PreparedStatement psmt = conn.prepareStatement(sql);
        
        //先对应SQL语句,给SQL语句传递参数
        psmt.setString(1, person.getName());
        psmt.setInt(2, person.getAge());
        psmt.setInt(3, person.getId());
        
        //执行SQL语句
        psmt.execute();
    }
    //------------------------------------------update--------------------------------------------------------
    //------------------------------------------delete--------------------------------------------------------
    
    public void deletePerson(int id) throws SQLException{
        Connection conn=DBUtil.getConnection();
        String sql="" + 
                "delete from BasicInfo where id = ?";
        PreparedStatement psmt = conn.prepareStatement(sql);
        psmt.setInt(1,id);
        
        //执行SQL语句
        psmt.execute();
    }
    //------------------------------------------delete--------------------------------------------------------
    //------------------------------------------SearchOne--------------------------------------------------------
    
    public Person SearchOne(int id) throws SQLException{
        Person p = null;
        Connection conn=DBUtil.getConnection();
        String sql="" + 
                "select * from BasicInfo where id = ?";
        PreparedStatement psmt = conn.prepareStatement(sql);
        psmt.setInt(1,id);
        
        //执行SQL语句
        ResultSet rs = psmt.executeQuery();
        while(rs.next()){
            p = new Person();
            p.setId(rs.getInt("id"));
            p.setName(rs.getString("name"));
            p.setAge(rs.getInt("age"));
        }
        return p;
    }
    //------------------------------------------SearchOne--------------------------------------------------------
    //------------------------------------------Search--------------------------------------------------------
    
    public List<Person> Search() throws SQLException{
        Connection conn = DBUtil.getConnection();
        Statement stmt = conn.createStatement();
        ResultSet rs =  stmt.executeQuery("select id,name,age from BasicInfo");
        List<Person> people = new ArrayList<Person>();
        Person p = null;
        while(rs.next()){//如果对象中有数据,就会循环打印出来
            p = new Person();
            p.setId(rs.getInt("id"));
            p.setName(rs.getString("name"));
            p.setAge(rs.getInt("age"));
            people.add(p);
        }
        return people;
        
    }
    //------------------------------------------Search--------------------------------------------------------
    
}

Testc.class

package Database;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;

public class Test {

    public static void main(String[] args) throws SQLException {
        // TODO Auto-generated method stub
        PersonDao p = new PersonDao();
        
        //add
        Person person0 = new Person();
        person0.setId(1);
        person0.setName("小明");
        person0.setAge(20);
        p.addPerson(person0);
        
        //update
        Person person1 = new Person();
        person1.setId(1);
        person1.setName("陈伟霆");
        person1.setAge(35);
        p.updatePerson(person1);
        
        //delete
        int id = 1;
        System.out.println(p.SearchOne(id).getName());
        
        
        //search
        List<Person> people = new ArrayList<Person>();
        people = p.Search();
        for(Person person : people){
            String str = person.getId()+","+person.getName()+","+person.getAge();
            System.out.println(str);
        }
        
        
        
    }
}

亲测有效

参考

Java连接并操作SQLServer数据库_xxpr_ybgg的博客-CSDN博客_java连接sqlserver数据库教程在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),这通过java.lang.Class类的静态方法forName(String className)实现。//ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句 ,返回一个结果集(ResultSet)对象。(1)ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句,返回一个结果集(ResultSet)对象。https://blog.csdn.net/xxpr_ybgg/article/details/126758649

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
import java.sql.*; import jdbc.DBManager; import jdbc.DBManagerTest; /** * <p>Title: </p> * <p>Description: </p> * <p>Copyright: Copyright (c) 2002</p> * <p>Company: </p> * @author * @version 1.0 */ /** * DBManager示例程序 */ public class Test { public Test() { } public static void main(String[] args) { DBManagerTest DBManagerTest1 = new DBManagerTest(); DBManager db_manager = new DBManager(); ResultSet result = null; // 数据库查询结果 try { db_manager.connect("rcms"); // 建表 db_manager .execute("create table table22 (c1 varchar(32) not null,c2 varchar(21))"); } catch (SQLException x) { x.printStackTrace(); try { db_manager.disconnect(); } catch (SQLException e) { // TODO 自动生成 catch 块 e.printStackTrace(); } System.err.print("数据库操作失败!"); } try { // 表更新操作,包括insert,update,delete db_manager .executeUpdate("insert into table22 (c1,c2) values('workflow1','engine1')"); db_manager .executeUpdate("insert into table22 (c1,c2) values('workflow2','engine2')"); db_manager .executeUpdate("insert into table22 (c1,c2) values('workflow3','engine3')"); db_manager .executeUpdate("insert into table22 (c1,c2) values('workflow4','engine4')"); db_manager.beginTransaction(); // for(int i=1500;i<2000;i++){ //// db_manager.executeUpdate("insert into T_USER (USER_ID, USER_NAME, ORG_ID, PASSWD, OLD_PASSWD, STATION, CREAT_DATE, CREAT_TIME, ALTER_DATE, ALTER_TIME, DEL_DATE, TEL, EMAIL, STATUS, SEX, ACADEMIC, CERTI_TYPE, CERTI, FAX, ADRESS, POSTCODE, BAK1, BAK2, BAK3, BAK4, BAK5)values ('test00"+i+"', 'test00"+i+"', '0001 ', 'FF5E61835C355E755EEF9321 ', 'A43B59E342F86CEE5EEF9321 ', '0 ', '20071201', '101010', null, null, null, null, null, '1', null, null, null, null, null, null, null, null, null, null, null, null)"); // db_manager.executeUpdate("insert into T_USER_ROLE values('test00"+i+"','sys_admin','')"); // if(i%300==0)db_manager.commitTransaction(); // } } catch (SQLException x) { x.printStackTrace(); try { db_manager.disconnect(); } catch (SQLException e) { // TODO 自动生成 catch 块 e.printStackTrace(); } System.err.print("数据库操作失败!"); } try { // 表查询操作,返回结果集存在DBResult类中,DBResult中的数据库查询结果已与数据库断开连接了, // 不能动态更新,注意在并发操作中应重新执行表查询操作 result = db_manager.executeQuery("select * from table22"); } catch (SQLException x) { x.printStackTrace(); try { db_manager.disconnect(); } catch (SQLException e) { // TODO 自动生成 catch 块 e.printStackTrace(); } System.err.print("数据库操作失败!"); } // int rows = result.getRows(); //返回的记录数 try { while (result.next()) { String s = result.getString("c1");// 取第4条记录c1的字段 System.out.println(s); s = result.getString("c2"); System.out.println(s); } } catch (SQLException e) { // TODO 自动生成 catch 块 e.printStackTrace(); } } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值