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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、