java连接数据库问题 求解答

第一个程序向数据库中添加一个记录

import java.sql.Connection;

import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class AddUser {

    /**
     * @param args
     */
    public static void main(String[] args) {
        try {
            Class.forName("com.mysql.jdbc.Driver"); // 加载数据库驱动
            String url = "jdbc:mysql://localhost:3306/db_database17"; // 声明数据库db_database17的URL
            String user = "root"; // 数据库用户名
            String password = "0226"; // 数据库密码
            Connection conn = DriverManager.getConnection(url, user, password); // 建立数据库连接,获得连接对象conn
            String sql = "insert into tb_users (username,password,sex,age) values('admin','111','男','22')"; // 生成一条sql语句
            Statement stmt = conn.createStatement(); // 创建一个Statment对象
            stmt.executeUpdate(sql); // 执行sql语句
            conn.close(); // 关闭数据库连接对象
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

运行结果在数据库中显示为:

admin 111 ? 22

第二个程序查询这个记录

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class SelectUsers {

    /**
     * @param args
     */
    public static void main(String[] args) {
        try {
            Class.forName("com.mysql.jdbc.Driver");                             // 加载数据库驱动
            String url = "jdbc:mysql://localhost:3306/db_database17";                 // 声明数据库db_database17的URL
            String user = "root";                                             // 数据库用户名
            String password = "0226";                                         // 数据库密码
            Connection conn = DriverManager.getConnection(url, user, password);         // 建立数据库连接,获得连接对象conn
            Statement stmt=conn.createStatement();
            String sql="select * from tb_users";
            ResultSet rs=stmt.executeQuery(sql);
            int id,age;
            String username,pwd,sex;
            System.out.println("id\t用户名\t密码\t性别\t年龄");
            while(rs.next()){
                id=rs.getInt("id");
                username=rs.getString(2);
                pwd=rs.getString("password");
                sex=rs.getString(4);
                age=rs.getInt("age");
                System.out.println(id+"\t"+username+"\t"+pwd+"\t"+sex+"\t"+age);
                
            }

        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}
运行结果:

admin 222 ? 22

这两个程序出现了两个问题,

我使用的是mysql数据库,

mysql数据库如何设置数据类型支持中文编码?


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值