前言:数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,用户可以对文件中的数据进行增、删、改、查。数据库有很多种类型,从简单的存储有各种数据的表格到能都进行海量数据存储的大型数据库系统都在各个方面都到了广泛的应用。在信息化社会,充分有效地管理和利用各类信息资源,是进行科学研究和决策管理的前提条件。数据库技术是管理信息系统、办公自动化系统、决策支持系统等各类信息系统的核心部分,是进行科学研究和决策管理的重要技术手段。这节课主要讲解SQL数据库。

内容

  1.SQL Server 2008安装教程参考:http://blog.csdn.net/mingxuanyun/article/details/7752259

  2.在新建数据库时,数据库最好以英文单词来命名,增强代码的可读性,并且各英文单词首字母大写。

  3.在新建表时,最好让表有一个自增的主键。

  4.数据库是运行在SQL Server(MSSQLSERVER)服务上的,若在删除某数据库时出现“该数据库正在被占用”的错误,则可以把该服务重启一下即可。重启该服务可以做应急处理。

  5.如果修改一个表的时候弹出不让修改的提示,可以选择工具->选项->Designers->表设计器和数据库设计器,将其下面的“阻止保存要求重新创建表的修改”前面的对号去掉即可。

  6.可以用可视化的方式创建数据库,也可以用SQL语句来进行创建。

  7.数据库中的布尔类型用bit来表示。

  8.char/nchar/varchar/nvarchar:char(10)表示能存放10个字符,5个汉字,定长,如果只放了一个字符则后面有九个空格,这种方式的存储容易造成浪费,所以很少使用;nchar(10)表示能放10个中文,也是定长的存储方式,也很少使用;varchar(10)能存放5个中文,变长,根据内容的长度来存储,不会造成空间的浪费,是比较常用的方式;nvarchar(10)表示可以放10个中文,变长,用的相对较多。

  9.SQL语句是不区分大小写的,且其字符串是单引号,不是双引号。

  10.常见的SQL语句用法:

    (1)create database Library  //创建数据库

          go

      use Library

      go

    (2)create table Users  //创建表

     {

      UID int primary key,

      userAge int not null,

      userName nvarchar(20) not null,

      userPwd nvchar(20) not null

     }

    (3)select语句

    select * from Users  //查询出Users表里面的所有信息

        select UID,userName from Users  //查询出Users表里面所有的UID,userName

      select * from Users where UID=3  //查询出Users表里面UID=3的所有信息

    select * from Users order by userAge asc  //默认是asc(可以不写)从小打到,desc是从大到小

    select * from Users where userName = 'zoe' and userAge = 20

    select * from Users where UID in (2,3,4)  //查询出Users表中的UID为2,3,4的所有信息

    select * from Users where userAge between 20 and 30 order by userAge  //查询出Users表中userAge在20到30之间的所有信息,并且按照userAge从小到大排序,同样也可以写成:select * from Users where userAge > 20 and  userAge <30 order by userAge

    select * from Users where userName like 'z%'  //查询出Users表中userName里面第一个字母是z的所有人信息

    select * from Users where userName like '%z%'  //查询出Users表中userName里面包含z的所有人信息

    select * from Users where userName like '%z'  //查询出Users表中userName里面最后一个字母是z的所有人信息

    select top 3* from Users order by userAge desc  //查询出年龄最大的三个用户

    select top 3 userName from Users order by userAge desc  //查询出年龄最大的三个用户的姓名

    select count(*) from Users  //查询出Users表中的所有记录数

    select count(*)  as UserCount from Users  //查询出Users表中的所有记录数,并将该列命名为UserCount

    select count(*) as UserCount, userAge from Users group by userAge  //通过userAge分组查询出Users表中的所有记录数,并将该列命名为UserCount

    select count(*) as UserCount, userAge from Users group by userAge having count(*)>2  //分组查询出表中记录数大于2的组,group by 和having配合使用,不能再使用where条件

    select min(userAge) from Users  //查询出Users表中userAge最小的记录

    select max(userAge) from Users  //查询出Users表中userAge最大的记录

    select avg(userAge) from Users  //查询出Users表中userAge的平均值

    select sum(userAge) from Users  //查询出Users表中userAge的总和

    select * from Users where userAge > (select avg(userAge) from Users)  //查询userAge大于平均userAge的所有记录

    (4)连接:inner join on,left join on, right join on

    select SI.StuId,SI.StuName,SI.ClassName,PE.FatherName,PE.MotherName from StuInfor SI left join Parent PE on SI.StuId=PE.StuId  //左关联,表示以左表为基准来查询,即上面的StuInfor,左表的记录将会全部表示出来,而右表(Parent)只会显示符合搜索条件的记录。同理可以理解right join on。inner join on并不以哪个表为基准,只显示符合条件的记录。项目中一般有三个表就行了,四个表或以上联合查询的效率很低下。

后记:大概了解了怎么用,基本的语句都是懂的,只能在实战中多使用了。

