SQLServe Mobile数据库以前的版本是SQLServe CE,现在最新的是3.5的版本,最近用vs2008做了一个小程序,是对SQLServe Mobile数据库读写数据。

注:SQLServe Mobile数据库安装已经有人写过了,这里不再赘述。

1、界面是四个button按钮,分别是“插入数据”、“读取数据”、“删除数据”、“退出系统”和一个detagrid控件;两个textbox控件,方便录入插入的数据。

数据库文件时myDB.sdf  用SQL Server2008创建的,方法是:打开连接,服务器类型选择“SQL Server Compact
Edition”,数据库文件选择“创建新数据库”,然后根据提示创建数据库文件。需要注意的是,加密类型选择后两种,然后把数据库文件放到设备的NandFlash里(我测试用的设备是飞淩家的TE6410)。

项目中要引用“System.Data.SqlServerCe”,并且需要添加三个dll文件:sqlceme35.dll,sqlceqp35.dll,sqlcese35.dll,开发平台不安装SQLServe Mobile数据库是不能引用“System.Data.SqlServerCe”的,我安装的是英文版的Mobile数据库,这些文件在网上都能找到。

2、代码

public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
         /// <summary>
         /// 定义连接字符串
         /// </summary>
         ///
        public string connectionString = "Data Source=\\NandFlash\\myDB.sdf;Database Password=xxxxx;";
        private void button_Insert_Click(object sender, EventArgs e)
        {
            APP_function.CloseKeyBoard();//关闭软键盘
            string name = this.textBox_Name.Text;
            string pass = this.textBox_Pass.Text;
            SqlCeParameter[] sqlParameters=new SqlCeParameter[2];
            sqlParameters[0] = new SqlCeParameter("@Name", textBox_Name.Text);
            sqlParameters[1] = new SqlCeParameter("@Password", textBox_Pass.Text);
            string sqlCmd = "insert into userinfo (用户名,密码) values (@Name,@Password)";
            if (name != "" || pass != "")
            {
                APP_function.P_ExecuteNonQuery(sqlCmd,connectionString,ref sqlParameters);
                //更新datagrid
                string sqlUpdataCmd = "select * from userinfo order by ID";
                DataSet ds = new DataSet();
                APP_function.ExecuteDataset(sqlUpdataCmd, connectionString, out ds);
                dataGrid_Read.DataSource = ds.Tables[0];
                ifReadSelected = true;
                textBox_Name.Text = "";
                textBox_Pass.Text = "";
            }
            else
            {
                MessageBox.Show("插入的用户名和密码不能为空!");
           
            }
        }

private void button_Read_Click(object sender, EventArgs e)
        {
            string sqlCmd = "select * from userinfo order by ID";
            try
            {
                DataSet ds = new DataSet();
                APP_function.ExecuteDataset(sqlCmd, connectionString, out ds);
                dataGrid_Read.DataSource = ds.Tables[0];
                ifReadSelected = true;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.ToString());
            }
          
        }

/// <summary>
        /// 定义是否选择了读数据变量ifReadSelected
        /// </summary>
        public static bool ifReadSelected = false;
        private void button_Delete_Click(object sender, EventArgs e)
        {
            if (ifReadSelected)
            {
                //取得主键的值
                DataGridCell selectCell = dataGrid_Read.CurrentCell;
                int id = Convert.ToInt32(dataGrid_Read[selectCell.RowNumber, 0].ToString());
                string sqlCmd = "delete userinfo where ID='" + id + "'";
                APP_function.ExecuteNonQuery(sqlCmd, connectionString);
                //更新datagrid
                string sqlUpdataCmd = "select * from userinfo order by ID";
                DataSet ds = new DataSet();
                APP_function.ExecuteDataset(sqlUpdataCmd, connectionString, out ds);
                dataGrid_Read.DataSource = ds.Tables[0];
            }
            else
            {
                MessageBox.Show("请选择删除的行!","提示");
            }
        }
        private void textBox_Name_GotFocus(object sender, EventArgs e)
        {
            //打开键盘
            APP_function.OpenKeyBoard();
        }

private void textBox_Pass_GotFocus(object sender, EventArgs e)
        {
            //打开键盘
            APP_function.OpenKeyBoard();
        }
        private void button_Exit_Click(object sender, EventArgs e)
        {
            this.Close();
            Application.Exit();
        }
    }

3、APP_function是另外一个类文件,其中定义了需要的功能函数,代码如下:

