Access数据库问题锦集

简介:

很少采用Access做数据库开发,前段时间,朋友接了一个小单,让我帮忙做后台开发,采用Access + Asp.Net开发,结果在开发过程使用Access碰到不少问题,所以把这些问题总结一下,希望对其它人有些帮助

1: Access 分页脚本问题

使用Access作为数据库开发系统时,页面数据分页的方案有好几种:

    1.1  使用DataGridView自带的分页功能.

    1.2.  使用SELECT TOP  NOT IN 来实现。类似如下所示:

 

SELECT TOP 100

        [ID] ,

        [Message] ,

        [CreateDate]

FROM    ScrollMessage

WHERE   ID NOT IN ( SELECT TOP 900

                            ID

                    FROM    ScrollMessage

                    ORDER BY ID )

ORDER BY ID

     1.3.使用嵌套的TOP结合分页控件AspNetPager来实现

     1.4. 设置一个自增长字段.并且该字段为INDEX.(网上有方案,我没有研究过这种方案)

其实上面几种方案中,我觉得效率最高的应该是使用TOP嵌套方案(特别是当数据量大的时候),也是我下面将要讲解的。 如下图所示:假设有些滚动信息需要分页显示,则我们可以这样处理

 

 

 

 

 

 

 

 

 

 

1.1 解决Access 分页,首页或最后一页数据显示错误、混乱问题

 

