2014-08-26 遇到的小問題

?

? ?不能快速的保存bug的確是很不爽的事情 ,不僅客戶著急 領導也著急 ,自己也著急。。。。。。。。哈哈

? ?

? ?原來好好的一個平臺 簡單的一個插入記錄 突然就報錯了

? ?錯誤為 could not insert #9521

? ?原來項目是用 NHibernate 做的插入

? ?拋出的異常 真是無法定位到底是什么錯誤啊
? ?于是想打開vs調試下遠程庫?

? ?結果調試過程中 無法查詢變量的值
? ?在調試即時窗口里 ?提示 表達式計算器中發生內部錯誤

? ?郁悶 ?于是重啟vs

? ?又提示 源文件與模塊生成時的不同

? ?網上搜了下解決方案 ?修改 調試 --》 選項 --》 常規里面 去掉 要求源文件與原始版本相匹配 ok 了

? ?調試過程中發現?

? ?-- 錯誤代碼拋出的異常 為 直接的 Exception 查看了下 innerException 結果為

? ?"當 IDENTITY_INSERT 設置為 OFF 時,不能向表 'OrderList' 中的標識列插入顯式值“

? ?理論上來說 這個表的主鍵設置了 自增長,查了下 果然 服務器的表 與 測試的表 不符合 應該是有人改了數據庫,
? ?只能是修改下 hbm.xml 文件 ok ,耗時一個半小時 ,

? ?時間主要浪費在 vs調試 這上面 ,錯誤沒能夠明顯的拋出

? ? 調試錯誤后 順便總結下吧

? ? innerException ?msdn的地址

? ?http://msdn.microsoft.com/zh-cn/library/system.exception.innerexception.aspx

? ? 總的來說 拋出innerException 能更快的定位到錯誤,但并不是每個Exception 都會有 innerException

?

? ?再一個 vs 的 要求源文件與原始版本匹配 ,網上還有一個解決辦法是 刪除bin目錄 重新生成 我沒試
? ?找了下這樣做可以的原因 應該是 pdb文件儲存了項目的調試信息,可能與修改不符合

? ?關于 pdb 文件,還真沒仔細研究過。

? ?pdb 文件 ?http://www.wintellect.com/blogs/jrobbins/pdb-files-what-every-developer-must-know

?

? ?nhibernate 主鍵

? ?

(1) assigned
主鍵由外部程序負責生成,無需NHibernate參與。

(2) hilo
通過hi/lo 算法實現的主鍵生成機制,需要額外的數據庫表保存主
鍵生成 歷史狀態。

?

<!--<generator class="hilo">
<param name="table">Tbl_Basic_Identity</param>
<param name="column">ProductVerifyMessageID</param>
<param name="max_lo">0</param>
</generator>-->

?

(3) seqhilo
與hilo 類似,通過hi/lo 算法實現的主鍵生成機制,只是主鍵歷史
狀態保存在Sequence中,適用于支持Sequence的數據庫,如Oracle。

(4) increment
主 鍵按數值順序遞增。此方式的實現機制為在當前應用實例中維持
一個變量,以保存著當前的最大值,之后每次需要生成主鍵的時候
將此值加1作為 主鍵。
這種方式可能產生的問題是:如果當前有多個實例訪問同一個數據
庫,那么由于各個實例各自維護主鍵狀態,不同實例可能生成同樣
的 主鍵,從而造成主鍵重復異常。因此,如果同一數據庫有多個實
例訪問,此方式必須避免使用。

(5) identity
采用數據庫提供的主鍵生成機制。如DB2、SQL Server、MySQL
中的主鍵 生成機制。

(6) sequence
采用數據庫提供的sequence 機制生成主鍵。如Oralce 中的
Sequence。

(7) native
由 NHibernate根據底層數據庫自行判斷采用identity、hilo、sequence
其中一種作為主鍵生成方式。) uuid.hex
由 Hibernate基于128 位唯一值產生算法生成16 進制數值(編碼后
以長度32 的字符串表示)作為主鍵。

(8) foreign
使用外部表的字段作為主鍵。

轉載于:https://www.cnblogs.com/havid/p/3937292.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/376701.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/376701.shtml
英文地址,請注明出處:http://en.pswp.cn/news/376701.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Fatal error: Please read “Security“ section of the manual to find out how to run mysqld as root

.通過在命令后面加上–userroot 進行強制使用root賬號啟動。 cd /etc/init.d mysqld --userroot 參考&#xff1a; https://blog.csdn.net/huo_wa/article/details/117550307?spm1001.2101.3001.6650.2&utm_mediumdistribute.pc_relevant.none-task-blog-2%7Edefault%7ECT…

取消cp別名'cp -i'(unalias)

在rhel4updae8系統是使用cp命令覆蓋文件總是提示要輸入yes或no&#xff0c;即使加上-f參數也無法強行覆蓋。[2] 方法一&#xff1a; 輸入alias命令&#xff0c;看到系統內部使用的是cp的別名。 #alias alias cpcp -i 輸入unalias cp命令&#xff0c;解除別名。 unalias cp #&…

增加swap分區

在確定了服務器所需要使用的內存后&#xff0c;需要增加1024M的swap空間 具體操作&#xff1a; 1、dd if/dev/zero of/tmp/swap bs1M count1024M #創建1024M的文件塊 2、mkswap /tmp/swap #創建swap文件 3、swapon /tmp/swap #激活swap文件 4、swapon -s #查看swap 5、修改…

python 實現 topk算法

