随笔分类 - MS SQL Server
摘要:看过前一篇博文http://www.cnblogs.com/insus/archive/2013/04/21/3029483.html的网友,都大约知道,重构asp.net程序过程,使用了继承的方法。说实在的,Insus.NET不太喜欢在程序中使用继承。因为继承在应用,由于本身的原因,很多问题无法解决,或是运行自如。就如上一篇中,每个网页还是有很多相同的代码,无法拿掉。接下来,Insus.NET想使用接口方式重新对上一篇的原程序重新重构一次,望网友又能从中学习到其中一些开发知识。仔细看看App_Code目录下的Unitcode1 ~ UnitCode4个类别,均有相似之处。Insus.NET在
阅读全文
摘要:原程序,可以从下面地址下载:http://download.cnblogs.com/insus/ASPDOTNET/Ref_Org.rar数据库SQL Server 2008 R2,数据名为[Demo],它有四张表[UnitCode1], [UnitCode2], [UnitCode3], [UnitCode4],每个表有几个字段[Unit1~4],[Description],[CreateBy],[CreateDate],[UpdateBy],[UpdateDate],此四个表的主键分别为[Unit1],[Unit2],[Unit3]和[Unit4],其余字段名称四张表都一样。数据库还有各个
阅读全文
摘要:出现这个错误,是因为插入一个长度为0的值至有外键约束的字段内。我们来做个实验,并尝试解决它。首先创建两个表,[dbo].[T1]是主表,[dbo].[T2]是子表,而子表的[c2]是一个有外键约束的字段。View Code CREATE TABLE [dbo].[T1]( col1 NVARCHAR(20) PRIMARY KEY NOT NULL, col2 NVARCHAR(30) NULL, col3 NVARCHAR(30) NULL)GOCREATE TABLE [dbo].[T2]( c1 NVARCHAR(20) NOT NULL PRIMARY KEY,...
阅读全文
摘要:搜索介面如下:程序中需要实现如上的一个搜索功能。[Option]有两个选项,说明结果需要一个Detail或Summary。这是二选一,而且必选一个。[By]选择是让用户填入用户信息,或是选择部门。 当用户选择用户选择,在下出现文本框,让用户填入用户名;当用户选择部门时,在下出现下拉列表,让用户选择部门。[DateTime]选择,也有两种情况选择,一个是选择年月份的,默认是当前年份,用户选择年份之后,选择月份; 另一个选择日期,当选择日期选项,在下出现两个文本框,可输入开始与结束日期的,也可以选择。分析,总共6个选择,2种结果,4个条件(用户,部门,日期或月份),因此将有8个参数,这个8个参数为
阅读全文
摘要:以前写Ajax 的AutoCompleteExtender功能,都需要写WCF Service或是Web Service数据源。但一个系统中,很多文本框都想使用AutoComplete的功能。我们不可能写很多的Service,比如一些较小的数据。我们是否有一个可替换的方法呢?这是肯定的。下面的演示,Insus.NET以不用写Service来实现文本框的AutoCompete extender功能。首先从数据库获取数,你可以写SQL语句,或是写存储过程,以下是获取域用户信息,仿Outlook输入收件人效果。获取域信息,可参考:http://www.cnblogs.com/insus/archiv
阅读全文
摘要:有一个程序,是记录公司域用户打印记录,它使用的是MS Access database(A服务器 32bit)。想以这些记录做一些Summary报表,报表实现是另外一台服务器Intranet web 服务(B服务器 64bit)。如查在非一台服务器读取远端的Access数据,也许需要数据库文件共享。网管说不能在服务器安装32 bit的Ole 驱动,不也能共享A服务器的Access数据库文件。Insus.NET需要怎样做? 只有想法是把这些记录每天定时转存一次至公司的数据库(MS SQL Server 2008 R2)(C服务器)。写一个控制台应用程序,放在Access数据库同一目录,然后让A服务
阅读全文
摘要:参考MSDN的文章 http://msdn.microsoft.com/zh-cn/library/a6t1z9x2.aspx中所指的SqlDataSourceEnumerator类别,是应用程序在当前的网络中查找SQL Server实例。Insus.NET在演示中,是把找到的实例显示于DropDownList控件中。首先在.aspx拉一个DropDownList控件:View Code Server: <asp:DropDownList ID="DropDownListInstance" runat="server"></asp:Dr
阅读全文
摘要:又帮朋友完成一个小新闻站点,还是Visual Basic.NET的asp.net程序。.NET Framework 4.0数据库SQL 2008 R2它有后管理,默认的帐号为sa, 密码为12345678,可以更改密码,但默认管理员帐号不可更改,但可以添加另外管理员帐户。新闻管理,它使用CuteEditor_for_NET6文本编辑器。当然新闻的添加编辑以及删除功能一应具全。ASP连接数据库,请参考web.config语句。程序中有几好个用户控件,参考如下:首页有可播放Flash(.swf),有多屏图片切换,简单的导航条,你均可以定制它。数据库在源程序压缩包内的DB目录。源程序下载:http:
阅读全文
摘要:此段时间写的程序,一些功能均被朋友推翻,由静态的改为动态的。就如下面这个导航条,是参考下面这个来实现的:http://www.cnblogs.com/insus/archive/2011/08/18/2144041.html原本Insus.NET已经写好:代码如下:View Code <style type="text/css"> .fsoverstyle { border-color: #3599ff; } .divoverstyle { background-color: #3399ff; color: #fff; } ...
阅读全文
摘要:朋友要求,做一个多屏图片切换效果,以作为网站广告宣传。朋友提供样版参考http://www.lanrentuku.com/js/jiaodiantu-895.html刚开始听到此要求时,心想一定很简单照抄就行了。但是朋友还有进一步要求,是要在网站管理后统一管理,添加图片,链接以及标题。还能编辑这些信息。前台不必在每次更新时,去修改前台代码。即然朋友有此要求,Insus.NET照做就是了。首先看看效果(今年是蛇年,刚好Windows 8 Themes也有几张蛇图片,因此拿它来做例子了。)在数据库创建一个表,来存储相关信息,如图片名称,链接以及标题等:[dbo].[SwitchFocusNews]
阅读全文
摘要:某一些情况,我们开发时,不能以添加先后进行排序,也不能以某一字段进行升序或降序排序。只好让用户自己排序。此篇就是以此要求,进行演示的。数据表中,应有此排序的字段,可以根据记录的多少来定义它的数据类型,如INT等。数据的存储过程,应该应用到事务。以怕异常出现,而出现断序现象。在添加时,应该找到存在记录中,最大的序号,如第一次添加,即是说最大记录为空,那它的的值为1。在更新时,需要处理用户输入小于或等于 0值,它真正的值是1;而输入大于 最大排序号时,它应该于最大值。在删除时,应该是比被删除记录的排序号大的,都应该减1。Insus.NET实现的效果如下:创建数据表View Code SET ANS
阅读全文
摘要:此篇是分享一个视频站点程序,它算是第二个版本了,因为它是参考这个版本http://www.cnblogs.com/insus/archive/2012/12/14/2818650.html来修正一些Bug,或是添加一些功能。程序功能特点,它有母板页,有使用Ajax,DataList分页,搜索功能,前一版本是使用两个文本框,此版本使用单一文本框,都可以搜索到目录或是视频文件名,使用到用户控件,有使用到接口。可上传大视频文件。此版本还添加多视频截图功能,可添加与编辑。可惜它的播放组件是Media Player。它基本要求为.NET Framework 4.0,SQL Server 2008 R2。
阅读全文
摘要:如果使用DATENAME()函数是取得月份的英文全称,但报表需要,只需显示月份名称缩写即可。十二个月份的英文缩写,只有五月份是全称与缩写一样,其它月份的缩写仅是取前三位字母。因此Insus.NET写成一个自定义函数:-- =============================================-- Author: Insus.NET-- Create date: 2012-12-18-- Description: Get Month abbreviation name-- =========================================...
阅读全文
摘要:开发要求,前台一次性将多笔记录存入数据库中。也就是说,将一个DataTable作为一个参数传入。而数据库的存储过程,也得有一个表数据类型(sql2008) http://www.cnblogs.com/insus/articles/1916591.html为了实现这个功能,Insus.NET先从数据库,然后至程序前台,一步一步演示给大家。在数据库中创建一个表[Orders]:View Code CREATETABLE[dbo].[Orders]([Orders_nbr]INTIDENTITY(1,1)PRIMARYKEY,[ItemCode]NVARCHAR(50)NOTNULL,[UM]N.
阅读全文
摘要:开发过程中,Insus.NET经常性遇上一对多的数据关系,并需要存入数据中。就以下图为例,一个拉号可以对应多台机器。下图有三个铵钮,分别为[分配机器], [取消分配]和[查看分配]。想存储这些分配数据,需要在数据库创建一个表存储。LaHaoJiQi SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGO--=============================================--Author:Insus.NET--Createdate:2012-09-13--Description:存储拉号与机器分配记录--===================
阅读全文
摘要:从上面一个例子子窗口选择多值返回至父窗口的文本框中 中看到,用户看到的和选择的始终是友善的数据。我们不能可能选择的是名称,显示的是ID,或是存入数据库的是ID,显示的还是ID。下图是沿继上一例子,进入编辑状态。需要把存在数据库的数据显示出来。在子窗口的记录,把已经选择的值,还是实现Highlight出来。存在数据库中的数据,只是存入异常编码的ID,用";"分隔。现在我们要处理这个ID,转换为真实名称,并显示于编辑页面的文本框中。我们在数据库(本演示数据实例是SQL Server2012)中,写一个函数:View Code SETANSI_NULLSONGOSETQUOTED
阅读全文
摘要:近段时间开发的ERP系统,需要涉及至季度的一些日期。在系统中,实现了三个函数。获取某一天的所在季度的第一天:SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGO--=============================================--Author: Insus.NET--Createdate: 2012-08-24--Description:获取某一天所在季度的第一天。--=============================================CREATEFUNCTION[dbo].[udf_FirstDayOfQuart
阅读全文
摘要:为了理解这两个函数,可以先参考下面这两篇,http://www.cnblogs.com/insus/archive/2012/03/18/2404288.html和 http://www.cnblogs.com/insus/archive/2012/03/23/2415041.html可以获取在某一种排序下的某一记录的前一个值或后一个值。现sQL Server 2012带来这两个函数,可以方便简捷实现。下面Insus.NET创建了一张临时表,并随意插入几笔记录。CREATETABLE[#tsource]([id]int,[title]nvarchar(100))INSERTINTO[#tsou
阅读全文
摘要:MS SQL Server 2012有一个新函数,就是CONCAT函数,连接字符串非它莫属。比如在它出现之前,连接字符串是使用"+"来连接,如遇上NULL,还得设置参数与配置,不然连接出来的结果将会是一个NULL,可以参考:http://www.cnblogs.com/insus/articles/1938572.html如今,使用这个函数,遇上了NULL也能串连起来,如:SELECTCONCAT('ab',null,'cd')执行结果:你还可以这样用,与''字符串连在一起。SELECTCONCAT('ab',
阅读全文
摘要:以sql2012以前的版本,我们使用CONVERT尝试把某一个值转为某一个数据类型值时,当转换失败时,它会抛出异常。就以这篇为例,http://www.cnblogs.com/insus/archive/2012/08/11/2634131.htmlDECLARE@dNVARCHAR(20)=N'2012年08月12日14时36分48秒'SELECTCONVERT(DATETIME,@d)它会抛出如下异常消息:Msg 241, Level 16, State 1, Line 2Conversion failed when converting date and/or time
阅读全文