/// <summary>

        /// 分页获取滚动消息数据

        /// </summary>

        /// <param name="pageSize">一页显示数据条数</param>

        /// <param name="curPageSize">当前页的数据在所有数据中位置(排序)</param>

        /// <param name="condition">查询条件</param>

        /// <returns>返回当前条件下的滚动消息</returns>

        public DataTable GetScrollMessage(int pageSize, int curPageSize, string condition)

        {

            string cmdText = string.Format(@"SELECT * FROM

                                               (SELECT TOP {0} * FROM

                                                (

                                                    SELECT TOP {1}  ID,  Message,CreateDate

                                                    FROM ScrollMessage

                                                    WHERE 1=1 {2}

                                                    ORDER BY ID DESC

                                                ) T

                                                 ORDER BY T.ID ASC   

                                                ) TT ORDER BY TT.ID DESC;        

                                        ", pageSize, curPageSize, condition);

 

 

            return DbHelper.ExecuteDataSet(cmdText).Tables[0];

 

        }


private void BindGridView()
    {
        // 当前页数据显示个数
        int pageSize = AspNetPager1.PageSize;

        // AspNetPager 控件中当前显示的页
        int pageIndex = AspNetPager1.CurrentPageIndex;
        int curPageSize = 0;
        MessageMangent module = new MessageMangent();

        //设置AspNetPager 的RecordCount属性
        AspNetPager1.RecordCount = module.GetScrollMessageCount("");

        if (pageIndex == AspNetPager1.PageCount)
        {
            pageSize = AspNetPager1.RecordCount - (pageIndex - 1) * pageSize;

            if (curPageSize == 0)
                curPageSize = AspNetPager1.RecordCount;

        }
        else
        {
            curPageSize = pageSize * pageIndex;
        }

   

        DataTable dtDataSource = module.GetScrollMessage(pageSize, curPageSize, "");

        gvMessage.DataSource = dtDataSource;
        gvMessage.DataBind();
    }
上面代码已经能解决分页数据错乱问题,但是其实里面还有个隐藏的bug,就是当数据表没有任何记录时,它会报错 :“SELECT 子句中包含一个保留字、拼写错误或丢失的参数,或标点符号不正确”。 可能有些人被这个人弄得莫名其妙,其实主要是TOP 0引起的, 你用SELECT TOP 0 * FROM A去查询设计里面执行下,就会弹出那个错误提示。所以要修改下上面的代码如下:
private void BindGridView()
    {
        // 当前页数据显示个数
        int pageSize = AspNetPager1.PageSize;

        // AspNetPager 控件中当前显示的页
        int pageIndex = AspNetPager1.CurrentPageIndex;
        int curPageSize = 0;
        MessageMangent module = new MessageMangent();

        //设置AspNetPager 的RecordCount属性
        AspNetPager1.RecordCount = module.GetScrollMessageCount("");

        if (pageIndex == AspNetPager1.PageCount)
        {
            pageSize = AspNetPager1.RecordCount - (pageIndex - 1) * pageSize;

            if (curPageSize == 0)
                curPageSize = AspNetPager1.RecordCount;

        }
        else
        {
            curPageSize = pageSize * pageIndex;
        }

        if (curPageSize == 0 && pageSize == 0)
        {
            curPageSize = 1;
            pageSize = 1;
        }


        DataTable dtDataSource = module.GetScrollMessage(pageSize, curPageSize, "");

        gvMessage.DataSource = dtDataSource;
        gvMessage.DataBind();
    }
1.2 SELECT TOP 失效问题,比如只需前十条记录,结果它给你查出了所有记录。这主要是查询TOP语句的后面使用Order by,而且Order by字段中有重复值的话,那么这个TOP很会失效而会返回所有记录,所以Order by后面最好用主键字段。我又一次就是犯了这个错误,查询语句如下所示,本来工作好好的,但是由于客户需求,把CreateDate字段从yyyy-MM-dd HH:mm 改成yyyy-MM-dd 结果排序全部混乱了。
string cmdText = string .Format(
                                @"SELECT * FROM 
                                (
                                    SELECT TOP {0} * 
                                    FROM (
                                            SELECT TOP {1} * FROM  Images I
                                            INNER JOIN BaseImgPage P ON I.PageID = P.PageID AND I.SubType = P.SubType 
                                            WHERE I.PageID =@PageID AND I.SubType=@SubType" + searchCondtion + @"
                                            ORDER BY CreateDate ASC
                                    ) ORDER BY CreateDate DESC
                                )  ORDER BY ImageSortNum DESC;", pageSize, curpageSize);


2 关键字问题,像password等,这样网上介绍很多了,想必大家都比较了解。这里就不多说了

3 错误提示"操作必须使用一个可更新的查询",部署到服务器上,插入或更新数据时,有时会爆出这样的错误

      1.Win 2000/ Win 2003 系统,在数据库文件上(*.mdb)点鼠标右键,选择属性,点安全,查看是否存在everyone用户,如果没有,添加everone用户,勾选"完全控制".

     2.Win XP 系统,打开 data 文件夹,点击“工具”->“文件夹选项”->“查看”,找到“使用简单文件共享(推荐)”这项,把前面的勾去掉。然后在数据库文件上 (*.mdb)点鼠标右键,选择属性,点安全,查看是否存在everyone用户,如果没有,添加everone用户,勾选"完全控制".


相关文章
|
数据库
如何在web.config文件中配置连接Access数据库?
如何在web.config文件中配置连接Access数据库?
99 0
|
18天前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
51 11
|
6月前
|
SQL 关系型数据库 MySQL
云服务器 ECS产品使用问题之出现“1044 - Access denied for user ‘root‘@‘%‘ to database ‘数据库名称‘”这样的错误,该怎么办
云服务器ECS(Elastic Compute Service)是各大云服务商阿里云提供的一种基础云计算服务,它允许用户租用云端计算资源来部署和运行各种应用程序。以下是一个关于如何使用ECS产品的综合指南。
|
8月前
|
SQL XML 存储
Microsoft Access 是微软公司开发的关系型数据库管理系统(
【5月更文挑战第14天】Microsoft Access 是微软公司开发的关系型数据库管理系统(
101 1
|
8月前
|
SQL 存储 数据可视化
access sql 数据库,Access SQL
access sql 数据库,Access SQL
|
8月前
|
Java 数据库连接 数据库
Windows7 64位 连接Access数据库“未发现数据源名称并且未指定默认驱动程序“的解决办法
Windows7 64位 连接Access数据库“未发现数据源名称并且未指定默认驱动程序“的解决办法
1097 0
|
8月前
|
开发框架 安全 .NET
某教程学习笔记(一):07、数据库漏洞(access注入)
某教程学习笔记(一):07、数据库漏洞(access注入)
58 0
|
关系型数据库 MySQL 数据库连接
root用户数据库连接出现错误号码**** Access denied for ‘root‘@‘IP‘(using password:YES)
root用户数据库连接出现错误号码**** Access denied for ‘root‘@‘IP‘(using password:YES)
74 0
|
SQL 数据库连接 数据库
在VS2013平台下,用VB.net 连接Access数据库
从开始学习计算机,我们使用的一直是SQL数据库。这次接触了Access数据库,我将从Access创建到连接向大家分享一下我在Access数据库中的收获。
263 0
|
SQL 安全 Oracle
MySQL&SQL server&Oracle&Access&PostgreSQL数据库sql注入详解
MySQL&SQL server&Oracle&Access&PostgreSQL数据库sql注入详解
470 0

热门文章

最新文章