安卓SQLite数据库框架的设计.doc
文本预览下载声明
安卓SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。虽然ThinkPHP是为了简化企业级应用开发和敏捷WEB应用开发而诞生的。,ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进。 ?? DB_TYPE = mysql, // 数据库类型
DB_HOST = localhost, // 服务地址
DB_NAME = test, // 数据库名
DB_USER = liangdi, // 用户名
DB_PWD = *******, // 数据库密码
DB_PORT = 3306, //端口号?
1.2.3.数据库使用
要使用数据库,就必须给每张表生成一个表的模型,放在Model文件夹下,如数据库里有tp_user_info表,则要写以下的这个模形:
?php
namespace Common\Model;
use Think\Model;
class UserinfoModel extends Model{
//protected $connection=DB_CONFIG2;
protected $trueTableName = tp_user_info;
public function fetch_all(){
return $this-where(id0)-select();
}
public function fetch_by_id($id){
return $this-where(id = ?,$id)-select();
}
}
这个数据表类要继承Model,可以在里面定义数据表的名和主键字段以及字段数组,这里只用$trueTableName定义了表名。然后使用继承类Model里的where()和find()、select()等方法自定义自己想要的方法,比如fetch_by_id()方法定义了通过字段id的值返回查询结果。
接下来要在控制器里通过D()函数实例化上面的数据表类,并使用fetch_by_id()函数即可返回结果,如下所示:
?php
namespace Home\Controller;
use Think\Controller;
use Common;
class IndexController extends Controller {
public function index(){
$this-show(style type=text/css….,utf-8);
}
public function dbtest(){
$userinfo=D(Common/Userinfo);
$res=$userinfo-fetch_all();
$this-assign(usif,$res);
$this-display();
}
$userinfo=D(Common/Userinfo);工厂模式返回实例化的UserinfoModel类。$res=$userinfo-fetch_by_id(2);调用现在的主流移动设备像Android、iPhone等都使用SQLite作为复杂数据的存储引擎,在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上的SQLite开发技巧。对于Android平台来说,系统内置了丰富的API来供开发人员操作SQLite,我们可以轻松的完成对数据的存取。Activity的onCreate中的操作 ????@Override??
????protected?void?onCreate(Bundle?savedInstanceState)?{??
????????super.onCreate(savedInstanceState);??
??????????
????????//打开或创建test.db数据库??
????????SQL
显示全部