Silverlight实用窍门系列:74.Silverlight使用Perst数据库Demo

简介:

  Perst是一个简单、快速、便捷的面向Java和.Net的数据库。它可以直接将.net对象存储,在Silverlight不需要web service的方式进行读写,而是直接读写。

  本文将编写一个实例进行perst的操作,下载一个PerstSilverlight.dll,然后引用它。

  首先:在App.xaml.cs中Application_Startup()中建立Perst数据库的实例,在Application.Exit()中关闭Perst数据库。

        private void Application_Startup(object sender, StartupEventArgs e)
        {
            //应用程序开启时打开数据库
            Storage instanse = StorageFactory.Instance.CreateStorage();
            //初始化数据库文件为1M
            instanse.SetProperty("perst.file.extension.quantum", 1024 * 1024);
            //数据库大小不够时,每次增加512K
            instanse.SetProperty("perst.extension.quantum", 512 * 1024);
            instanse.Open("SLDemo.dbs");
            db = new Database(instanse);
            this.RootVisual = new MainPage();
        }

        private void Application_Exit(object sender, EventArgs e)
        {
            //应用程序关闭时关闭数据库连接
            db.Storage.Close();
        }

  其次:建立一个实体类继承于Persistent,定义为索引的字段必须设置为Public。

    /// <summary>
    /// 城市类
    /// </summary>
    public class City : Persistent
    {
        //定义为索引
        [FullTextIndexable]
        public string _CityName;

        /// <summary>
        /// 城市名称
        /// </summary>
        public string CityName
        {
            get { return _CityName; }
            set { _CityName = value; }
        }

        [FullTextIndexable]
        public string _CityNum;

        /// <summary>
        /// 城市电话区号
        /// </summary>
        public string CityNum
        {
            get { return _CityNum; }
            set { _CityNum = value; }
        }

        public override void OnLoad()
        {
            base.OnLoad();
        }

        //删除
        public override void Deallocate()
        {
            base.Deallocate();
        }
    }

  再次:实现前台界面的事件,并实现它。

    public partial class MainPage : UserControl
    {

        public MainPage()
        {
            InitializeComponent();

        }

        private void GetNum_1(object sender, RoutedEventArgs e)
        {
            BindCity();
        }

        /// <summary>
        /// 绑定所有的城市,并且按照CityNum排序
        /// </summary>
        private void BindCity()
        {
            List<City> list = App.db.Select<City>("order by CityNum").ToList();
            this.dgrid.ItemsSource = list;
        }

        /// <summary>
        /// 查找到021号码的区号对象并且删除
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void DeleteNum_2(object sender, RoutedEventArgs e)
        {
            City city = App.db.Select<City>("CityNum='021'").FirstOrDefault();
            city.Deallocate();
            App.db.Storage.Commit();
            BindCity();
        }

        /// <summary>
        /// 查找到020区号的对象进行修改
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void EditNum_4(object sender, RoutedEventArgs e)
        {
            City city = App.db.Select<City>("CityNum='020'").FirstOrDefault();
            city.CityName = "上海市";
            city.Store();
            App.db.UpdateFullTextIndex(city);
            BindCity();
        }

        /// <summary>
        /// 添加数据
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void AddNum_3(object sender, RoutedEventArgs e)
        {
            App.db.AddRecord(new City() { CityName = "广州", CityNum = "021" });
            App.db.AddRecord(new City() { CityName = "北京", CityNum = "010" });
            App.db.AddRecord(new City() { CityName = "上海", CityNum = "020" });
            App.db.AddRecord(new City() { CityName = "成都", CityNum = "028" });
            App.db.Storage.Commit();
        }
    }

  最后我们来看前台界面Xaml如下:

    <Grid x:Name="LayoutRoot" Background="White">
        <sdk:DataGrid Name="dgrid" HorizontalAlignment="Left" Height="181" 
                Margin="10,80,0,0" VerticalAlignment="Top" Width="338"/>
        <Button Content="增加数据" HorizontalAlignment="Left" Margin="42,10,0,0"
                VerticalAlignment="Top" Width="75" Click="AddNum_3"/>
        <Button Content="获取值" HorizontalAlignment="Left" Margin="160,10,0,0"
                VerticalAlignment="Top" Width="75" Click="GetNum_1"/>
        <Button Content="修改值" HorizontalAlignment="Left" Margin="42,48,0,0"
                VerticalAlignment="Top" Width="75" Click="EditNum_4"/>
        <Button Content="删除值" HorizontalAlignment="Left" Margin="160,48,0,0"
                VerticalAlignment="Top" Width="75" Click="DeleteNum_2"/>
    </Grid>

  下面是效果图片,如需源码请点击 SLPerstDemo.rar 下载。



