Java MySQL 程序优化

使用 Properties

在上面的文章中,我已经介绍了在 Java 中如何使用 MySQL, 下面就来看看怎么使用 Propreties 对原本的程序进行优化。

 String url = "jdbc:mysql://localhost:3306/user_db?" + "user=root&password=hwaphon&&useSSL=true";

这个时候问题出现了,如果我们的数据库更改名称了,访问密码改了,那我们怎么办?我们直接去修改源代码吗?当然这样是可以的,但不推荐这么做,因为这样违背了开闭原则。所以我们最好将其放到配置文件中,这样我们只需要对配置文件进行修改即可,不必再去修改我们的源代码。

首先我们新建一个名为 dbconfig.properties文件,在其中写入下面这两行代码。

mysql_driver=com.mysql.jdbc.Driver
mysql_url=jdbc:mysql://localhost:3306/user_db?user=root&password=hwaphon&&useSSL=true

下面我们新建一个工厂类,用于读取配置文件中的内容,并且实现返回 Connection 的方法。

 public class ConnectionFactory {

    private static String mysql_driver;
    private static String mysql_url;
    private static ConnectionFactory factory = new ConnectionFactory();

    static {
        Properties properties = new Properties();
        try {
            InputStream inputStream = ConnectionFactory.class
                    .getClassLoader()
                    .getResourceAsStream("dbconfig.properties");
            properties.load(inputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
        mysql_driver = properties.getProperty("mysql_driver");
        mysql_url = properties.getProperty("mysql_url");
    }

    private ConnectionFactory() {
    }

    public static ConnectionFactory getInstance() {
        return factory;
    }

    public Connection makeConnection() {
        Connection connection = null;
        try {
            Class.forName(mysql_driver);
            connection = DriverManager.getConnection(mysql_url);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }

        return connection;
    }

}

1.首先我们利用 static 定义了一个块,这个块会在 JVM 首次加载类的时候被调用,在这里我们将之前写在配置文件中的内容读取出来,并且其保存在我们自己声明的变量中,用于在 makeConnection() 中获取到一个 Connection
2.注意在这里我们使用了单例模式用于对工厂类实例的创建进行限制。

下面我们就去测试一下这么写是否能够对数据库进行正常操作。

public class Client {
    public static void main(String[] args) {
        Connection connection = ConnectionFactory.getInstance().makeConnection();
        try {
            Statement statement = connection.createStatement();
            String sql = "INSERT INTO table_user(username,password,email) " +
                    "VALUES('testPerson','testPass','testEm@163.com')";
            statement.executeUpdate(sql);
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

运行之后,进入 MySQL Workbench 查询一下数据,发现以上代码确实是可以有效运行的。修改之后,我们可以看到,在主方法中代码量大大减少了。重要的是我们这么做让我们的程序遵守了开闭原则。

DAO && DTO

什么是 DTO 呢 ? 我所理解的就是,将数据库中的表抽象成 Java 中的一个对象,将表中的字段抽象成对象的属性,并为其设置 SetterGetter。那么为什么将表转化成一个对象呢?Java 是一种面向对象的语言,一旦我们将表抽象成对象,那么我们对其的操作也就变得简单起来。

什么是 DAO 呢?就是对非对象数据进行对象化操作。下面我将我创建表的语句粘贴出来,然后进行讲解如何使用 DAODTO 概念对数据库操作进行优化。

CREATE TABLE table_user (
    id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    username VARCHAR(20) NOT NULL DEFAULT '',
    password VARCHAR(16) NOT NULL DEFAULT '',
    email VARCHAR(20) DEFAULT '',
    PRIMARY KEY (id)
)  ENGINE=INNODB DEFAULT CHARSET=UTF8;

下面我们将这个表抽象成一个对象。

public class User {

    private String username;
    private String password;
    private String email;
    protected Long id;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    @Override
    public String toString() {
        return "User{" +
                "username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", email='" + email + '\'' +
                ", id=" + id +
                '}';
    }
}

为了代码的可拓展性,我们先定义一个接口。

public interface UserDao {

    public void save(Connection connection, User user) throws SQLException;

    public void update(Connection connection, Long id, User user) throws SQLException;

    public void delete(Connection connection, User user) throws SQLException;
}

然后定义一个实现类,完成对数据库的操作。

public class ConcreteUserDao implements UserDao {

    @Override
    public void save(Connection connection, User user) throws SQLException {
        PreparedStatement statement = connection
                .prepareCall("INSERT INTO table_user(username,password,email) VALUES(?,?,?)");
        statement.setString(1, user.getUsername());
        statement.setString(2, user.getPassword());
        statement.setString(3, user.getEmail());
        statement.execute();
    }

    @Override
    public void update(Connection connection, Long id, User user) throws SQLException {

    }

    @Override
    public void delete(Connection connection, User user) throws SQLException {

    }
}

由于各个方法的代码都是类似的,所以在这里我只实现了一个 save() 方法。注意 VALUES 后面括号中的 ? 是一个占位符,其值我们是在下面进行手动指定的。

利用这种方式,我们对数据库的操作显得十分简单,逻辑十分清晰。好了,本篇文章就介绍到这里,有疑问可在下方进行留言。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容