Xamarin.android的Sqlite数据库原来是这么用的?
程序员文章站
2022-06-22 17:27:06
初次接触Xamarin.android,尝试开发一个APK,其实入门的教程在微软官方有一大部分,不过关于数据库这块还是看得不知所云android自带sqlite数据库模块,但是这个引用Visual Studio 2019中好像是没有的(还是我没找到?)NuGet中下载Mono.Data.Sqlite.Portable安装即可本来以为很简单的操作,其实不然,下面写个类连接数据库:public class clsSqlite { private SqliteConnec...
初次接触Xamarin.android,尝试开发一个APK,其实入门的教程在微软官方有一大部分,不过关于数据库这块还是看得不知所云
android自带sqlite数据库模块,但是这个引用Visual Studio 2019中好像是没有的(还是我没找到?)
NuGet中下载Mono.Data.Sqlite.Portable安装即可
本来以为很简单的操作,其实不然,下面写个类连接数据库:
public class clsSqlite
{
private SqliteConnection m_dbConnection;
public clsSqlite()
{
string dbPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal),"data.db");
m_dbConnection = new SqliteConnection(string.Format("Data Source={0};Version=3;",dbPath));
m_dbConnection.Open();
}
public bool test()
{
string sql = "select count(id) from [login]";
try
{
SqliteCommand command = new SqliteCommand(sql, m_dbConnection);
object obj = command.ExecuteScalar();
return true;
}
catch(Exception ex) {
return false;
}
}
public void Close()
{
m_dbConnection.Close();
}
}
因为dbPath输出的是类似路径,这个路径应该就是SD的目录
/data/user/0/com.companyname.app6/files/data.db
所以我在工程目录新建了files目录,把data.db放了进去,但是提示找不到数据表
后来百度一番,好像是要把数据库复制到SD目录
private void dbImport()
{
string dbPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal), "data.db");
try
{
if (!File.Exists(dbPath))//不存在,拷贝raw中的data.db到SD卡目录
{
Stream stm = Resources.OpenRawResource(Resource.Raw.data);
FileStream outfile = new FileStream(dbPath, FileMode.OpenOrCreate, FileAccess.Write);
byte[] buffer = new byte[1024];
int count = 0;
while ((count = stm.Read(buffer)) > 0)
{
outfile.Write(buffer, 0, count);
}
outfile.Close();
stm.Close();
}
//else
// File.Delete(dbPath);
}
catch (Exception e)
{
Toast.MakeText(ApplicationContext.ApplicationContext,"复制数据库失败",ToastLength.Short);
}
}
这里需要注意,如果你已经运行过连接数据库文件的操作,但SD文件不存在,Android会默认生成一个空的数据库文件,所以可以先检测一下文件是否存在,如果存在,先把原来的空数据库文件删除
本文地址:https://blog.csdn.net/rztyfx/article/details/107985755
上一篇: 为什么要查找oom
下一篇: MySQL学习11_表连接
推荐阅读
-
Windows 8 Metro用C#连接SQLite及创建数据库,数据表的增删改查的实现
-
Windows 8 Metro用C#连接SQLite及创建数据库,数据表的增删改查的实现
-
怎么用java语言查询读出一个SQLite数据库文件中的数据?
-
Xamarin.android的Sqlite数据库原来是这么用的?
-
怎么用java语言查询读出一个SQLite数据库文件中的数据?
-
[代码实例][C语言][sqlite3]用SQL语句查询数据库的实例
-
Xamarin.android的Sqlite数据库原来是这么用的?
-
使用scrapy框架,用模拟浏览器的方法爬取京东上面膜信息,并存入mysql,sqlite,mongodb数据库