Android SQLite 用のstorm-gen ORM を使用していて、生の SQL クエリを実行したいと考えています。基になる SQLiteDatabase クラスにアクセスするにはどうすればよいですか?
2 に答える
3
生成された DAO から利用できる DatabaseHelper クラスを介して、基礎となる SQLite データベースにアクセスできます。
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
David's answer を参照すると、注釈生成が storm-gen で機能するように、gradle ファイルを機能させるために Android studio プロジェクトで storm-gen lib をセットアップする際に問題が発生する可能性があります。
android studio と storm-gen を使用して 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 Central Repository にプッシュされたので、簡単にインポートして使用できます。いいえ、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 に答える