Java操作MySQL数据库——插入表中数据

1. 在数据库中建立表

CREATE TABLE `user`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `password` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 303 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

SET FOREIGN_KEY_CHECKS = 1;

2.编写代码

public class Main {
    //数据库连接
    private static Connection connection;
    //连接数据库的URL
    private static String url = "jdbc:mysql:///blog?useSSL=false";
    //连接数据库的账号
    private static String username = "root";
    //连接数据库的密码
    private static String password = "123456";

    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //加载数据库驱动
        Class.forName("com.mysql.jdbc.Driver");
        //获取数据库连接
        connection = DriverManager.getConnection(url, username, password);
        //由于数据库主键设置为自增,所以在这里传入的主键设置为为null
        String sql = "insert into user values (null,?,?)";
        PreparedStatement statement = connection.prepareStatement(sql);
        //开启事务
        connection.setAutoCommit(false);
        //设置第一个问号
        statement.setString(1, "a");
        //设置第二个问号
        statement.setString(2, "b");
        //执行SQL
        statement.executeUpdate();
        //提交事务
        connection.commit();
        statement.close();
        connection.close();
    }
}
class User {
    private Integer id;
    private String username;
    private String password;

    public User(Integer id, String username, String password) {
        this.id = id;
        this.username = username;
        this.password = password;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username=" + username +  +
                ", password=" + password +  +
                };
    }
}
经验分享 程序员 微信小程序 职场和发展