這里的版本是針對的一個class的某一個成員變量進行的&#xff1a; 關于如何定義對象的比較方法&#xff0c;請參考往期文章&#xff1a;python定義對象的比較方法 class province_room_quality_data:def __init__(self, room, quality):self.room roomself.quality qualityd…

2013年,未知的旅程

去年就開始策劃要辭職到外面去闖一闖&#xff0c;今年年初在上一家公司毅然辭職了&#xff0c;理由是自己需要出去鍛煉鍛煉。 帶著一個月的工資&#xff0c;和一點積蓄&#xff0c;還有一個女朋友來到了這個我以前都沒有來過的城市-深圳。 聽好多人都說過深圳是個好地方&#x…

SQL基礎

經過這幾天我才發現原來我最弱的是數據庫&#xff0c;好了現在就來補補吧 SQL(Struct Query Language) 結構化查詢語言&#xff0c;屬于第四代語言&#xff08;接近于自然語言&#xff09;符合主謂賓定狀補 DDL (Data Define L)數據定義語言,創建一個數據庫&#xff0c;創建一個…

主成分分析資料

推薦一份介紹主成分分析的資料&#xff1a;http://www.cs.otago.ac.nz/cosc453/student_tutorials/principal_components.pdf&#xff0c;寫的很好&#xff01; 在R語言中使用PCA&#xff1a;http://www.cnblogs.com/bigshuai/archive/2012/06/18/2553808.html 轉載于:https://…

關于mysql的binlog寫滿磁盤而導致mysql無法連接的問題。

問題描述與追蹤 首先是mysql連不上&#xff1a; [rootVM-90-225-centos ~]# mysql -uroot -p Enter password: ERROR 2002 (HY000): Cant connect to local MySQL server through socket /var/lib/mysql/mysql.sock (111)然后查看mysql的狀態&#xff1a; [rootVM-90-225-c…

.NET系統架構改造的經驗和教訓

轉自&#xff1a; http://robbinfan.com/blog/43/rid-off-dotnet-experience 在互聯網行業&#xff0c;基于Unix/Linux的網站系統架構毫無疑問是當今主流的架構解決方案&#xff0c;這不僅僅是因為Linux本身足夠的開放性&#xff0c;更因為圍繞傳統Unix/Linux社區有大量的成熟開…

yum error :No module named yum

Yum&#xff08;全稱為 Yellow dog Updater, Modified&#xff09;是一個在Fedora和RedHat以及SUSE、CentOS中的Shell前端軟件包管理器。基於RPM包管理&#xff0c;能夠從指定的服務器自動下載RPM包并且安裝&#xff0c;可以自動處理依賴性關系&#xff0c;并且一次安裝所有依賴…

403報錯解決方案

403報錯解決方案 服務器使用yum install httpd時出現403報錯&#xff0c;參考了幾個文章&#xff1a; 首先根據這篇文章&#xff1a; devcloud上yum install 安裝軟件報錯403 打開 /root/.bashrc 文件&#xff0c;然后在最末尾可以看到 no_proxy&#xff1a; export no_pr…

控制器中獲取Field值

在ASP.NET MVC程序中&#xff0c;我們需要POST Data到制器中&#xff0c;是有很多方法。但是我們想在控制器中&#xff0c;獲取Feild值呢&#xff1f;怎樣獲取&#xff1f;你可以留意到有一個類FormCollection。它能幫助到我們解決這個問題。 舉個簡單的例子。在ASP.NET MVC應用…

new(std::nothrow)

new(std::nothrow) 顧名思義&#xff0c;即不拋出異常&#xff0c;當new一個對象失敗時&#xff0c;默認設置該對象為NULL&#xff0c;這樣可以方便的通過if(p NULL) 來判斷new操作是否成功 普通的new操作&#xff0c;如果分配內存失敗則會拋出異常&#xff0c;雖然后面一般也…

如何刪除cygwin

網上大多數方法在不具備用戶權限獲取的情況下都不能工作。 國外有人通過很簡單的命令行就實現了&#xff1a; Here’s how to remove Cygwin once and for all. You will need Cygwin cmd.exe 2 minutesRun cmd, navigate to C:\ (or other disk, if you have installed it in …

私有RTP協議和標準流媒體協議

先介紹下RTP協議&#xff1a; 實時傳輸協議RTP&#xff08;Real-time Transport Protocol&#xff09;是一個網絡傳輸協議 &#xff0c;該協議詳細說明了在互聯網上傳遞音頻和視頻的標準數據包格式 。 RTP標準定義了兩個子協議 &#xff0c;RTP和RTCP 數據傳輸協議RTP&#xff…

【python】入門學習(五)

字符串&#xff1a; 正索引&#xff0c;從0開始 和 負索引&#xff0c;從-1開始 >>> s apple >>> s[0] a >>> s[1] p >>> s[2] p >>> s[3] l >>> s[4] e >>> s[-1] e >>> s[-2] l >>> s[-3…

實現 winform 異步跨線程訪問UI控件

在開發winform時經常會用到多線程防止界面出現假死現象&#xff0c;比如當你單擊某個按鈕時&#xff0c;需要執行很多代碼&#xff0c;但是在執行過程中想實時的將當前執行的情況報告給用戶&#xff0c;類型進度條或文本什么的。 這個時候很顯然&#xff0c;如果你把要實現的內…

JavaScript對象的創建總結

方式 缺點 優點 基于已有對象擴充屬性和方法 不可重用&#xff0c;沒有約束 無 工廠方法 檢測不出是什么的實例 簡單封裝&#xff0c;可以傳參 構造方法 每創建一個對象就有開辟存放方法的空間 能通過instanceof檢測出實例類型&#xff0c;可以傳參 原型方式 不能…