ASP.NET动态网站制作(15)-- SQL数据库(1)的更多相关文章

  1. ASP.NET动态网站制作(3)--css(2)

    前言:css分为四次课讲完,第一节课内容见ASP.NET动态网站制作(2)--css(1),接下来的内容会涉及到定位.浮动.盒子模型(第二次课).css的具体应用(第三次课).css3(第四次课).今 ...

  2. ASP.NET动态网站制作(16)-- SQL数据库(2)

    前言:SQL数据库的第二节课,继续讲解基本的语句及用法. 内容: 1.insert插入语句  insert into Book(bookName,bookPrice,bookAuthor) value ...

  3. ASP.NET动态网站制作(1)--html

    前言:正式上课的第一课,讲的是前端部分的最基础内容:html. 前端:html,css,js 数据库:sql server 动态部分:.net,c#... IIS(Internet Informati ...

  4. ASP.NET动态网站制作(28)-- 三层框架(2)

    前言:三层框架的第二节课,继续上次课的内容. 内容: 1.三层框架的使用目的:可以将视图层和业务逻辑层及实体层分开,可以提高代码的扩展性,安全性,可以实现程序的低耦合性. 2.GetModel方法及G ...

  5. ASP.NET动态网站制作(26)-- Ajax

    前言:这节课讲解关于Ajax的相关内容. 内容: 1.当点击页面中的一个按钮提交数据或请求数据的时候,整个页面的信息都会提交(不管信息是否是提交或者请求的数据,页面中所有的数据都提交),这样耗用的时间 ...

  6. ASP.NET动态网站制作(24)-- ADO.NET(3)

    前言:ADO.NET的第三节课.今天主要讲SQL Helper. 内容: 1.DataReader和DataSet的区别: (1)DataReader是一行一行地读,且只能向前读:DataSet是一次 ...

  7. ASP.NET动态网站制作(22)-- ADO.NET(1)

    前言:这节课开始真正地学习WEB开发,ADO.NET就是一组允许.NET开发人员使用标准的.机构化的,甚至无连接的方式与数据交互的技术.所属的类库为:System.Data.dll. 内容: 1.AD ...

  8. ASP.NET动态网站制作(27)-- 三层框架(1)

    前言:今天主要介绍一下三层框架,给大家一个整体的概念.分层概念使得程序低耦合,更加健壮,扩展性更好. 内容: 1.三层: UI(表现层):主要是指与用户交互的界面.用于接收用户输入的数据和显示处理后用 ...

  9. ASP.NET动态网站制作(23)-- ADO.NET(2)

    前言:这节课老师请高级班的E老师过来代课,还是接着老师讲的内容继续深入,修改了上节课老师写的部分代码. 内容: 1.数据库本质就是一个软件,这个软件帮助我们把数据有序地存储起来,当我们需要数据的时候帮 ...

随机推荐

  1. java内存缓存,节省内存

    缓存的对象 这个问题就是我们上面提到的极端情况,在Java中,会对-128到127的Integer对象进行缓存,当创建新的Integer对象时,如果符合这个这个范围,并且已有存在的相同值的对象,则返回 ...

  2. [置顶] docker--基础镜像和dockerfile

    制作基础镜像 注意:需要在CentOS6下操作 准备工作 yum -y install febootstrap 下载ISO镜像文件到服务器 mkdir /mnt/centos6/ mount -o l ...

  3. [置顶] kubernetes将外部服务映射为内部服务

    在实际应用中,一般不会把mysql这种重IO.有状态的应用直接放入k8s中,而是使用专用的服务器来独立部署.而像web这种无状态应用依然会运行在k8s当中,这时web服务器要连接k8s管理之外的数据库 ...

  4. 模式识别hw2-------基于matconvnet,用CNN实现人脸图片性别识别

    主要来源模式识别课程大作业,本文首先感谢当初的助教和一起完毕作业的队友 matconvnet在matlab下封装了CNN常见算法,网址http://www.vlfeat.org/matconvnet/ ...

  5. 使用JProfiler分析定位java内存泄露memory leak

    使用jprofiler远程profile JBoss应用服务器 项目中发现JBoss出现内存泄露, 从2G一直涨到3.5G左右 开始考虑使用jmap dump出内存来, 在用jhap打开浏览器分析. ...

  6. UVa 10192 - Vacation &amp; UVa 10066 The Twin Towers ( LCS 最长公共子串)

    链接:UVa 10192 题意:给定两个字符串.求最长公共子串的长度 思路:这个是最长公共子串的直接应用 #include<stdio.h> #include<string.h> ...

  7. Singleton单例模式是最简单的设计模式,它的主要作用是保证在程序执行生命周期中,使用了单类模式的类仅仅能有一个实例对象存在。

                                                                                                        ...

  8. Android API Guides---RenderScript

    RenderScript RenderScript是在Android上的高性能执行计算密集型任务的框架. RenderScript主要面向与数据并行计算的使用.尽管串行计算密集型工作负载能够受益.该R ...

  9. UITextView被键盘遮挡的处理

    这个应该是一个通用的任务了吧,键盘弹出来的时候,UITextView(或者UITextField)会被遮挡. 解决的办法就不是很能通用了. 1. 如果有UIScrollView做父view的话只需要滚 ...

  10. 去除inline-block元素间间距的N种方法-zhangxinxu

    张鑫旭原文:点这里进入原文 另外附上大漠老师的如何解决inline-block元素的空白间距地址!!! 去除inline-block元素间间距的N种方法: 一.现象描述 真正意义上的inline-bl ...