- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
目前我正在使用 Arduino 开发空气质量监测设备的原型(prototype)。该设备集成了三个气体传感器,可通过 HC-05 蓝牙模块将数据发送到我的安卓应用程序。我能够实时接收值并使用 textview 显示它,但不知道必须使用 SQL 数据库将数据保存在 android 设备本身中。我已经尝试了我在其他地方找到的所有教程,但它只在单击按钮时保存数据,但即使在尝试 buttonclick 方法时,应用程序也会崩溃(相反,我想在每次应用程序启动时在后台连续保存数据)。我是android开发的新手,请帮助我。
目前我需要保存(时间/日期、GPS 坐标、传感器 1 数据、传感器 2 数据、传感器 3 数据、整体空气质量)。
对不起,已经去掉了SQL存储部分,这里是从Arduino获取实时数据的代码。
//data received from Arduino as #data+data+data+~
bluetoothIn = new Handler() {
public void handleMessage(Message msg) {
if (msg.what == handlerState) { //if message is what we want
String readMessage = (String) msg.obj; // msg.arg1 = bytes from connect thread
recDataString.append(readMessage); //keep appending to string until ~
int endOfLineIndex = recDataString.indexOf("~"); // determine the end-of-line
if (endOfLineIndex > 0) { // make sure there data before ~
String dataInPrint = recDataString.substring(0, endOfLineIndex);
if (recDataString.charAt(0) == '#') //if it starts with # we know it is what we are looking for
{
dataInPrint = dataInPrint.substring(1, dataInPrint.length() - 1); //remove the Hash tag symbol
StringTokenizer st = new StringTokenizer(dataInPrint,"+");
String sensor0 = st.nextToken();
String sensor1 = st.nextToken();
String sensor2 = st.nextToken();
showMq135.setText(sensor0); //update the textviews with sensor values
showMq9.setText(sensor1);
showDust.setText(sensor2);
p1 = (ProgressBar) findViewById(R.id.progressBarMq135);
int p135 = Integer.parseInt(sensor0);
p1.setMax(100);
p1.setProgress(p135);
p2 = (ProgressBar) findViewById(R.id.progressBarMq9);
int p9 = Integer.parseInt(sensor1);
p2.setMax(100);
p2.setProgress(p9);
p3 = (ProgressBar) findViewById(R.id.progressBarDust);
int pDust = Integer.parseInt(sensor2);
p3.setMax(100);
p3.setProgress(pDust);
if (p135 >= 51 || p9 >= 51 || pDust >= 51) {
showAirQuality.setTextColor(Color.RED);
showAirQuality.setText("Hazardous/Very unhealthy");
sound.start();
}
else {
showAirQuality.setTextColor(Color.BLUE);
showAirQuality.setText("Normal/Intermediate");
}
}
recDataString.delete(0, recDataString.length());//clear all string data
}
}
}
};
最佳答案
好的,这里有一些你可以改编的东西,它展示了如何创建数据库和表,然后如何插入数据,以及如何检查数据是否存在。
几乎所有代码都在 SQLiteOpenHelp 子类中,为方便起见,我将其称为 so46375780DBHelper
(您很可能会重命名它)这应该在一个文件中名为 so46375780DBHelper.java :-
public class so46375780DBHelper extends SQLiteOpenHelper {
public static final String DBNAME = "airquality";
public static final int DBVERSION = 1;
public static final String READINGS_TBL = "air_readings";
public static final String READINGID_COL = "_id";
public static final String READINGTIMESTAMP_COL = "timestamp";
public static final String READINGLOCATION_COL = "location";
public static final String READINGSENSOR1_COL = "sensor1";
public static final String READINGSENSOR2_COL = "sensor2";
public static final String READINGSENSOR3_COL = "sensor3";
public static final String READINGAIRQLTY_COL = "airquality";
SQLiteDatabase db;
// SQL to create the table
String tblcrtsql = "CREATE TABLE " + READINGS_TBL + "(" +
READINGID_COL + " INTEGER PRIMARY KEY, " + // unqiue identifier
READINGTIMESTAMP_COL + " INTEGER, " +
READINGLOCATION_COL + " TEXT, " +
READINGSENSOR1_COL + " TEXT, " +
READINGSENSOR2_COL + " TEXT, " +
READINGSENSOR3_COL + " TEXT, " +
READINGAIRQLTY_COL + " TEXT" +
")";
// Database Helper Constructor
so46375780DBHelper(Context context) {
super(context, DBNAME, null, DBVERSION);
db = this.getWritableDatabase(); // Open the database
}
@Override
// Called when Database is openbed when it doesn't already exist
// ^^^^^^^^ IMPORTANT to note ^^^^^^^^
public void onCreate(SQLiteDatabase db) {
db.execSQL(tblcrtsql); // Create the table(s)
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldversion, int newversio) {
}
public boolean insertReading(String location,
String sensor1,
String sensor2,
String sensor3,
String airquality) {
ContentValues cv = new ContentValues();
cv.put(READINGTIMESTAMP_COL,
Long.toString(
System.currentTimeMillis()
)
);
cv.put(READINGLOCATION_COL,location);
cv.put(READINGSENSOR1_COL,sensor1);
cv.put(READINGSENSOR2_COL,sensor2);
cv.put(READINGSENSOR3_COL,sensor3);
cv.put(READINGAIRQLTY_COL,airquality);
return (db.insert(READINGS_TBL,null,cv) < 1);
}
public void showAllDataToLog() {
//get all rows eqv to SELECT * FROM air_readings;
Cursor csr = db.query(READINGS_TBL,null,null,null,null,null,null);
// Traverse the cursor
while (csr.moveToNext()) {
String rowinfo = "Row " +
csr.getPosition() +
" of " +
csr.getCount() + ".";
for (int i=0; i < csr.getColumnCount();i++) {
rowinfo = rowinfo +
"\n\t Column=" + csr.getColumnName(i) +
"\t Value=" + csr.getString(i);
}
Log.d("DBINFO",rowinfo);
}
csr.close(); // Should always close cursor when finished with them
}
}
简而言之,你有
onCreate
和 onUpgrade
(两者都是必需的,但不一定需要执行任何操作)update
方法,该方法使用 ContentValues 对象作为列/值对。如果插入成功,此方法将返回 1 或更大的值(相当于 _id 列的 rowid)。接下来只需两步即可启用数据插入,这些步骤放在将插入数据的类(或多个类)中。
1 创建 SQLiteOpenHelper 子类的实例,例如:-
so46375780DBHelper dbhlpr = new so46375780DBHelper(this);
2 使用 insertReading 方法插入一些数据,例如:-
// Insert a row
dbhlpr.insertReading(
"001,345", //coords
"76.5", // sensor 1 reading
"57.3", // sensor 2 reading
"12.6", // sensor 2 reading
"LOUSY" // air quality
);
注意!组成读数,您也可能希望改变方法以使用更多相关类型(请注意,SQlite 在类型方面非常灵活,几乎没有限制,如果值在任何类型的列中,您可以存储任何类型)。但是,当涉及到从 Cursor 中提取数据时,您应该选择最合适的 get?????
方法(下面仅使用 getString
方法,这是 Ok只是为了检查是否存在)。
以下代码将数据列在日志中,它仅用于初始确认插入正在工作:-
// Check data (writes to the log)
dbhlpr.showAllDataToLog();
关于android - 如何使用 SQL 数据库在 Android 中保存从 Arduino 板接收到的数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46375780/
我尝试根据表单元素的更改禁用/启用保存按钮。但是,当通过弹出按钮选择更改隐藏输入字段值时,保存按钮不受影响。 下面是我的代码。我正在尝试序列化旧的表单值并与更改后的表单值进行比较。但我猜隐藏的字段值无
我正在尝试保存模型的实例,但我得到了 Invalid EmbeddedDocumentField item (1) 其中 1 是项目的 ID(我认为)。 模型定义为 class Graph(Docum
我有一个非常奇怪的问题......在我的 iPhone 应用程序中,用户可以打开相机胶卷中的图像,在我的示例中 1920 x 1080 像素 (72 dpi) 的壁纸。 现在,想要将图像的宽度调整为例
目前,我正在使用具有排序/过滤功能的数据表成功地从我的数据库中显示图像元数据。在我的数据表下方,我使用第三方图像覆盖流( http://www.jacksasylum.eu/ContentFlow/
我的脚本有问题。我想按此顺序执行以下步骤: 1. 保存输入字段中的文本。 2. 删除输入字段中的所有文本。 3. 在输入字段中重新加载之前删除的相同文本。 我的脚本的问题是 ug()- 函数在我的文本
任何人都可以帮助我如何保存多对多关系吗?我有任务,用户可以有很多任务,任务可以有很多用户(多对多),我想要实现的是,在更新表单中,管理员可以将多个用户分配给特定任务。这是通过 html 多选输入来完成
我在 Tensorflow 中训练了一个具有批归一化的模型。我想保存模型并恢复它以供进一步使用。批量归一化是通过 完成的 def batch_norm(input, phase): retur
我遇到了 grails 的问题。我有一个看起来像这样的域: class Book { static belongsTo = Author String toString() { tit
所以我正在开发一个应用程序,一旦用户连接(通过 soundcloud),就会出现以下对象: {userid: userid, username: username, genre: genre, fol
我正在开发一个具有多选项卡布局的 Angular 7 应用程序。每个选项卡都包含一个组件,该组件可以引用其他嵌套组件。 当用户选择一个新的/另一个选项卡时,当前选项卡上显示的组件将被销毁(我不仅仅是隐
我尝试使用 JEditorPane 进行一些简单的文本格式化,但随着知识的增长,我发现 JTextPane 更容易实现并且更强大。 我的问题是如何将 JTextPane 中的格式化文本保存到文件?它应
使用 Docker 相当新。 我为 Oracle 11g Full 提取了一个图像。创建了一个数据库并将应用程序安装到容器中。 正确配置后,我提交了生成 15GB 镜像的容器。 测试了该图像的新容器,
我是使用 Xcode 和 swift 的新手,仍在学习中。我在将核心数据从实体传递到文本字段/标签时遇到问题,然后用户可以选择编辑和保存记录。我的目标是,当用户从 friendslistViewCon
我正在用 Java 编写 Android 游戏,我需要一种可靠的方法来快速保存和加载应用程序状态。这个问题似乎适用于大多数 OO 语言。 了解我需要保存的内容:我正在使用策略模式来控制我的游戏实体。我
我想知道使用 fstream 加载/保存某种结构类型的数组是否是个好主意。注意,我说的是加载/保存到二进制文件。我应该加载/保存独立变量,例如 int、float、boolean 而不是结构吗?我这么
我希望能够将 QNetworkReply 保存到 QString/QByteArray。在我看到的示例中,它们总是将流保存到另一个文件。 目前我的代码看起来像这样,我从主机那里得到一个字符串,我想做的
我正在创建一个绘图应用程序。我有一个带有 Canvas 的自定义 View ,它根据用户输入绘制线条: class Line { float startX, startY, stopX, stop
我有 3 个 Activity 第一个 Activity 调用第二个 Activity ,第二个 Activity 调用第三个 Activity 。 第二个 Activity 使用第一个 Activi
我想知道如何在 Xcode 中保存 cookie。我想使用从一个网页获取的 cookie 并使用它访问另一个网页。我使用下面的代码登录该网站,我想保存从该连接获得的 cookie,以便在我建立另一个连
我有一个 SQLite 数据库存储我的所有日历事件,建模如下: TimerEvent *Attributes -date -dateForMark -reminder *Relat
我是一名优秀的程序员,十分优秀!