(转)新手C#SQL语句的学习2018.08.13
1.创建数据库(create)
CREATE DATABASE database-name
2.删除数据库(drop)
drop database dbname
3.备份数据库
--- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBack
4.创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) --根据已有的表创建新表: A:create table tab_new like tab_old (使用旧表创建新表) B:create table tab_new as select col1,col2… from tab_old definition only
5.删除新表
drop table tabname
6.增加一个列(字段)
Alter table tabname add column col type --注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7.添加主键
Alter table tabname add primary key(col) --说明:删除主键: Alter table tabname drop primary key(col)
8.创建索引
create [unique] index idxname on tabname(col….) --删除索引:drop index idxname --注:索引是不可更改的,想更改必须删除重新建。
9.创建视图
create view viewname as select statement --删除视图:drop view viewname
10.几个最简单的SQL语句
--选择:
select * from table1 where 范围 --插入:
insert into table1(field1,field2) values(value1,value2) --删除:
delete from table1 where 范围 --更新:
update table1 set field1=value1 where 范围 --查找:
select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料! --排序:
select * from table1 order by field1[desc],field2[asc] --二次排序,当有重复值时按照主键排序 --总数:
select count as totalcount from table1 --求和:
select sum(field1) as sumvalue from table1 --平均:
select avg(field1) as avgvalue from table1 --最大:
select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1 --统计记录条数
SELECT COUNT(*) FROM T_EMPLOYEE --向下/向上取整
SELECT FLOOR(50.41) --
SELECT CEILING(50.41) --
使用通配符
通配符过滤关键词:LIKE
--"%"为匹配零个或多个任意字符,结果为包含O的字符串
SELECT * FROM T_EMPLOYEE WHERE FNAME LIKE '%O%'
--非O开头但包含O的字符串
SELECT * FROM T_EMPLOYEE WHERE FNAME LIKE '[^O]%O%'
--非O开头和结尾但中间包含O的字符串
SELECT * FROM T_EMPLOYEE WHERE FNAME LIKE '[^O]%O%[^O]'
--"_"为匹配一个任意字符,结果为前后匹配任意字符,单至少有一个O在中间
SELECT * FROM T_EMPLOYEE WHERE FNAME LIKE '_%O%_'
--包含a-t之间的任意单个字母
SELECT * FROM T_EMPLOYEE WHERE FNAME LIKE '[a-t]'
空值处理:数据库中,如果一个列没有指定值,这个值就是NULL,但是这个NULL和C#中的NULL不同,数据库中的NULL代表的是不知道,未定义的意思,而C#中的NULL表示为空,例如Person h;就表示h为空。
SQL语句查询空值的语句为
--空值查询
SELECT * FROM T_EMPLOYEE WHERE FNAME IS NULL
多值查询:IN,BETWEEN-AND
--IN类似于英文or,即根据IN中所包含的部分查询
SELECT FNUM,FNAME,FAGE,FSALARY FROM T_Employee WHERE FAGE IN(,,,);
--BETWEEN-AND用于查询在其之间的部分,注意其为大于等于
SELECT FNUM,FNAME,FAGE,FSALARY FROM T_Employee WHERE FAGE BETWEEN AND ;
--BETWEEN不可用于字符的比较,可用>,<通过自动转换为ASCII码比较
SELECT FNUM,FNAME,FAGE,FSALARY FROM T_Employee WHERE FTEST BEWTEEN 'A'AND 'G'
SELECT FNUM,FNAME,FAGE,FSALARY FROM T_Employee WHERE FTEST>= 'A'AND FTEST<= 'G'
分组查询:GROUP BY
--GROUP BY用于分组,两个条件时通过两个共同的进行分组
SELECT FTEST,COUNT(*) FROM T_EMPLOYEE GROUP BY FTEST
SELECT FNAME,FTEST,COUNT(*) FROM T_EMPLOYEE GROUP BY FTEST,FNAME