public partial  class APP_function
    {
       /// <summary>
       /// 打开、关闭软键盘
       /// </summary>
        public static uint SIPF_OFF = 0x00;//软键盘关闭 
        public static uint SIPF_ON = 0x01;//软键盘打开 
        [DllImport("coredll.dll")]
        public extern static void SipShowIM(uint dwFlag);
        public static void OpenKeyBoard()
        {
            SipShowIM(SIPF_ON);
        }
        public static void CloseKeyBoard()
        {
            SipShowIM(SIPF_OFF);
        }
       /// <summary>
       /// 向数据库插入、更新、删除数据(不带参数)
       /// </summary>
       /// <param name="sqlCmd">命令字符串</param>
       /// <param name="connectionString">连接字符串</param>
       ///
        public static void ExecuteNonQuery(string sqlCmd, string connectionString)
        {
            using (SqlCeConnection conn=new SqlCeConnection(connectionString))
            {
                try
                {
                    using (SqlCeCommand cmd = new SqlCeCommand(sqlCmd, conn))
                    {
                        conn.Open();
                        cmd.CommandType = CommandType.Text;
                        cmd.ExecuteNonQuery();
                    }
                }
                catch (Exception e)
                {
                    MessageBox.Show(e.ToString(),"提示");
                }
                finally
                {
                    conn.Close();
                }
            }
        }
        /// <summary>
        /// 带参数向数据库插入、更新、删除数据
        /// </summary>
        /// <param name="sqlCmd">命令字符串</param>
        /// <param name="connectionString">连接字符串</param>
        ///
        static public void P_ExecuteNonQuery(string sqlCmd,string connectionString,ref SqlCeParameter[] sqlParameters)
        {
            using (SqlCeConnection conn = new SqlCeConnection(connectionString))
            {
                try
                {
                    using (SqlCeCommand cmd = new SqlCeCommand(sqlCmd, conn))
                    {
                        conn.Open();
                        cmd.CommandType = CommandType.Text;
                        for (int i = 0; i < sqlParameters.Length;i++ )
                        {
                            cmd.Parameters.Add(sqlParameters[i]);
                        }
                        cmd.ExecuteNonQuery();
                    }
                }
                catch (Exception e)
                {
                    MessageBox.Show(e.ToString(), "提示");
                }
                finally
                {
                    conn.Close();
                }
            }
        }

/// <summary>
        /// 查询数据库,返回dataset
        /// </summary>
        /// <param name="sqlCmd">命令字符串</param>
        /// <param name="connectionString">连接字符串</param>
        /// <param name="connectionString">连接字符串</param>
        ///
        public static void ExecuteDataset(string sqlCmd, string connectionString, out DataSet ds)
        {
            ds = new DataSet();
            using(SqlCeConnection conn=new SqlCeConnection(connectionString))
            {
                try
                {
                    using(SqlCeDataAdapter da=new SqlCeDataAdapter())
                    {
                        da.SelectCommand = new SqlCeCommand(sqlCmd, conn);
                        da.Fill(ds);
                    }
                }
                catch (Exception e)
                {
                    MessageBox.Show(e.ToString());
                }
                finally
                {
                    conn.Close();
                }
            }
        }
    }