本文转自程兴亮 51CTO博客,原文链接:http://blog.51cto.com/chengxingliang/974152

相关文章
|
7月前
|
SQL 数据库 微服务
微服务03,最简单的Demo,我们每个服务不能重复开发相同业务,微服务数据独立,不要访问其他微服务的数据库,微服务的特点之一是提供不能功能的数据库互相分割,微服务需要根据业务模块拆分,做到单一职责,
微服务03,最简单的Demo,我们每个服务不能重复开发相同业务,微服务数据独立,不要访问其他微服务的数据库,微服务的特点之一是提供不能功能的数据库互相分割,微服务需要根据业务模块拆分,做到单一职责,
|
8月前
|
Oracle Java 关系型数据库
[学习笔记] 在Eclipse中使用Hibernate,并创建第一个Demo工程,数据库为Oracle XE
[学习笔记] 在Eclipse中使用Hibernate,并创建第一个Demo工程,数据库为Oracle XE
|
9月前
|
存储 NoSQL 容灾
Neo4j【环境部署 01】图形数据库(简介+下载地址+安装+配置+demo源码+学习教程地址)
Neo4j【环境部署 01】图形数据库(简介+下载地址+安装+配置+demo源码+学习教程地址)
645 1
|
9月前
|
SQL 前端开发 Java
Hasor【环境搭建 01】SpringBoot集成Dataway接口配置服务(依赖+配置+数据库数据源初始化+注解添加+demo验证测试)
Hasor【环境搭建 01】SpringBoot集成Dataway接口配置服务(依赖+配置+数据库数据源初始化+注解添加+demo验证测试)
210 0
|
关系型数据库 MySQL 数据库
Qt+MySql开发笔记:Qt5.9.3的mingw32版本编译MySql8版本驱动并Demo连接数据库测试
之前特定的mysql版本msvc版本已经调通了,但是为了更好的跨平台,所以选择用mingw32版本,于是需要编译mysql驱动的mingw32版本的驱动库,以便提供给qt连接mysql使用。
Qt+MySql开发笔记:Qt5.9.3的mingw32版本编译MySql8版本驱动并Demo连接数据库测试
|
Java 关系型数据库 MySQL
【Java】Java连接Mysql数据库的demo示例
【Java】Java连接Mysql数据库的demo示例
305 0
【Java】Java连接Mysql数据库的demo示例
|
关系型数据库 MySQL 数据库连接
Qt+MySql开发笔记:Qt5.9.3的msvc2017x64版本编译MySql8.0.16版本驱动并Demo连接数据库测试
mysql驱动版本msvc2015x32版本调好, mysql的mingw32版本的驱动上一个版本编译并测试好,有些三方库最低支持vs2017,所以只能使用msvc2017x64,基于Qt5.9.3,于是本篇编译mysql驱动的msvc2017x64版本,满足当前的特定需求,这次过程有点费劲,可能是Qt的版本低于Qt5.12,继续无保留分享出来。   本篇主要描述Qt5.9.3 msvc2017x64 + mysql8.0.16的驱动编译过程。
|
1月前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
21天前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
120 42
|
12天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
67 25

热门文章

最新文章