我正在使用Storm-gen ORM for Android SQLite 并希望运行原始 SQL 查询。如何访问底层 SQLiteDatabase 类?
问问题
335 次
2 回答
3
您可以通过 DatabaseHelper 类访问底层 SQLite 数据库,该类可从生成的 DAO 中获得:
ContactDao dao = new ContactDao(this);
SQLiteDatabase db = dao.getDbHelper(this).getReadableDatabase();
// SELECT DISTINCT Locale FROM PALABRA
Cursor c = db.query(...);
您还可以在 DatabaseHelper 类上调用 getWriteableDatabase(),这样做是安全的,因为storm-gen 使用底层 SQLiteDatabase 的单例实例。
于 2014-03-19T03:24:52.077 回答
1
参考大卫的回答,您可能会在 Android Studio 项目中设置storm-gen lib 以使gradle 文件正常工作,以便注释生成适用于storm-gen。
如果您想使用带有storm-gen的android studio运行helloworld程序,请考虑这个解决方案
代码:
import android.support.v7.app.ActionBarActivity;
import android.support.v7.app.ActionBar;
import android.support.v4.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.os.Build;
import com.example.stormtestlib.Person;
import com.example.stormtestlib.TestingDB;
public class MainActivity extends ActionBarActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (savedInstanceState == null) {
getSupportFragmentManager().beginTransaction()
.add(R.id.container, new PlaceholderFragment())
.commit();
}
TestingDB tt = TestingDB.getInstance(this);
Person p = tt.getPerson(this);
p.setMyString("blah blah");
tt.savePerson(this);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
switch (item.getItemId()) {
case R.id.action_settings:
return true;
}
return super.onOptionsItemSelected(item);
}
/**
* A placeholder fragment containing a simple view.
*/
public static class PlaceholderFragment extends Fragment {
public PlaceholderFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_main, container, false);
return rootView;
}
}
}
来源:github 信用:Maia
更新:
Storm-gen 刚刚被推送到Maven 中央存储库,因此您可以轻松导入和使用它。不,我们可以将它与 Gradle build.gradle 一起使用
// Top-level build.gradle
buildscript {
repositories {
mavenCentral()
}
dependencies {
classpath 'com.android.tools.build:gradle:0.11.+'
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.3'
}
}
allprojects {
repositories {
mavenCentral()
}
}
// app module build.gradle
apply plugin: 'android'
apply plugin: 'android-apt'
android {
compileSdkVersion 19
buildToolsVersion "19.1.0"
defaultConfig {
applicationId "com.turbomanage.storm.sample"
minSdkVersion 10
targetSdkVersion 19
versionCode 1
versionName "1.0"
}
buildTypes {
release {
runProguard false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
}
dependencies {
apt 'com.turbomanage.storm:storm-impl:0.98'
compile 'com.android.support:appcompat-v7:19.1.0'
compile 'com.android.support:support-v4:19.1.0'
compile 'com.turbomanage.storm:storm-api:0.98'
}
信用:盖莱克斯
于 2014-03-19T07:44:11.943 回答