日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

用AR执行sql

發布時間:2025/7/25 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用AR执行sql 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
摘自: http://forum.castleproject.org/viewtopic.php?t=52

Hi, I got somewhat the same problem. I need to run T-SQL commands, as we are new to ActiveRecord and NHibernate, and would like a quick "workaround" when we can't find our ways

I refered to http://castleproject.org/index.php/ActiveRecord:Using_HQL and made a derived class from ActiveRecordBaseQuery.

Code:
Public Class SqlNonQuery
? ? Inherits ActiveRecordBaseQuery

? ? Private _commandText As String
? ? Public Property CommandText() As String
? ? ? ? Get
? ? ? ? ? ? Return _commandText
? ? ? ? End Get
? ? ? ? Set(ByVal Value As String)
? ? ? ? ? ? _commandText = Value
? ? ? ? End Set
? ? End Property

? ? Public Sub New(ByVal commandText As String)
? ? ? ? MyBase.New(GetType(User))

? ? ? ? _commandText = commandText

? ? End Sub

? ? Public Overrides Function Execute(ByVal session As NHibernate.ISession) As Object
? ? ? ? Dim cmd As IDbCommand = session.Connection.CreateCommand()
? ? ? ? cmd.CommandText = CommandText
? ? ? ? cmd.ExecuteNonQuery()
? ? ? ? Return Nothing
? ? End Function

End Class


''' usage '''
Dim q As SqlNonQuery("ANY SQL STATEMENT")
ExecuteQuery(q)


But still have the same problem as Nick, need to pass some arbitrary ActiveRecord class type for the ActiveRecordBaseQuery constructor.

If you have better ways, please advice.. Thanks.



Ok, I figured out something that works:

Code:

ISessionFactoryHolder holder = ActiveRecordMediator.GetSessionFactoryHolder();
ISession session = holder.CreateSession(typeof(User));

IDbCommand cmd = session.Connection.CreateCommand();
cmd.CommandText = "ALTER TABLE stops ALTER description TYPE text;";
cmd.ExecuteNonQuery();
? ?? ?? ?? ?
holder.ReleaseSession(session);


However it's a lot of code, and two things that bug me are:

1) Must give CreateSession some arbitrary ActiveRecord class type (type "User" in the example)
2) GetSessionFactoryHolder() seems to be a "temporary" method, not intended to be used



This disscuss is old though, I post the idea to solve above problem. It maybe help someone who has same problem.
Code:

// Create query
SimpleQuery<object[]> query = new SimpleQuery<object[]>(
? ? ? ? ? ? ? ? typeof(TopCalled),
? ? ? ? ? ? ? ? @"select RecID, count(Called_Number) as frequency, Called_Number
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?from detail_record
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?group by Called_Number
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?order by frequency desc");

// Execute query
object[][] results = query.Execute();


It also might work that you use TopCalled class instead of "object[]" if the class has "operator=(object[])".

轉載于:https://www.cnblogs.com/shiningrise/archive/2007/09/09/887355.html

總結

以上是生活随笔為你收集整理的用AR执行sql的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。