value
=
rs.getString("name")
之前要先rs.next()一下
你用这个来判断密码错误?
if(!rs.isBeforeFirst()){
JOptionPane.showMessageDialog(frame,
"Wrong
password!")
}
isBeforeFirst()
的意思是:获取光标是否位于此
ResultSet
对象的第一行之前。
要看你是用框架还是传统的JDBC连接了,如果是传统的JDBC连接的话方法如下:
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver")//加载数据库驱动,不同数据库加载的驱动不一样,这个例子是sql server数据库
String url = "jdbc:sqlserver://127.0.0.1:1433databaseName=testDB"//IP:端口databaseName:数据库名
String sql = "select name from t_user"//sql 查询语句
Connection con = DriverManager.getConnection(url , username , password )//url:
数据库连接串 userName:数据库登录账号 passWord:数据库登录密码
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY)
ResultSet rs = stmt.executeQuery(sql)
//用户对象集合
List<User> userList = new ArrayList<User>()
while(rs.next()){
User user = new User()
user.setName = rs.getString("name")
userList.add(user)
}
用JDBC连接数据库,然后用sql语句。要导入mysql的驱动包。import java.sql.*
public class TestMySql {
static Connection con = null// 声明Connection对象
static Statement sql = null
static ResultSet res = null
public static void main(String[] args) {
TestMySql c = new TestMySql()
con = c.getConnection()
try {
sql = con.createStatement()
res = sql.executeQuery("select * from dept")
//sql语句,我数据库里有张dept表
while (res.next()) {//输出结果
System.out.print(res.getString(1) + "<——>")
System.out.print(res.getString(2) + "<——>")
System.out.print(res.getString(3) )
System.out.println()
}
} catch (SQLException e) {
e.printStackTrace()
} finally {
try {
if (res != null) {
res.close()
res =null
}
if (sql != null) {
sql.close()
sql =null
}
if (con != null) {
con.close()
con =null
}
} catch (SQLException e) {
e.printStackTrace()
}
}
}
public Connection getConnection() {
try {
Class.forName("com.mysql.jdbc.Driver")
// 加载oracleJDBC驱动
System.out.println("数据库驱动加载成功")
} catch (ClassNotFoundException e) {
e.printStackTrace()
}
try {// 通过访问数据库的URL获取数据库连接对象
con = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/mydata", "root", "qwer1234")
//mydata为mysql名字
System.out.println("数据库连接成功")
} catch (SQLException e) {
e.printStackTrace()
}
return con// 按方法要求返回一个Connection对象
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)