- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我现在正在使用 C# 为 MS-SQL View 查询实现 View 生成器。
如果 FROM 子句中已经有一个表,我必须将它与现有表别名重用到 SELECT 子句中
例如,如果我输入“PackOrderPouch”,结果将是“A”,或者如果我输入“Client”,结果将是“R”。
是否有简单的方法让 MS-SQL 可以给表别名,或者用 C# 可以很容易地做到这一点?
ALTER VIEW [dbo].[PackOrderRefV]
AS
SELECT
A.PackOrderItemOrientedID
, A.PackOrderItemID
, A.PouchNo
, C.PatientNo
, C.PatientName
, D.FacilityNo AS LocationNo
, IIF(D.FacilityName = N'WALK-IN', N'', D.FacilityName) AS LocationName
, E.FacilityNo AS HospitalNo
, E.FacilityName AS HospitalName
, ISNULL(E.FacilityDescription, E.FacilityName) AS HospitalDescription
, A.AdminDay
, GETDATE() AS PackedDate
, ISNULL(H.PrescriptionValue, '') AS BirthDay --BirthDay (1/2)
, R.MachineNo --MachineNo (1/3)
, Patient_ETC01.PrescriptionItemValue AS Patient_ETC01 --Patient_ETC01 (1/2)
FROM
PackOrderPouch A
LEFT OUTER JOIN Prescription B ON A.PrescriptionID = B.RawID
LEFT OUTER JOIN Patient C ON B.PatientID = C.RawID
LEFT OUTER JOIN Facility D ON A.LocationID = D.RawID
LEFT OUTER JOIN Facility E ON A.FacilityID = E.RawID
LEFT OUTER JOIN AdminTime F ON A.AdminTimeID = F.RawID
LEFT OUTER JOIN PrescriptionDetail H ON A.PrescriptionID = H.PrescriptionID AND H.OCSFormatItemID = 6 --BirthDay (2/2)
-- * Patient ETC OCSFormatItemID - 01:91, 02:92, 03:93, 04:94, 05:95, 06:96, 07:97, 08:98, 09:99
LEFT OUTER JOIN PackOrderItemOriented Q ON A.PackOrderItemOrientedID = Q.RawID --MachineNo (2/3)
LEFT OUTER JOIN Client R ON Q.ClientID = R.RawID --MachineNo (3/3)
LEFT OUTER JOIN PrescriptionDetail Patient_ETC01 ON A.PrescriptionID = Patient_ETC01.PrescriptionID AND Patient_ETC01.OCSFormatItemID = 91 --Patient_ETC01 (2/2)
GO
抱歉解释不充分,我会进一步澄清这个例子。
“PackOrderRefV”已经存在,C# 将使用“sp_helptext PackOrderRefV”读取此 View 脚本,并希望通过读取 XML 文件和更改 View 在 SELECT 子句上添加“Patient.RoomNo”列。但是,“Patient”表已经存在于 FROM 子句中,因此如果 Patient 表已经存在,则不应在 FROM 子句中添加。如果FROM子句中已经没有Patient表,则需要在FROM子句中添加。
<?xml version="1.0" encoding="utf-8" ?>
<ArrayOfViewElement xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<ViewElement ViewName="PackOrderRefV" ColumnName="RoomNo" Description="Patient's RoomNo">
<ViewElementDetail Type="SELECT">
, {Patient}.RoomNo
</ViewElementDetail>
<ViewElementDetail Type="FROM">
LEFT OUTER JOIN Patient {0} ON {Prescription}.PatientID = {0}.RawID
</ViewElementDetail>
</ViewElement>
<ViewElement ViewName="PackOrderRefV" ColumnName="DayOfWeek_MultiLanguage" Description="Day Of Week text with its patient language">
<ViewElementDetail Type="SELECT">
, FORMAT(A.AdminDay, N'ddd',
(
CASE MR5.PrescriptionItemValue
WHEN N'Korean' THEN N'ko-KR'
WHEN N'English' THEN N'en-US'
WHEN N'German' THEN N'de-DE'
WHEN N'French' THEN N'fr-FR'
WHEN N'Japanese' THEN N'ja-JP'
WHEN N'Danish' THEN N'da-DK'
WHEN N'Spanish' THEN N'es-ES'
WHEN N'Italian' THEN N'it-IT'
WHEN N'Dutch' THEN N'nl-NL'
WHEN N'Portuguese' THEN N'pt-PT'
WHEN N'Finnish' THEN N'fi-FI'
WHEN N'Swedish' THEN N'sv-SE'
WHEN N'Hungarian' THEN N'hu-HU'
WHEN N'Polish' THEN N'pl-PL'
WHEN N'Turkish' THEN N'tr-TR'
WHEN N'Traditional Chinese' THEN N'zh-Hant'
WHEN N'Simplified Chinese' THEN N'zh-Hans'
WHEN N'Arabic' THEN N'ar-SA'
WHEN N'Thai' THEN N'th-TH'
WHEN N'Bokmål' THEN N'nb-NO'
ELSE N'en-US'
END
)) DayOfWeek_MultiLanguage --DayOfWeek_MultiLanguage (1/3)
</ViewElementDetail>
<ViewElementDetail Type="FROM">
LEFT OUTER JOIN PrescriptionItem K1 ON K1.RawID = (SELECT TOP (1) RawID FROM PrescriptionItem p1 where p1.PrescriptionID = A.PrescriptionID) --DayOfWeek_MultiLanguage (2/3)
LEFT OUTER JOIN PrescriptionItemDetail MR5 ON K1.RawID = MR5.PrescriptionItemID AND MR5.OCSFormatItemID = 71 --DayOfWeek_MultiLanguage (3/3)
</ViewElementDetail>
</ViewElement>
<ViewElement ViewName="PackOrderRefV" ColumnName="Patient_ETC01" Description="Patient Random 01 Field in OCS file">
<ViewElementDetail Type="SELECT">
, PR1.PrescriptionItemValue AS Patient_ETC01 --Patient_ETC01 (1/2)
</ViewElementDetail>
<ViewElementDetail Type="FROM">
LEFT OUTER JOIN PrescriptionDetail PR1 ON A.PrescriptionID = PR1.PrescriptionID AND PR1.OCSFormatItemID = 91 --Patient_ETC01 (2/2)
</ViewElementDetail>
</ViewElement>
</ArrayOfViewElement>
最佳答案
这可以用 T-SQL 来完成。首先获取您需要的 View 的定义:
DECLARE @view nvarchar(max) = N'',
@x xml
SELECT @view = sm.[definition]
FROM sys.views v
INNER JOIN sys.sql_modules sm
ON v.[object_id] = sm.[object_id]
WHERE v.[name] = 'PackOrderRefV'
然后:
SELECT @view = SUBSTRING(@view,CHARINDEX('FROM',@view)+4,CASE WHEN CHARINDEX('GO',@view) > 0 THEN CHARINDEX('GO',@view)-2 ELSE LEN(@view) END)
SELECT @x = '<t>'+REPLACE(@view,'JOIN','</t><t>')+'</t>'
;WITH cte AS (
SELECT LTRIM(t.c.value('.','nvarchar(max)')) as p
FROM @x.nodes('/t') as t(c)
)
SELECT CASE WHEN CHARINDEX(' on ',p) > 0 THEN SUBSTRING(p,1,CHARINDEX(' on ',p)) ELSE p END
FROM cte
输出:
PackOrderPouch A LEFT OUTER
Prescription B
Patient C
Facility D
Facility E
AdminTime F
PrescriptionDetail H
PackOrderItemOriented Q
Client R
PrescriptionDetail Patient_ETC01
正如您首先看到的,我参与了从 FROM
关键字到 GO
的部分。然后,将其设为 XML。并通过搜索 ON
关键字得到我们需要的东西。
这就是在 View 查询中查找表别名的方法吗?
关于c# - 如何在 View 查询中找到表别名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48001554/
上下文:我已经在域根上设置了一个用于 GIS 测试和 dokuwiki 的虚拟机服务器。我想在子域上提供 gis Web 应用程序,这样 dokuwiki url 重命名就不会发生冲突(而且感觉更干净
这个问题在这里已经有了答案: If two variables point to the same object, why doesn't reassigning one variable affe
代码如下: Select Branch.BranchName, Sum(Inventory.OnHand) From Inventory, Branch Inventory.BranchNum = B
我的目标是创建一种“Javascript 库”,如果您可以这样调用它的话。我打算在浏览网页时使用它来操作页面,将其作为 greasemonkey 脚本动态加载。这个想法是将“win”映射到window
是否可以在 javascript 中以某种方式为本地变量分配别名/引用? 我的意思是类似 C 的东西: function foo() { var x = 1; var y = &x; y+
SQLite 别名 您可以暂时把表或列重命名为另一个名字,这被称为别名。使用表别名是指在一个特定的 SQLite 语句中重命名表。重命名是临时的改变,在数据库中实际的表的名称不会改变。 列别名用来
我有以下导入(在同一个 TS 源文件中): import {Vector as sourceVector} from "ol/source"; import {Vector} from "ol/lay
我想弄清楚 this 到底是什么行是在这个 github json 项目的 cmake 文件中, add_library(${NLOHMANN_JSON_TARGET_NAME} INTERFACE)
使用集合时如何创建别名 (AS)。 $collection->addAttributeToSelect('total_qty') 可以这样做: $collection->getSelect()->co
这个问题在这里已经有了答案: Pass an argument to a Git alias command (4 个回答) 去年关闭。 我的团队在不同的分支上工作,通常,我需要快速从分支切换来帮助他
我正在寻找一种向我的 vimrc 添加自定义命令或别名的方法,以便快速切换到 Vim 中的不同目录。我曾经设置过一些东西,但丢失了那个配置。这是用于 Linux 设置。 基本上,我想设置一个别名(如果
我使用 Delphi 和 Firebird 1.5 开发了一个应用程序,其中服务器与应用程序位于同一台计算机上。我现在正在将应用程序部署到另一个站点,其中 Firebird 服务器( super 服务
我创建了一个全新的 React 应用 create-react-app demo 我需要为某些目录/组件创建别名,例如: import { Header } from '@uicomponents'
我正在尝试打印有向图,并且不断更改各种节点属性,例如颜色和形状。有什么方法可以使用一次定义并用于多个节点的变量?理想情况下,我想要这样的东西: digraph g { building_color =
server { listen 80; server_name pwta; root html; location /test/{ alia
我想匹配多个数组,并在匹配时构建另一个数组。该键可以在任意数量的数组中匹配,也可以根本不匹配。 [ [{ 'a': 13 }, { 'b': 62 }, { 'c': 93 }, { 'd': 52
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我有一个这样的查询: select a1.name, b1.info from (select name, id, status from table1 a) as a1 righ
我想给一些 racket 2htdp 函数/宏起别名,这样我就可以为我的 child 将它们翻译成另一种语言。 我可以简单地用define给函数起别名。我在使用 big-bang 结构时遇到了麻烦;例
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我是一名优秀的程序员,十分优秀!