insert:    Location为    Geography类型                INSERT INTO [oss1].[dbo].[Order] ([Location]) VALUES (geography :: STGeomFromText ( 'POINT(55.9271035250276 -3.29431266523898)', 4326) ) 查询select:select location.Lat ,location.Long from [Order]   //查…
这是我以前学习时, 整理的一套基础SQL Server增.删.改.查 等语句 ,初学者可以从上往下学完. 也方便自己忘记时翻看! create database SQLschool go --批 go use SQLschool go -- --------------------------删除表----------------------------- select * from goods --全部删除 delete from goods --有条件的批量删除 delete from go…
<insert id="abatorgenerated_insert" parameterClass="net.xxxxxl.dataobject.Users"> <!-- WARNING - This element is automatically generated by Abator for iBATIS, do not modify. This element was generated :: CST . --> insert in…
什么是自增列 在SQL Server中可以将Id列设为自增.即无需为Id指定值,由SQL Server自动给该列赋值,每新增一列Id的值加一,初始值为1. 需要注意的是即使将原先添加的所有数据都删除,然后新增数据.此时记录的Id依然不会从1开始,而是原先的最大值加1. 自增列的取值范围 一般在定义自增列时,都会指定其数据类型为int类型.而且也只有int类型及其相关数据类型的列可以指定为自增列. 下面是自增列可以使用的数据类型: (,,,,,,) 到 (,,,,,,) 字节 (,,,) 到 (,…
1.引言 T-SQL(Transact Structured Query Language)是标准的SQL的扩展,是程序和SQL Server沟通的主要语言. T-SQL语言主要由以下几部分组成: 数据定义语言(DDL):用来建立数据库.数据库对象等,如CREATE TABLE.DROP TABLE等. 数据控制语言(DCL):控制数据库的存取许可.权限等,如GRANT等. 数据操纵语言(DML):用于插入.修改.删除和查询数据库中数据,如SELECT.INSERT.UPDATE.DELETE等…
近日对SQL操作XML作了如下整理: 1.插入 XML DECLARE @myDoc XMLSET @myDoc = '<Root> <ProductDescription ProductID="1" ProductName="Road Bike"> <Features> </Features> </ProductDescription> </Root>'/*将元素节点插入到文档中*/--在Fe…
使用 sql 语句创建表时,可以使用系统存储过程 sp_addextendedproperty 给字段添加描述说明. sp_addextendedproperty 语法: sp_addextendedproperty [ @name = ] { 'property_name' } [ , [ @value = ] { 'value' } [ , [ @level0type = ] { 'level0_object_type' } , [ @level0name = ] { 'level0_obj…
建立指向Oracle的连接假设Oracle数据库的用户名为test,密码为test,在SQL Server数据库所在服务器上建立的指向Oracle数据库的服务命名为hisorcl.1. 在SQL Server的企业管理器中的对象资源管理器中,展开“服务器对象”,在“链接服务器”上右击,选“新建链接服务器”.如下图所示进行配置. 通过连接查询Oracle数据库中的数据 select * from openquery(TEST_ORA, 'SELECT * FROM BASEMETADATA_DEP…
前言 上一篇我们分析了查询优化器的工作方式,其中包括:查询优化器的详细运行步骤.筛选条件分析.索引项优化等信息. 本篇我们分析在我们运行的过程中几个关键指标值的检测. 通过这些指标值来分析语句的运行问题,并且分析其优化方式. 通过本篇我们可以学习到调优中经常利用的几个利器! 废话少说,开始本篇的正题. 技术准备 数据库版本为SQL Server2008R2,利用微软的一个更简洁的案例库(Northwind)进行分析. 利器一.IO统计 通过这个IO统计能为我们分析出当前查询语句所要扫描的数据页的…
前言 前面我们的几篇文章介绍了一系列关于运算符的介绍,以及各个运算符的优化方式和技巧.其中涵盖:查看执行计划的方式.几种数据集常用的连接方式.联合运算符方式.并行运算符等一系列的我们常见的运算符.有兴趣的童鞋可以点击查看. 本篇我们介绍关于子查询语句的一系列内容,子查询一般是我们形成复杂查询的一些基础性操作,所以关于子查询的应用方式就非常重要. 废话少说,开始本篇的正题. 技术准备 数据库版本为SQL Server2008R2,利用微软的一个更简洁的案例库(Northwind)进行分析. 一.独…
最近项目开发一直在不断切换数据库,有时候一条sql 要同时考虑多种数据库中的兼容问题 , 先总结一条模糊查询拼接查询条件的问题,后续追加总结. 目前使用   mybatis: 1. Oracle 中使用     "||"和 "+"   来进行拼接参数条件,如 : select * from user where name like  '||'  +  #{name}  +  '||'  2. SQL Server 中使用     "%"和 &qu…
三.连接查询部分 --------------------嵌套循环-------------------- /* UserInfo表数据少.Coupon表数据多嵌套循环可以理解为就是两层For循环,外层For会循环其中的每一项,内层For进行匹配,相应的外层For对应外部输入表,执行计划的图示排在上面,内层For对应内部出入表,执行计划的图示排在下面,外部表每一行都要使用来匹配,而内部表却不一定每一行都在匹配中被使用,所以,1.外部表输入越小越好,也可以利用索引来减少输入行数2.内部表匹配则可以…
一.数据查询部分 1. 看到执行计划有两种方式,对sql语句按Ctrl+L,或按Ctrl+M打开显示执行计划窗口每次执行sql都会显示出相应的执行计划 2. 执行计划的图表是从右向左看的 3. SQL Server有几种方式查找数据记录 [Table Scan] 表扫描(最慢),对表记录逐行进行检查 [Clustered Index Scan] 聚集索引扫描(较慢),按聚集索引对记录逐行进行检查 [Index Scan] 索引扫描(普通),根据索引滤出部分数据在进行逐行检查 [Index See…
.net Entity Framework(调研的是Entity Framework 4.0) code first方式生成数据库时,不能修改数据库表的索引,而SQLServer默认会把数据表的主键设置为聚集索引,所以Entity Framework如果要修改索引,只能执行sql脚本修改. 这里主要介绍一下调研修改聚集索引来提升查询性能的过程. 系统环境 我们做的是一个form程序,多个客户端直接访问数据库.对于此系统,用户没有需求在短时间内插入大量的数据,只需要满足一般的业务需求即可,但是用户…
前言 前面我们的几篇文章介绍了一系列关于运算符的介绍,以及各个运算符的优化方式和技巧.其中涵盖:查看执行计划的方式.几种数据集常用的连接方式.联合运算符方式.并行运算符等一系列的我们常见的运算符.有兴趣的童鞋可以点击查看. 本篇我们介绍关于子查询语句的一系列内容,子查询一般是我们形成复杂查询的一些基础性操作,所以关于子查询的应用方式就非常重要. 废话少说,开始本篇的正题. 技术准备 数据库版本为SQL Server2008R2,利用微软的一个更简洁的案例库(Northwind)进行分析. 一.独…
通过SqlCommand对象的ExecuteNonQuery方法执行命令行,来实现数据库中表的增.删.改.主要有5步 using System.Data.SqlClient;//载入数据库命名空间 private void button1_Click(object sender, EventArgs e) { .连接数据库 SqlConnection con = new SqlConnection("Server=CAIWU;User Id=sa;Pwd=;DataBase=db_Me"…
获取一个表中最大的值. function GetNEWID(tablename: string): string; begin Result:=''; with DMW_Public.DQ_Pub do begin Close; SQL.Clear; SQL.Add('SELECT IDENT_CURRENT('''+tablename+''') + IDENT_INCR('''+tablename+''') as newid'); Open; ' else Result:=Fieldbynam…
前言: 数据库操作避免不了对数据的操作,操作方法大同小异,万变不离其宗,今就写一下各种花式操作的根本增删改查四种操作,今天我们就来说一下增加操作的三种方法 正文: 增加操作是对数据库进行数据行的添加,用于添加新的数据信息 注意事项: 1.插入数据行时要插入完整,不要只插入几列 2.每个值的数据类型.精度和小数位数必须与相应的列匹配: 3.不能为标识列指定值,因为它的数字是自动增长的: 4.插入时要符合约束 5.具有缺省值的列,可以使用DEFAULT(缺省)关键字来代替插入的数值 格式: (1)…
use master --drop database Class create database Class on primary( name='Class', filename='D:\SQLTest\Class.mdf', size=10mb, filegrowth=10mb ) log on( name='Class_log', filename='D:\SQLTest\Class_log.ldf', size=5mb, filegrowth% ) use Class--使用数据库 tru…
create database 数据库名 go --穿件完成 go create table 表名(列名 类型, 列名 类型, 列名 类型 --最后一个列名不加逗号) go --创建完成go 以创建表为例 create table book(daihao varchar(10),mingcheng varchar(50),zuozhe varchar(10),chubanshe varchar(50),shijian datetime)go--创建完成加go--插入insert into boo…
一.数据库的增删改查 1.新建数据库 create database students on primary ( name="students_data",--主数据文件的逻辑名 filename="E:\students_data.mdf",--主数据文件的存储位置 size=3MB,--主数据文件的初始大小 maxsize=100MB,--主数据文件的最大大小,不写就没有限制 filegrowth=1MB--主数据文件每次增长大小 ) log on ( name…
在MSSQLServer2008下的语句 不同版本可能语句会有微小差别 SELECT [Slot ID], [Transaction ID], Operation, AllocUnitName, [Current LSN], [Log record] , [RowLog Contents 0], [RowLog Contents 1], [RowLog Contents 2], [RowLog Contents 3], [RowLog Contents 4], [Log Record Fixed…
数据库结构: CREATE TABLE [dbo].[cg_tz_log] ( [logid] int NOT NULL IDENTITY(1,1) , operate varchar(10), -- 操作类型 如Insert,Update,Delete. id int, -- 原表ID(主键) [cg_date_o] date NULL , [cg_date_n] date NULL , [cg_id_o] varchar(255) NULL , [cg_id_n] varchar(255)…
数据的添加: 首先建立一个数据库,点击新建查询,然后用代码建立一个表,表里写上列名和数据类型,约束可加可不加 然后使用insert语句往表里添加数据 insert [into] 表名 (列名1,列名2,列名3......列名n) values ('列值1','列值2','列值3',......'列值n') 注:列值需要用单引号引起来,[]中括号中的into可写可不写 数据的修改: 使用update语句对数据进行修改 格式:update 表名 set 列名='表达式' where 条件表达式 例:…
示例数据库 点我下载 一条完整的sql语句 select top | distinct 字段, 表达式, 函数, ... from 表表达式 where 筛选条件 group by 分组条件 having 筛选条件 order by 排序依据; SQL的执行顺序: 运算符的优先级 SELECT语句的元素 SELECT empid, YEAR(orderdate) AS orderyear, COUNT(*) AS numorders FROM Sales.Orders GROUP BY empi…
知识点: 复杂查询1:统计全校有多少个男生.有多少个女生? 写法1(分组): select sex as 性别,count(*) as 人数 from student group by sex 写法2(合并): select '男' as 性别,count(*) as 人数 from student where sex='男' union all select '女' as 性别,count(*) as 人数 from student where sex='女' 写法3(条件): select…
如图所示,Jdate和Jdate2是两个分开的字段,一个是date类型,存储日期,一个是time(0)类型,存储具体时间 现在有这样的要求,就是获得(Jdate和Jdate2组合起来的日期时间)在(当前日期时间之后)的数据 一开始我是用的SQL语句是  select * from table where Jdate>XXX and Jdate2 >XXX.这样的语句查询出来是有问题的,因为这两个条件是分开的,可以说是有前后关系,先满足Jdate再满足Jdate2,而这样写的话就是并列关系了,两…
drop table class create table class ( classId ) primary key not null, cName ) ) insert into class ','自动化1班') insert into class ','计算机1班'), (','计算机2班'), (','自动化2班') select * from class ' ' ' ' update class set cName='自动化3班' alter table student )not nu…
==================================声明================================== 本文原创,转载在正文中显要的注明作者和出处,并保证文章的完整性. 未经作者同意请勿修改(包括本声明),保留法律追究的权利. 未经作者同意请勿用于出版.印刷或学术引用. 本文不定期修正完善,为保证内容正确,建议移步原文处阅读. 本文链接:http://www.cnblogs.com/wlsandwho/p/4364899.html =============…
一.From阶段 针对连接说明: 1.笛卡尔积 2.on筛选器 插播:unknown=not unknuwn 缺失的值: 筛选器(on where having)把unknown当做FALSE处理,排除在筛选结果之外.如果比较两个null,结果是不相等的,false check约束中当做true,例如要求某列大于0,当插入null时是成功的,认为null>0是ture.如果比较两个null,结果是相等的,这种比较在unique约束.集合运算(例如union .except).排序.分组,都认为是…