基于wince系统开发的 SQLServe Mobile数据库应用的更多相关文章

  1. 初试 Windows XP Embedded 系统开发1

    目前 Windows PE(Preinstallation Environment)和 Windows XP Embedded 是可以脱离主机里的硬盘独立运行的 Windows 操作系统,Window ...

  2. WinCE的开发流程

    总的来说,WinCE的开发是分为: 一.硬件开发:硬件设计,Boot Loader开发,OAL开发,BSP开发二.操作系统开发:定制驱动,创建最小内核,定制操作系统组件,测试集成三.应用程序开发:开发 ...

  3. 【Android 系统开发】 编译 Android文件系统 u-boot 内核 并烧写到 OK-6410A 开发板上

    博客地址 : http://blog.csdn.net/shulianghan/article/details/40299813  本篇文章中用到的工具源码下载 : -- ok-6410A 附带的 A ...

  4. 基于SSH框架的网上书店系统开发的质量属性

    基于SSH框架的网上书店系统开发的质量属性 对于我的基于SSH框架的网上书店系统的开发要实现的质量属性有可用性.可修改性.性能.安全性.易用性和可测试性. 1.对于可用性方面的战术: 可用性(Avai ...

  5. 基于JSP+Servlet开发手机销售购物商城系统(前台+后台)源码

    基于JSP+Servlet开发手机销售购物商城系统(前台+后台) 开发环境: Windows操作系统 开发工具:Eclipse/MyEclipse+Jdk+Tomcat+MySQL数据库 运行效果图: ...

  6. 基于C/S架构的3D对战网络游戏C++框架 _05搭建系统开发环境与Boost智能指针、内存池初步了解

    本系列博客主要是以对战游戏为背景介绍3D对战网络游戏常用的开发技术以及C++高级编程技巧,有了这些知识,就可以开发出中小型游戏项目或3D工业仿真项目. 笔者将分为以下三个部分向大家介绍(每日更新): ...

  7. 基于ssh框架开发的购物系统的质量属性

    根据前面的博客,我们已经大致了解了ssh架构开发整体概念:Struts是一个实现了MVC模式的经典的框架:Hibernate是轻量级Java EE应用的持久层解决方案,以面向对象的方式提供了持久化类到 ...

  8. Atitit  基于meta的orm,提升加速数据库相关应用的开发

    Atitit  基于meta的orm,提升加速数据库相关应用的开发 1.1. Overview概论1 1.2. Function & Feature功能特性1 1.2.1. meta api2 ...

  9. 开发一个基于 Android系统车载智能APP

    很久之前就想做一个车载相关的app.需要实现如下功能: (1)每0.2秒更新一次当前车辆的最新速度值. (2)可控制性记录行驶里程. (3)不连接网络情况下获取当前车辆位置.如(北京市X区X路X号) ...

随机推荐

  1. com.github.pagehelper.PageHelper cannot be cast to org.apache.ibatis.plugin.Interceptor

    在MyBatis的配置文件中修改对pageHelper的配置修改前 <plugins> <plugin interceptor="com.github.pagehelper ...

  2. python27期day03:字符串详解:整型、可变数据类型和不可变数据类型、进制转换、索引、切片、步长、字符串方法、进制转换、作业题。

    1.%s: a = "我是新力,我喜欢:%s,我钟爱:%s"b = a%("开车","唱跳rap")print(b)2.整型: 整数在Pyt ...

  3. Slack完整教学与上手心得:找到正确的团队沟通之道

    Slack完整教学与上手心得:找到正确的团队沟通之道 时间 2015-06-13 09:21:42 逐鹿网 原文  http://www.zhulu.com/article/5519.html 主题 ...

  4. 【Spring AOP】通知(五)

    一.通知介绍 1. 前置通知(Before) 在目标方法执行之前执行的通知. 前置通知方法,可以没有参数,也可以额外接收一个JoinPoint,Spring会自动将该对象传入,代表当前的连接点,通过该 ...

  5. 解决 SpringMVC 非spring管理的工具类使用@Autowired注解注入DAO为null的问题

    在SpringMVC框架中,我们经常要使用@Autowired注解注入Service或者Mapper接口,我们也知道,在Controller层中注入service接口,在service层中注入其它的s ...

  6. 在分页中,删除操作后,AJAX重载刷新当前页

    需求 分页中,在 删除 和 编辑 完成后,AJAX重载刷新 当前页 ,而不是跳转到 第一页 实现步骤 添加两个的 input 控件,用来存储 当前页数 和 记录总条数(非必须,能有方法获取到这两个值即 ...

  7. 复杂模拟 | 1095 模拟N个学生有K个志愿填M个学校

    妈的智障 #include <stdio.h> #include <memory.h> #include <math.h> #include <string& ...

  8. Java解决方案

    1.新建模板类提示版本太低 Syntax error, type parameters are only available if source level is 1.5 当我的eclipse使用jd ...

  9. [HNOI2012]集合选数(构造,状态压缩,DP)

    神仙题. 莫名其妙的就试一试把所有数放进一个类似矩阵的东西里面. 首先把 \(1\) 放到左上角,然后在每个数的右边放它的 \(3\) 倍(大于 \(n\) 就不用放了),下面放它的 \(2\) 倍( ...

  10. [探究] [Luogu4550]收集邮票的概率意义

    自认为这道题是一道比较简单的扩展题--?此处采用了和别的题解思路不同的,纯概率意义上的解法. 首先考虑一个简化版问题: 每次随机一个\([1,n]\)的整数,问期望几次能凑出所有数 这东西我写过一个b ...