- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含两个表的数据库。
第一个:queue_incoming
+---------------+
| column_name | pk
+---------------+
|id | 1
|api_id | 0
|driver | 0
|vehicle_number | 0
+---------------+
第二表:包
+------------------+
| column_name | pk
+------------------+
|id | 1
|api_id | 0
|queue_incoming_id | 0
|driver | 0
|vehicle_number | 0
+------------------+
两个表之间的关系是一个queue_incoming有很多包。queue_incoming.id = bag.queue_incoming_id
问题是,我需要将每个queue_incoming记录中的bag的所有记录放到一个List中。
到目前为止,这是代码。非常感谢任何帮助。
实体:QueueIncomingEntity.java
@Entity(tableName = "queue_incoming")
public class QueueIncomingEntity {
@PrimaryKey(autoGenerate = true)
private Long id;
@ColumnInfo(name = "api_id")
private Integer ApiId;
@ColumnInfo(name = "driver")
private String driver;
@ColumnInfo(name = "vehicle_number")
private String vehicleNumber;
@ColumnInfo(name = "date_unique_number")
private String dateUniqueNumber;
@ColumnInfo(name = "unique_number")
private String uniqueNumber;
@ColumnInfo(name = "message")
private String message;
@ColumnInfo(name = "status")
private String status;
@Ignore
private List<BagEntity> bagEntities; // handle all bags in each queue
// Constructor
public QueueIncomingEntity(String driver, String vehicleNumber, String dateUniqueNumber, String uniqueNumber, String message, String status) {
this.driver = driver;
this.vehicleNumber = vehicleNumber;
this.dateUniqueNumber = dateUniqueNumber;
this.uniqueNumber = uniqueNumber;
this.message = message;
this.status = status;
}
// Getter Setter
}
DAO:QueueIncomingDao.java
@Dao
public interface QueueIncomingDao {
@Insert(onConflict = OnConflictStrategy.REPLACE)
long insert(QueueIncomingEntity queueIncomingEntity);
@Update
void update(QueueIncomingEntity queueIncomingEntity);
@Delete
void delete(QueueIncomingEntity queueIncomingEntity);
@Query("DELETE FROM queue_incoming")
void deleteAll();
@Query("SELECT * FROM queue_incoming WHERE id =:id")
QueueIncomingEntity findById(long id);
@Query("SELECT * FROM queue_incoming ORDER BY id DESC")
LiveData<List<QueueIncomingEntity>> getAll();
// This is the problem, how to pass this , or how to related this on LiveData
@Query("SELECT " +
"bag.id as id," +
"bag.api_id as apiId," +
"bag.bag_number as bagNumber," +
"bag.lot_number as lotNumber," +
"bag.consignee_name as consigneeName," +
"bag.allocation_consignee as allocationConsignee," +
"bag.nett_weight as nettWeight," +
"bag.gross_weight as grossWeight " +
"FROM queue_incoming " +
"LEFT JOIN bag bag ON bag.queue_incoming_id = queue_incoming.id WHERE queue_incoming.id = :id")
List<QueueIncoming> getAllJoinBags(long id);
// Inner class to handle method getAllJoinBags
class QueueIncoming {
public Long id;
public Integer apiId;
public Integer bagNumber;
public String lotNumber;
public String consigneeName;
public String allocationConsignee;
public Integer nettWeight;
public Integer grossWeight;
// Getter Setter
}
}
存储库
public class QueueIncomingRepository {
private QueueIncomingDao queueIncomingDao;
private BagDao bagDao;
private Context context;
private ArrayList<BagLotNumberModel> bagLotNumbers;
private LiveData<List<QueueIncomingEntity>> listLiveData;
// constructor
public QueueIncomingRepository(Application application) {
AppDatabase database = AppDatabase.getInstance(application);
queueIncomingDao = database.queueIncomingDao();
listLiveData = queueIncomingDao.getAll();
}
// a lot of crud code
// Handling LiveData
public LiveData<List<QueueIncomingEntity>> getAll() {
return listLiveData;
}
}
View 模型:QueueIncomingViewModel.java
public class QueueIncomingViewModel extends AndroidViewModel {
private QueueIncomingRepository queueIncomingRepository;
private LiveData<List<QueueIncomingEntity>> listLiveData;
/**
* Create constructor matching super
*/
public QueueIncomingViewModel(@NonNull Application application) {
super(application);
queueIncomingRepository = new QueueIncomingRepository(application);
listLiveData = queueIncomingRepository.getAll();
}
public void insert(QueueIncomingEntity queueIncomingEntity) {
queueIncomingRepository.insert(queueIncomingEntity);
}
public void update(QueueIncomingEntity queueIncomingEntity) {
queueIncomingRepository.update(queueIncomingEntity);
}
public void delete(QueueIncomingEntity queueIncomingEntity) {
queueIncomingRepository.delete(queueIncomingEntity);
}
public void deleteAll() {
queueIncomingRepository.deleteAll();
}
public LiveData<List<QueueIncomingEntity>> getListLiveData() {
return listLiveData;
}
}
Activity :AntamQueueIncomingRoomActivity.java
public class AntamQueueIncomingRoomActivity extends AppCompatActivity {
public static final int ADD_QUEUE_INCOMING = 1;
public static final int EDIT_QUEUE_INCOMING = 2;
public static final int EDIT_QUEUE_INCOMING_BAGS = 3;
public static final int RE_UPLOAD = 4;
private QueueIncomingViewModel queueIncomingViewModel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_antam_incoming_room);
RecyclerView recyclerView = findViewById(R.id.recycler_view_antam_queue_incoming);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
recyclerView.setHasFixedSize(true);
QueueIncomingAdapter adapter = new QueueIncomingAdapter();
recyclerView.setAdapter(adapter);
queueIncomingViewModel = ViewModelProviders.of(this).get(QueueIncomingViewModel.class);
queueIncomingViewModel.getListLiveData().observe(this, queueIncomingEntities -> {
adapter.submitList(queueIncomingEntities);
});
FloatingActionButton fab = findViewById(R.id.fab);
fab.setOnClickListener(view -> {
Intent intent = new Intent(getApplicationContext(), AntamAddEditQueueIncomingRoomActivity.class);
startActivityForResult(intent, ADD_QUEUE_INCOMING);
});
//handling item click on row adapter
adapter.setOnItemClickListener(new QueueIncomingAdapter.OnItemClickListener() {
@Override
public void onItemClick(QueueIncomingEntity queueIncomingEntity) {
String[] options = {"1. Update Master Incoming", "2. Update Detail Bags", "3. Re-Upload"};
AlertDialog.Builder builder = new AlertDialog.Builder(AntamQueueIncomingRoomActivity.this);
builder.setTitle("Menu: " + queueIncomingEntity.getDriver() + " # " + queueIncomingEntity.getVehicleNumber());
builder.setItems(options, (dialog, which) -> {
switch (which) {
case 2:
Intent intent2 = new Intent(AntamQueueIncomingRoomActivity.this, AntamDialogReUploadIncomingActivity.class);
// Data Master
intent2.putExtra(AntamDialogReUploadIncomingActivity.EXTRA_ID, Long.valueOf(queueIncomingEntity.getId()));
intent2.putExtra(AntamDialogReUploadIncomingActivity.EXTRA_API_ID, queueIncomingEntity.getApiId());
// Get Data Detail bags, how ?
// Get and passing All bags into new ActivityForResult
startActivityForResult(intent2, RE_UPLOAD);
break;
default:
break;
}
});
builder.show();
}
});
}
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == ADD_QUEUE_INCOMING && resultCode == RESULT_OK) {
// insert
} else if (requestCode == EDIT_QUEUE_INCOMING && resultCode == RESULT_OK) {
Long id = Long.valueOf(data.getLongExtra(AntamAddEditQueueIncomingRoomActivity.EXTRA_ID, -1));
// Update
queueIncomingEntity.setId(id);
queueIncomingViewModel.update(queueIncomingEntity);
Toast.makeText(this, data.getStringExtra(AntamAddEditQueueIncomingRoomActivity.EXTRA_DRIVER) + " is successfully updated", Toast.LENGTH_SHORT).show();
} else if (requestCode == RE_UPLOAD) {
}
}
}
BagEntity.java
我已经声明过了
import android.arch.persistence.room.ColumnInfo;
import android.arch.persistence.room.Entity;
import android.arch.persistence.room.ForeignKey;
import android.arch.persistence.room.PrimaryKey;
@Entity(
tableName = "bag",
foreignKeys = {
@ForeignKey(
entity = QueueIncomingEntity.class,
parentColumns = "id",
childColumns = "queue_incoming_id",
onDelete = ForeignKey.CASCADE
),
@ForeignKey(
entity = QueueContainerStuffingEntity.class,
parentColumns = "id",
childColumns = "queue_container_stuffing_id"
)
}
)
public class BagEntity {
@PrimaryKey(autoGenerate = true)
private Long id;
@ColumnInfo(name = "api_id")
private Long ApiId;
@ColumnInfo(name = "queue_incoming_id", index = true)
private Long queueIncomingId;
@ColumnInfo(name = "queue_container_stuffing_id", index = true)
private Long queueContainerStuffingId;
@ColumnInfo(name = "bag_number")
private Integer bagNumber;
@ColumnInfo(name = "lot_number")
private String lotNumber;
@ColumnInfo(name = "consignee_name")
private String consigneeName;
@ColumnInfo(name = "allocation_consignee")
private String allocationConsignee;
@ColumnInfo(name = "nett_weight")
private Integer nettWeight;
@ColumnInfo(name = "gross_weight")
private Integer grossWeight;
public BagEntity(Long ApiId, Integer bagNumber, String lotNumber, String consigneeName, String allocationConsignee, Integer nettWeight, Integer grossWeight, Long queueIncomingId, Long queueContainerStuffingId) {
this.ApiId = ApiId;
this.bagNumber = bagNumber;
this.lotNumber = lotNumber;
this.consigneeName = consigneeName;
this.allocationConsignee = allocationConsignee;
this.nettWeight = nettWeight;
this.grossWeight = grossWeight;
this.queueIncomingId = queueIncomingId;
this.queueContainerStuffingId = queueContainerStuffingId;
}
// Getter Setter
}
最佳答案
我认为您错过了 BagEntity.java 中的 @ForeignKey。 @ForeignKey 将连接两个表,因此如果有任何表更新,将触发实时数据。
第二件事是您的输出列表不是实时数据类型。您必须在 LiveData<List<QueueIncoming>>
等查询中更新输出列表
更新:您可以在您的 viewModel 中尝试这个 //先声明
private final MediatorLiveData<List<QueueIncoming>> mObservableProducts;
在dao调用后的构造函数中
mObservableProducts.addSource(products, new Observer<List<UserEntity>>() {
@Override
public void onChanged(@Nullable List<QueueIncoming> outputDaoList) {
mObservableProducts.postValue(outputDaoList);
}
});
然后在您的 View 模型中编写一个您可以从 Activity 中观察到的方法
public LiveData<List<QueueIncoming>> getAllList() {
return mObservableProducts;
}
关于java - 房间 : LiveData One To Many Relation,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56539762/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!