分组后的查询条件:HAVING
--分组之后的结果集的条件用HAVING,不用GROUP BY采用的条件是WHERE,但其条件必须要包含在结果集当中,如采用FAGE>30则不可以
SELECT FNAME,FTEST,COUNT(*) as 数量 FROM T_EMPLOYEE
GROUP BY FTEST,FNAME
HAVING COUNT(*)>1
合并结果集:UNION (ALL)
--合并结果集,并且去除重复项
SELECT c_name from Category
union
select b_title from Book --合并结果集,不去除重复项
SELECT c_name from Category
union all
select b_title from Book
当查询多个列时,去除重复项只能去除完全相同的项,若一列相同,其他列不同,则不算是重复,不会去除。
2018.08.13
(转)新手C#SQL语句的学习2018.08.13的更多相关文章
- 新手C#SQLServer在程序里实现语句的学习2018.08.12
从C#中连接到SQL Server数据库,再通过C#编程实现SQL数据库的增删改查. ado.net提供了丰富的数据库操作,这些操作可以分为三个步骤: 第一,使用SqlConnection对象连接数据 ...
- 新手C#SQL Server使用记录2018.08.10
主键(PrimaryKey):主键就是每个数据行(记录)的唯一标识,不会有重复值的列(字段)才能当做主键.一个表可以没有主键,但是这样会很难处理表,因此一般情况表都要设置主键. 主键有两张选用策略,分 ...
- SQL语句的学习
SQL语句的学习 要交作业了,刚好把SQL查询语句的内容写成笔记,以后好查看.水一下 单表查询 DISTINCT:去掉结果中的重复行作用,将DISTINCT关键字放在select的后面.目标列名的前面 ...
- 标准sql语句,学习
标准SQL语句总结标准SQL语句总结,标准SQL语言基本上适用于下面所列出的数据库软件 -------------------------------------------------------- ...
- sql语句的学习(1)
一.创建表 CREATE TABLE `student` ( `id` ) NOT NULL AUTO_INCREMENT, `name` ) DEFAULT NULL COMMENT '姓名', ` ...
- 新手C#异常的学习2018.08.07
异常是在程序执行期间出现的问题.C# 中的异常是对程序运行时出现的特殊情况的一种响应,比如尝试除以零. class Program { static void Main(string[] args) ...
- 新手C#构造函数、继承、组合的学习2018.08.06/07
构造函数,是一种特殊的方法.主要用来在创建对象时初始化对象,即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中.特别的一个类可以有多个构造函数,可根据其参数个数的不同或参数类型的不同 ...
- 新手C#s.Split(),s.Substring(,)以及读取txt文件中的字符串的学习2018.08.05
s.split()用于字符串分割,具有多种重载方法,可以通过指定字符或字符串分割原字符串成为字符串数组. //s.Split()用于分割字符串为字符串数组,StringSplitOptions.Rem ...
- 新手C#int.Parse、int.TryParse的学习2018.08.04
int.Parse()用于将字符串转换为32为int类型,但是在遇到非数字或者类似1.545这种小数的时候会报错,后来采用了int.TryParse,这个在转换后会判断是否可以正常转换,若不能,会返回 ...
随机推荐
- 【appium】根据xpath定位元素
1. 背景 本文尝试使用的试验对象是SDK自带的NotePad应用实例,假设已经有两个Notes分别是“note1”和“note2”添加到Notepad上面,我们要做的就是尝试用xpath的方法来定位 ...
- javacv 340使用 人脸检测例子【转载】
Java下使用opencv进行人脸检测 工作需要,研究下人脸识别,发现opencv比较常用,尽管能检测人脸,但识别率不高,多数是用来获取摄像头的视频流的,提取里面的视频帧,实现人脸识别时通常会和其他框 ...
- linux 线程的同步 一 (互斥量和信号量)
互斥量(Mutex) 互斥量表现互斥现象的数据结构,也被当作二元信号灯.一个互斥基本上是一个多任务敏感的二元信号,它能用作同步多任务的行为,它常用作保护从中断来的临界段代码并且在共享同步使用的资源. ...
- Windows Server 2008 R2 3389端口更改
Windows Server 2008 R2 3389端口更改 2016-04-28 23:08 4734人阅读 评论(0) 收藏 举报 分类: Windows(61) 版权声明:本文为博主原创文 ...
- css position 和 块级/行内元素解释
一.position 属性: static:元素框正常生成.块级元素生成一个矩形框,作为文档流的一部分,行内元素则会创建一个或多个行框,置于其父元素中. relative:元素框偏移某个距离.元素仍保 ...
- Spring中的后置处理器BeanPostProcessor讲解
Spring中提供了很多PostProcessor供开发者进行拓展,例如:BeanPostProcessor.BeanFactoryPostProcessor.BeanValidationPostPr ...
- Unity3D SerialPort处理
using UnityEngine; using System.Collections; using System; using System.Threading; using System.Coll ...
- 1005 Spell It Right (20 分)
1005 Spell It Right (20 分) Given a non-negative integer N, your task is to compute the sum of all th ...
- MapReduce C++ Library
MapReduce C++ Library for single-machine, multicore applications Distributed and scalable computing ...
- 《Linux内核精髓:精通Linux内核必会的75个绝技》一HACK #19 ext4的调整
HACK #19 ext4的调整 本节介绍可以从用户空间执行的ext4调整.ext4在sysfs中有一些关于调整的特殊文件(见表3-6).使用这些特殊文件,就不用进行内核编译.重启,直接从用户空间确认 ...