- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过获取 cursor.getString() 并将其设置为 Textview 来访问和显示存储在数据库中的详细信息。我有点坚持这样做并帮助我
数据库助手.java
public Cursor checkduplicates_in_user_credentials(String user_name, String password, String table) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor res = null;
if (table.equals(TABLE_NAME_USER)) {
res = db.rawQuery("select * from " + TABLE_NAME_USER + " where username=? and password=? ", new String[]{user_name, password},null);
}
return res;
}
运行应用程序时出错
Process: com.example.instacure, PID: 11556
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.instacure/com.example.instacure.Personal_Info}: java.lang.IllegalArgumentException: the bind value at index 2 is null
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3270)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016)
at android.os.Handler.dispatchMessage(Handler.java:107)
at android.os.Looper.loop(Looper.java:214)
at android.app.ActivityThread.main(ActivityThread.java:7356)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)
Caused by: java.lang.IllegalArgumentException: the bind value at index 2 is null
at android.database.sqlite.SQLiteProgram.bindString(SQLiteProgram.java:167)
at android.database.sqlite.SQLiteProgram.bindAllArgsAsStrings(SQLiteProgram.java:203)
at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:49)
at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1443)
at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1400)
at com.example.instacure.DatabaseHelper.checkduplicates_in_user_credentials(DatabaseHelper.java:72)
at com.example.instacure.Personal_Info.onCreate(Personal_Info.java:44)
at android.app.Activity.performCreate(Activity.java:7802)
at android.app.Activity.performCreate(Activity.java:7791)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1299)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3245)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3409)
at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2016)
at android.os.Handler.dispatchMessage(Handler.java:107)
at android.os.Looper.loop(Looper.java:214)
at android.app.ActivityThread.main(ActivityThread.java:7356)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)
这是它引用的地方
个人信息.java
Cursor y = db.checkduplicates_in_user_credentials(username, password, getResources().getString(R.string.user_credentials));
if (y.moveToFirst()) {
String name1 = y.getString(y.getColumnIndex("first_name"));
String name2 = y.getString(y.getColumnIndex("last_name"));
name.setText(name1+" "+name2);
age.setText(y.getString(y.getColumnIndex("age")));
email.setText(y.getString(y.getColumnIndex("e_mail")));
pwd.setText(y.getString(y.getColumnIndex("password")));
usrname.setText(y.getString(y.getColumnIndex("username")));
phoneno.setText(y.getString(y.getColumnIndex("phone_number")));
bloodgroup.setText(y.getString(y.getColumnIndex("blood_group")));
gender.setText(y.getString(y.getColumnIndex("gender")));
city.setText(y.getString(y.getColumnIndex("city")));
utype.setText(y.getString(y.getColumnIndex("user_type")));
}
最佳答案
java.lang.IllegalArgumentException: the bind value at index 2 is null
告诉你 password 是 null 因此不能用于替换(绑定(bind))查询中的?。
您需要确保在获取密码时绝不会为空或将其处理为空。
正确的修复应该是第一个(没有提供获取密码的代码所以无法给出这个修复)。但是以下(将其处理为空)可以解决潜在问题:-
public Cursor checkduplicates_in_user_credentials(String user_name, String password, String table) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor res = null;
if (password == null) password = "apassswordthatwouldneverbeusedbytheuser";
if (table.equals(TABLE_NAME_USER)) {
res = db.rawQuery("select * from " + TABLE_NAME_USER + " where username=? and password=? ", new String[]{user_name, password},null);
}
return res;
}
但是,可能仍然存在问题,因为调用代码未处理空游标,如果表不等于 TABLE_NAME_USER,则可能会发生这种情况。
所以你应该有这样的东西:-
Cursor y = db.checkduplicates_in_user_credentials(username, password, getResources().getString(R.string.user_credentials));
if (y != null && y.moveToFirst()) { // will not try to moveToFirst if the Cursor is null
String name1 = y.getString(y.getColumnIndex("first_name"));
String name2 = y.getString(y.getColumnIndex("last_name"));
name.setText(name1+" "+name2);
age.setText(y.getString(y.getColumnIndex("age")));
email.setText(y.getString(y.getColumnIndex("e_mail")));
pwd.setText(y.getString(y.getColumnIndex("password")));
usrname.setText(y.getString(y.getColumnIndex("username")));
phoneno.setText(y.getString(y.getColumnIndex("phone_number")));
bloodgroup.setText(y.getString(y.getColumnIndex("blood_group")));
gender.setText(y.getString(y.getColumnIndex("gender")));
city.setText(y.getString(y.getColumnIndex("city")));
utype.setText(y.getString(y.getColumnIndex("user_type")));
}
既然您正在处理空游标,那么如果密码实际上是apassswordthatwouldneverbeusedbytheuser,那么您可以改为使用:-
public Cursor checkduplicates_in_user_credentials(String user_name, String password, String table) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor res = null;
if (password == null) return null;
if (table.equals(TABLE_NAME_USER)) {
res = db.rawQuery("select * from " + TABLE_NAME_USER + " where username=? and password=? ", new String[]{user_name, password},null);
}
return res;
}
关于android - java.lang.IllegalArgumentExceptionIllegalArgumentException : the bind value at index 2 is null 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58648992/
在 Tomcat 6/Ubuntu 12.04 上启动 Grails 2.1.0 应用程序时出现以下错误。 Error 500 - Internal Server Error. groovy.lang
在运行 Storm 拓扑时,我收到此错误。拓扑完美运行 5 分钟,没有任何错误,然后失败。我正在使用 Config.TOPOLOGY_TICK_TUPLE_FREQ_SECS as 300 sec i
我有一个 jsp 代码在其中一台机器上运行良好。但是当我复制到另一台机器时,我得到了这个 no such method found 异常。我是 Spring 的新手。有人可以解释我错过了什么吗? 以下
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我的代码在下面给出了一个错误; Exception in thread "main" java.lang.NoSuchMethodError: com/myApp/Client.cypherCBC(L
我正在尝试一个 Restful web 服务示例,所以当我要访问 url 时,我遇到了异常 java.lang.NoSuchMethodError: jersey.repackaged.com.goo
我正在将一个 Spring web 项目转换为一个 Maven 项目,但我收到了这个错误: java.lang.NoSuchMethodError: org.jboss.logging.Logger.
在我的项目中,我有一个像这样的枚举: public enum MyEnum { FIRST(1), SECOND(2); private int value; private MyEnum(int v
我创建了这个简单的示例,用于读取 Linux 正常运行时间: public String getMachineUptime() throws IOException { String[] di
我正在使用 Eclipse,并且正在使用 Java。我的目标是使用 bogoSort 方法对 vector 进行排序在一个 vector (vectorExample)中适应我的 vector 类型,
我正在运行以下查询。它显示一条错误消息。如何解决这个错误? ListrouteList=null; List companyList = session.createS
我有以下模型类: @Entity @Table(name="user_content") @org.hibernate.annotations.NamedQueries({ @org.
我有那个错误。这是我的代码: GmailSettingsService service = new GmailSettingsService(APPLICATION_NAME, DOMAIN_NAME
实际上我在执行我的java程序时遇到了下面提到的错误 Exception in thread "pool-1-thread-1" java.lang.ClassCastException: jav
java.lang.ClassCastException: java.lang.Float cannot be cast to java.lang.String 我在以下代码中遇到此异常: Strin
我正在尝试从 linkedhashset 中检索随机元素。下面是我的代码,但它每次都给我异常。 private static void generateRandomUserId(Set userIds
我已经完成了 Android 中的代码: List spinnerArray = new ArrayList(); for (int i = 0; i item = (LinkedTreeMap)
这个问题已经有答案了: Explanation of ClassCastException in Java (12 个回答) 已关闭 6 年前。 我已经编写了 java 到 Json 的代码,同时从页
这个问题在这里已经有了答案: ClassCastException java.lang.Long cannot be cast to clojure.lang.IFn (4 个答案) 关闭 6 年前
我在运行时遇到问题来编译这段代码,这给我一个错误,java.lang.Integer 无法转换为 Java.lang.Double。如果有人帮助我更正此代码,我将非常高兴 double x; pu
我是一名优秀的程序员,十分优秀!