1.sqlserer 中有一张父子关系表,表结构如下: CREATE TABLE [dbo].[testparent]( [ID] [int] IDENTITY(1,1) NOT NULL, [name] [nvarchar](50) NULL, [parentID] [int] NULL, CONSTRAINT [PK_testparent] PRIMARY KEY CLUSTERED 2.其中的数据类似: 3.用 CET 递归的方式返回每条记录的层级,其中 lev 为层级, where 后面…
表  A=approval_order, B=admin,  表A中technician_username, salesman_username 都是id号,中文名保存在admin表的nickname字段 ThinkPHP代码: $row = db('approval_order')->alias('ao') ->field('a1.nickname as technician,a2.nickname as salesman,ao.*') ->join('admin a1','ao.te…
在Delphi cxGrid主从表中从表只能编辑第一条记录,这个问题是由于设置主从关联字段错误造成的. 从表DBtableView2的keyfieldnames,DetailKeyFieldNames和MasterKeyFieldNames 是关键:             MasterKeyFieldNames为主表关联字段,             DetailKeyFieldNames 为从表关联字段, keyfieldnames这里应该设置的是从表主字段,而不是跟MasterKeyFie…
和MySql的对比下,两者有数量级的差距. 表ddl: CREATE TABLE tb04 ( "ID" ,) not null primary key, "NAME" NVARCHAR2() not null, "AGE" ,) not null , "CREATEDTIME" ) not null ) 代码如下: package com.hy; import java.sql.Connection; import java…
CREATE TABLE [dbo].[test1]( [program_id] [int] NULL, [person_id] [int] NULL ) ON [PRIMARY] /*查询每组分组中第一条记录*/ select * from test1 as a where a.person_id in ( person_id from test1 where program_id = a.program_id); select * from ( select ROW_NUMBER() ove…
1.SQL Server或MySQL中: INSERT INTO `userTable` (`user_id`, `user_name`) VALUES (, 'dsf'), (, 'fgy'), (, 'faad'); 2.Oracle中: 现在有一个空表a和一个有数据的表格b,他们的结构是一样, 把b表中的所有数据插入到a表中的语句是: INSERT INTO A (列1,列2,列3) SELECT 列1,列2,列3 FROM B ; --查询语句中可以使用任意复杂的条件或者子查询 如果数据…
通常有这种情况,某个表或者准确的说是表的某条记录被锁(TX锁),在业务层面排查之余,一般都会想知道是哪条记录被锁,每次被锁的是否是同一条记录?还是每次都不同?通过记录可以找到这条记录可以在哪个模块.哪个业务流程中被操作到,有助于定位问题.但是思前想后,好像不大好找,oracle的锁机制不同于一些数据库,oracle没有一个集中式的锁管理器,oracle的记录锁(行级排他锁存在于数据块上),只有事务到达那一行的时候才能知道这行是否被锁.举个例子,现在科技大厦的物业需要统计C座每层公司的门是不是都上…
查询整个数据库中某个特定值所在的表和字段的方法 当数据库做的太庞大的时候,难免会出现忘记哪个值会存入哪个表的情况,于是在网上找到的如下解决办法. 通过做一个存储过程,只需要传入一个想要查找的值,即可查询出这个值所在的表和字段名.前提是要将这个存储过程放在所查询的数据库. CREATE PROCEDURE [dbo].[SP_FindValueInDB] ( ) ) AS BEGIN -- SET NOCOUNT ON added to prevent extra result sets from…
SELECT [ID] ,[UserID] ,[StartDate] ,[EndDate] ,[CreateUser] ,[CreateDate] ,[LastEditUser] ,[LastEditDate] FROM [DB_Base].[dbo].[DB_Contracts] ,(SELECT UserID AS U,MAX(EndDate) AS E FROM dbo.DB_Contracts GROUP BY UserID) temp WHERE temp.U = dbo.DB_Con…
select * from (  select mp.MsgID,m.Content,m.CreatorID,m.CreateTime,ROW_NUMBER() over(partition by m.CreatorID order by m.CreateTime desc) as new_index   from U_Account_WX_MsgProperty mp   join U_Account_WX_Messages m on mp.MsgID=m.MsgID  where mp.Us…
现有表如下:id time is_login 3 2012-07-03 11:20:20 13 2012-07-03 11:25:20 04 2012-07-03 12:30:20 14 2012-07-03 12:20:50 0需要的效果: id login_ time logout_time3 2012-07-03 11:20:20 2012-07-03 11:25:20 4 2012-07-03 12:20:20 2012-07-03 12:30:50实现语句: SELECT `order…
原文:http://www.jb51.net/article/28753.htm http://xuzhihong1987.blog.163.com/blog/static/26731587200981744956366/ 要实现的SQL查询很原始: 要求从第一个表进行查询得到第二个表格式的数据,上网查询之后竟然能写出下面的SQL: 复制代码代码如下: select * from userino SELECT * FROM( SELECT DISTINCT userpart FROM useri…
在实际运用中经常会创建这样的结构表Category(Id, ParentId, Name),特别是用于树形结构时(菜单树,权限树..),这种表设计自然而然地会用到递归,若是在程序中进行递归(虽然在程序中递归真的更方便一些),无论是通过ADO.NET简单sql查找还是ORM属性关联都会执行多次sql语句,难免会造成一些性能上的损耗,所以干脆使用sql的函数来解决这个问题,用函数返回我们最终需要的结果. 数据准备 CREATE TABLE Region ( Id INT IDENTITY PRIMA…
1.SQL SELECT DISTINCT 语句 在表中,可能会包含重复值.这并不成问题,不过,仅仅列出不同(distinct)的值. 关键词 DISTINCT 用于返回唯一不同的值. 语法: SELECT DISTINCT 列名称 FROM 表名称 使用 DISTINCT 关键词 1 SELECT DISTINCT Company FROM Orders 2.子查询限制返回结果 1 2 3 4 5 6 7 8 SELECT * FROM TestData  WHERE id IN  (  --…
如果两表联查,主表和明细表的主键都是id的话,明细表的多条只能查询出来第一条. 造成以上情况可能的原因: 1.级联查询的时候,主表和从表有一样的字段名的时候,在mysql上命令查询是没问题的.但在mybatis中主从表需要为相同字段名设置别名.设置了别名就OK了. 例子: 主表Standard, 从表StandEntity,均有名为id的字段 1 <resultMap id="StandardAndEntityResultMap" type="whu.edu.irlab…
select * from ( select *, ROW_NUMBER() over(partition by IPAddress order by recordtime desc) as rowNum from MonitoringSystem ) A order by A.IPAddress, A.recordtime desc 如果表中的数据是以秒记录的  但是显示的时候想以分钟显示 怎么办 select * from MonitoringSystem where RecordTime…
package demo; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; i…
package demo; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; im…
package entity; import java.util.Date; import com.mongodb.BasicDBList;import com.mongodb.DBObject; public class CommonEditEntity { /** 数据库中查询记录结果 */ private DBObject record; /** 数据库默认id */ private String _id; /** 项目id */ private String project_id; /*…
select * from (select * from 表名 order by 字段 desc limit 10) 临时表 order by 字段…
insert into tableA select * from tableB b where not exists(select 1 from tableA a where a.id = b.id) insert into tableA select * from tableB b left join tableA a on a.id = b.id where a.id is null…
假设对表 TXxxxxxxx 表新插入一条记录,然后要 SELECT 出刚刚插入的这条记录.可使用 SCOPE_IDENEITY(); 处理.具体代码参考如下: INSERT INTO TXxxxxxxx(...) VALUES(...) DECLARE @LastInsertId INT = 0; SET @LastInsertId = SCOPE_IDENTITY(); SELECT * FROM TGamePrizePoolWinRecord AS tppwr WHERE id = @La…
先附上数据. CREATE TABLE `course` ( `cno` ) NOT NULL, `cname` ) CHARACTER SET utf8 NOT NULL, `ctime` ) NOT NULL, `scount` ) NOT NULL, `ctest` datetime NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=latin1; ', '2016-03-10 10:08:29'); ', '2016-03-10 10:09:24'); '…
MySQL中一条SQL的加锁分析 id主键 + RC id唯一索引 + RC id非唯一索引 + RC id无索引 + RC id主键 + RR id唯一索引 + RR id非唯一索引 + RR id无索引 + RR Serializable 一条复杂的SQL 死锁原理与分析 SQL1:select * from t1 where id = 10;(不加锁.因为MySQL是使用多版本并发控制的,读不加锁.) SQL2:delete from t1 where id = 10;(需根据多种情况进行…
方法1:select max(id) from tablename 方法2:select last_insert_id(); 在MySQL中,使用auto_increment类型的id字段作为表的主键,并用它作为其他表的外键,形成“主从表结构”,这是数据库设计中 常见的用法.但是在具体生成id的时候,我们的操作顺序一般是:先在主表中插入记录,然后获得自动生成的id,以它为基础插入从表的记录.这里面有个困 难,就是插入主表记录后,如何获得它对应的id.通常的做法,是通过“select max(id…
--用OUTER APPLY select b.* FROM a表 a OUTER APPLY () * from b表 WHERE [Name] = a.[AName] ORDER BY BNo desc) b 总结: . 理解 CROSS APPLY 与 OUTER APPLY(个人理解) ) CROSS APPLY 的意思是“交叉应用”,在查询时首先查询左表,然后右表的每一条记录跟左表的当前记录进行匹配.匹配成功则将左表与右表的记录合并为一条记录输出:匹配失败则抛弃左表与右表的记录.(与…
解决ora-01652无法通过128(在temp表空间中)扩展temp段的过程 昨天开发人员跟我说,执行一个sql语句后,大约花了10分钟,好不容易有一个结果,但是报了一个ora-01652错误,查阅了oracle的错误代码说明:意思是指temp表空间无法自动扩展temp段.这种问题一般有两种原因:一是临时表空间空间太小,二是不能自动扩展. 分析过程:    既然是temp表空间有问题,那当然就要从temp表空间说起啦.首先要说明的是temp表空间的作用,temp表空间主要是用作需要排序的操作.…
批量更新 mysql更新语句很简单,更新一条数据的某个字段,一般这样写: 代码如下: UPDATE mytable SET myfield = 'value' WHERE other_field = 'other_value'; 如果更新同一字段为同一个值,mysql也很简单,修改下where即可: 代码如下:  UPDATE mytable SET myfield = 'value' WHERE other_field in ('other_values');  这里注意 ‘other_val…
在Sharepoint的实际运用中会经常使用到父子表来建立2个表之间的关系.通常父表为表头,存储公共的数据项目,子表存储细分的项目. 例如通过下面2个表实现图书借阅功能,表1为图书的基础信息,表2为图书的借阅记录,采用查阅字段调用表一的图书数据. 1.先建一个自定表,字段如表1所示. 表1   图书表 2.再建个自定义表,增加查阅字段 表2   图书借阅记录字段如下 3.打开建好的表一,新建一条记录,如下所示 4.选择列表的数据,点击菜单上的“自定义表单”,调用Infopath2010对表单进行…
原文 sql多表查询之一:Where 和 On的秘密 对于还在SQL初级阶段的朋友来说,sql多表查询问题是一个比较有趣也容易出错的技术.什么时候会用到sql多表查询呢?是在两张或两张以上表单中通过某几个字段进行互联管理的时候,这就不得不说说sql多表查询中Where 和 On的秘密. 在了解sql多表查询中Where 和 On的秘密之前,让我们先来温习一下连接基础吧 按列a把两表连接,请问各种连接方式的结果的结果? 语法呢? 左    select * from @a Aa left join…