㈠ 如何自學oracle資料庫
你想學oracle幹嘛用,oracle資料庫可是大型資料庫,不說一般,就是中型企業也支付不起一年幾千萬的使用費。初學者可以先學mysql資料庫。
mysql和oracle一樣都支持sql語法,都是關系型資料庫。不同的是存儲過程不一樣,許可權管理不一樣。mysql現在是中小型企業的主流。你可以考慮一下。
你可以想想一個oracle資料庫工程師的要求,即使你達到了,企業也不敢用年輕人。所以先主要已mysql入手。
最好買一本適合初學者的書,買別的書估計初學者看不懂。再結合網上的教程,資料。
如何純粹是為了好玩,那就隨心所欲吧。首先學習什麼是關系型資料庫,關系型資料庫的特點和數據是如何查詢的這些都有助於你今後對資料庫的理解。作為一個能寫出高效的sql語句的程序員來說這個必須要理解。
然後學習sql語句,sql語句主要是對表的操作。查詢,刪除,修改,添加等操作。
然後再學習觸發器,存儲過程,視圖,控制器 。
學到這里就有一定的基礎了,接下來可以選擇學習方向,你可以深入學習資料庫許可權管理,你可以學習更多的資料庫函數來寫出高效的sql語句。
㈡ sqlserver
摘自:http://database.ctocio.com.cn/analysis/465/7709465.shtml
【IT專家網獨家】SQL Server用戶自定義函數和存儲過程有類似的功能,都可以創建捆綁SQL語句,存儲在server中供以後使用。這樣能夠極大地提高工作效率,通過以下的各種做法可以減少編程所需的時間:
重復使用編程代碼,減少編程開發時間。
隱藏SQL細節,把SQL繁瑣的工作留給資料庫開發人員,而程序開發員則集中處理高級編程語言。
維修集中化,可以在一個地方做業務上的邏輯修改,然後讓這些修改自動應用到所有相關程序中。
乍看之下,用戶自定義函數和存儲過程的功能似乎一摸一樣。但是,其實這兩者之間還有一些雖然細微但是很重要的差異:
存儲過程是使用EXEC命令獨立調用的,而用戶自定義函數是在另一個SQL語句中調用的。
l存儲程序是允許用戶和程序去使用存儲過程,而不是允許其存取表格,這樣能夠增強程序安全性。與標準的SQL Server相比,存儲程序限制用戶行動許可權方面更為細化。例如,如果你有一個貨存表格,每次賣出一個貨物收銀員都要對表格進行更新一次(從貨存中把該貨品減去一件)。你可以給收銀員設置許可權,允許其使用decrement_item存儲過程,而不是允許他們有任意修改或村表格的許可權。
函數必須始終返回一個值(一個標量值或一個表格)。而存儲過程可以返回一個標量值、一個表值或無需返回值。
總而言之,存儲程序對SQL Server開發員來說是最有價值的寶物之一,用於資料庫中,能夠大大的提高工作效率,增強安全性,絕對超值。
㈢ 存儲過程和觸發器到底是個什麼玩意
存儲過程相當於打包好的sql語法,可以包含復雜的sql操作,在程序調用時只要執行該存儲過程,一句話就可以完成復雜的資料庫操作.
觸發器是也是打包好的sql語法,只不過執行它的條件是當被設定改觸發器的表有變化的時候.比如我可以寫一個觸發器,設定它在插入一筆數據到這個表裡的時候,去同步另一個表.那麼在程序里我只要做到往資料庫里插一筆數據,那麼另一個表就可以同時被更新.
用存儲過程和資料庫的好處是,可以充分利用資料庫資源,減少程序代碼,程序員的工作將更簡便,寫出來的代碼也更簡潔明了.當然要真正明白程序在做什麼,還是要到存儲過程和觸發器裡面看明白.
呵呵,這些都是本人自身體會,你可以有選擇的看看.
㈣ 存儲過程和函數的區別
一、含義不同
1、存儲過程:存儲過程是 SQL 語句和可選控制流語句的預編譯集合,以一個名稱存儲並作為一個單元處理。
2、函數:是由一個或多個 SQL 語句組成的子程序,可用於封裝代碼以便重新使用。函數限制比較多,如不能用臨時表,只能用表變數等
二、使用條件不同
1、存儲過程:可以在單個存儲過程中執行一系列 SQL 語句。而且可以從自己的存儲過程內引用其它存儲過程,這可以簡化一系列復雜語句。
2、函數:自定義函數諸多限制,有許多語句不能使用,許多功能不能實現。函數可以直接引用返回值,用表變數返回記錄集。但是,用戶定義函數不能用於執行一組修改全局資料庫狀態的操作。
三、執行方式不同
1、存儲過程:存儲過程可以返回參數,如記錄集,函數只能返回值或者表對象。存儲過程的參數有in,out,inout三種,存儲過程聲明時不需要返回類型。
2、函數:函數參數只有in,而函數需要描述返回類型,且函數中必須包含一個有效的return語句。
㈤ 關於存儲過程與事務
這兩個概念可以說是兩個范疇的概念,事務是資料庫操作范疇的概念,保證資料庫數據的完整性和一致性;存儲過程是高級程序設計中模塊化設計思想的重要內容。
事務是包含一組修改(插入、更新和刪除)的工作的邏輯單位。事務的操作要麼被保存到資料庫commit,要麼回滾rollback,事務中的所有修改要麼全部提交,要麼什麼也不做,這樣保證了資料庫中數據的完整性和一致性。
資料庫操作中為了完成一個完整的資料庫任務,從而引進高級程序的設計要素。過程就是高級程序設計語言中的模塊概念,將一些內部聯系的命令組成一個個過程,通過參數在過程間傳遞數據來完成一個完整的資料庫任務,這就是模塊化設計思想的重要內容。
有的時候可以把一個過程看作一個事務,但是有的過程運行過程中因為滿足某些條件而從過程中跳出,這時就不能把過程看作事務;反之,一個事務可能是一個過程,也可能一個事務中包含對一個或多個過程的調用。
二者概念所述的范疇不同,在資料庫中,是相互聯系相互區別的;而且兩者都是具體的,不是抽象的,因為都可以拿出一段代碼,說它是事務或是存儲過程。
以上是個人理解,希望對你有所幫助。
㈥ 資料庫系統原理 什麼是存儲過程有什麼優點
存儲過程也可以看成是函數的一種, 而且存儲過程中的過程如果放到了開發 系統的 D 層的時候執行效果也是相同的。 存儲過程是存儲在資料庫中的一個程序 塊, 裡麵包含了自己定義的一段程序來實現相應的功能,比如要選擇資料庫的表 裡面的記錄,就可以使用下面的存儲過程的框架:
這個實現的過程比較簡單, 就是利用的是資料庫自帶的存儲過程的模版,新 建存儲過
程的時候就可以非常方便的實現自己所需要的功能。 存儲過程中使用的 是資料庫的語言, 跟其他的高級語言的用法相似,熟練的使用資料庫的語言可以 加快開發的效率,技術也是很厲害的。 存儲過程的到底有什麼好處呢?一定要用存儲過程嗎? 存儲過程的優點: 1.存儲過程只在創造時進行編譯,以後每次執行存儲過 程都不需再重新編譯,而一般 SQL 語句每執行一次就編譯一次,所以使用存儲過 程可提高資料庫執行速度。 2.當對資料庫進行復雜操作時,可將此復雜操作用 存儲過程封裝起來與資料庫提供的事務處理結合一起使用。更多資料庫的知識, 盡在南京寶雲官網。 3.存儲過程可以重復使用,可減少資料庫開發人員的工作量 4.安全性高,可設定只有某此用戶才具有對指定存儲過程的使用權。 存儲過程有利於實現一系列的操作簡化,提高系統的執行效率,而且放在存 儲過程中的 SQL 語句是直接在資料庫中編譯過了的, 系統在執行的時候就可以減 少這部分代碼的資源開銷。 但是對於機房重構中,有時候我們只需要更新一個記錄中的某一個欄位的值, 這個時候用存儲過程就有點不劃算了,這個時候系統如 果不用存儲過程直接用 SQL 語句來說,是比較方便的。所以存儲過程並不是所有 的地方用都好,凡事都有一個合適的問題,一個度的問題。 可能有的人想存儲過程這么有用,而且對系統的性能有提升,那就強迫症的 都去使用存儲過程。 這里又有一個問題了,存儲過程的作用主要是對資料庫進行 操作, 那麼學過資料庫系統原理的我們就需要注意一個問題了,如何防止死鎖? 毫無節制的使用存儲過程, 而不考慮資料庫結構是不科學的。對於相同的表進行 不同的操作,所產生的結果也是不一樣的,產生的順序也是不一樣的,如何在存 儲過程中進行有效的操作來使系統健康強壯,這是需要注意的。 通過使用存儲過程, 可以更加清晰的理解資料庫和系統是如何相互關聯工作 的,存儲過程的使用不僅是一種技術上的提升,更是思想上的一種啟發,在今後 的開發工作中是否有相同的地方需要這樣的抽象封裝呢。 面對更多的重復出現的 封裝,我們的工作也將更加高效、簡潔。
㈦ 什麼是計算機硬體工程師、程序員、網路管理員、系統維護專家及資料庫管理人員
硬體工程師
主要負責
電腦硬體
的設計,維修。主要是這2個方面,還有的還要參與編程,但都是單片機編程!
程序員就是寫程序代碼的一些人,分初級到高級,按級別編寫不同的代碼,初級主要寫一些簡單的,比如前台代碼,高級主要寫核心部分!
網路管理員
主要管理的是網路連接,維護,伺服器的管理,
路由器
的配置,和網路的組建!
系統維護
專家主要乾的是硬體與軟體方面的結合部分,難度挺大的。
資料庫管理員
主要負責編寫資料庫
存儲過程
和資料庫文檔的編寫,還要寫
幫助文件
,和各個資料庫之間的轉換!
在一些大一點的軟體公司這些人都不可缺少!