Mysql+IIS+三层架构创建网站遇到的过程总结

2024-09-05 02:18

本文主要是介绍Mysql+IIS+三层架构创建网站遇到的过程总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.三层架构的创建

1)添加新项,添加类库:实体,业务逻辑,数据库访问,并将新创建的类库添加到网站的引用。

2)为实体类库设置属性,并设置set和get方法。

3)为数据库访问类库新建Connection和DataService类,其中Connection类中包含了数据库连接字符串成员变量以及设置方法,DataService类是数据库操作类,包含了各种数据库的操作,在DataService类库中新建类SQLHelper类,SQLHelper类实现了数据库的增删改查的基本操作。

注:SQLHelper类的函数的参数的形式,一般为要执行的sql语句,以及包含了sql语句中参数的参数值的sqlparameters数组,在SQLHelper类中的函数中,将sqlparameter数组中的参数值赋值到sql语句中的形参中构造真正的sql语句

注:sqlparameter的用法:

       1)strSql = "select * from database where id=@id"

           1.1)SqlParameter para = new SqlParameter("@id",SqlDbType.Int,10),有三个参数,@id是sql语句中的形参,形参的数据类型,长度

           1.2)SqlParameter[]  para = new SqlParameter{         new SqlParameter("@id",SqlDbType.Int,10),new SqlParameter("@name",SqlDbType.String,10).....                    }

                   para[0].Value = ...,para[1].Value = ...

       cmd.Parameter.AddRange(para);                   //为sql语句中的形参赋值

4)SQLHelper类中的函数的返回值设为DataSet或者table,然后在DataService类库从数据源中取出数据,并赋值给实体的相应属性,然后返回已经赋值过的实体。从DataSet对象中取出数据的过程:

for(int i = 0;i < ds.Table[0].Rows; ++i){//User为实体集的实例User[i].username = ds.Table[0].Row[i][2].ToString();
}                
遇到的问题:

1)Mysql服务无法启动。解决:运行MysqlInstaller,修复并重启Mysql服务

2)为项目添加了对类库的引用,却依然提示缺少using。解决:出现这种问题的原因,是因为尚未生成解决方案就直接在浏览器中查看,先生成解决方案然后再查看。若出现对代码等的修改,也要先生成解决方案再查看结果。

3)在浏览器中查看网页的时候提示错误:You have an error mysql synax。。。解决:sql语句语法错误,修改sql语句构造的

二,返回受影响的行数

SqlConnection con = new SqlConnection("连接字符串");con.Open();SqlCommand cmd = new SqlCommand("select * from Table where ..",con); SqlDataApdater da=new SqlDataApdater (cmd);DataTable dt=new DataTable();da.Fill(dt);//影响的行数int count=dt.Rows.Count;con.Close();

//

遇到的问题:

1)在查询并返回表的前n条记录的时候,一直提示sql语句语法错误。解决:Mysql和SqlServer在查询前N条记录的时候语法不相同,若是Mysql,语法不是select top n * from table

2)将查询到的数据保存到DataReader对象中后,在从DataReader对象中读取数据的时候,如果超出数据的记录数会提示错误,如select top 10 * from table但是table中只有5条记录,这样在读取数据的时候,读取到第六条的时候会报错。解决:换成DataSet对象来保存数据,DataSet对象有Rows.Count成员可以得到记录的总数

3)在讲数据库中的float类型数据取出并复制给对象的成员变量的时候,如float.parse(dataset.Tables[0].Rows[0][0].ToString())会报错,原因是若数据库中该条记录对应的该列的数据为NULL,在转换为float类型的时候会报错


这篇关于Mysql+IIS+三层架构创建网站遇到的过程总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137689

相关文章

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安