mvc調用存儲過程
Ⅰ .net mvc 怎樣調用 存儲過程詳細點最好有例子
由於問題主要是存儲過程,以下例子的架構會直接點,Controller直接依賴sqlRepository,而未用到依賴注入。。
所以,架構方面千萬不要參考了這個例子。。
費話不多說,先講資料庫。舉例的資料庫(SQLServer 2008)名為TestDB01,僅有的一張表表名為UserInfo,表有皆不可為空的三個欄位,分別為UserID(int),UserName(nvarchar(50)),UserAge(smallint),其有一條記錄為UserID:1,UserName:Lcng,UserAge22。
接下來是寫在資料庫里的存儲過程,如下:
USE [TestDB01]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [dbo].[myProcere] 
 @parameter1 int
AS
BEGIN
 SET NOCOUNT ON;
 SELECT * from [UserInfo] where [UserInfo].UserID = @parameter1 
END
希望我復制粘貼時沒有出錯,當然,如果你對存儲過程熟悉的話你會發現我的錯誤,如果有的話。。
存儲過程表達的意思在此就不說了(想你應該熟悉存儲過程),如果需要,請補充問題。。
接下來就是Visual Studio 2010里的工作了。
新建一個空ASP.NET MVC 2項目,我取的項目名是UsingProcereInMVC,往項目里加一個名為Repositories的文件夾,此文件夾用來存放對資料庫的操作的類,一會兒會講,先看Models文件夾。
往Models文件夾里加一個名叫Person的類,Person類如下:
public class Person
    {
        public string PersonName { get; set; }
        public short PersonAge { get; set; }
    }
現在回到Repositories文件夾,往這個文件夾里加一個名叫SqlRepository的類,SqlRepository類如下:
public class SqlRepository
    {
        private List<Person> personList = new List<Person>();
        public List<Person> PersonList
        {
            get
            {
                return personList;
            }
        }
        public SqlRepository(string connectionString)
        {
            SqlConnection sqlconn = new SqlConnection(connectionString);
            SqlCommand sqlcmd = new SqlCommand("myProcere", sqlconn);
            sqlcmd.CommandType = CommandType.StoredProcere;
            SqlDataReader rd;
            try
            {
                sqlconn.Open();
                sqlcmd.Parameters.Add(new SqlParameter("@parameter1", SqlDbType.Int));
                sqlcmd.Parameters["@parameter1"].Value = 1;
                rd = sqlcmd.ExecuteReader();
                while (rd.Read())
                {
                    personList.Add(new Person { PersonAge = (short)rd[2], PersonName = rd[1].ToString() });
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }
            finally
            {
                sqlconn.Close();
            }
        }
同樣,希望我的復制粘貼沒有出錯。。
希望對於此類需要講解的只有以下這些內容,如
SqlCommand sqlcmd = new SqlCommand("myProcere", sqlconn);
sqlcmd.CommandType = CommandType.StoredProcere;
如果你用過ASP.NET WebForm,那麼對這兩條中的第一條語句你應該很熟悉,相對於ASP.NET WebForm,SqlCommand sqlcmd = new SqlCommand("myProcere", sqlconn);只是把第一個參數由原來的SQL語句換成了定義在資料庫里的存儲過程的名字;而第二條語句只是告訴sqlcmd它的命令類型而已。
當然,我還要說的是,其實這根本就是在ASP.NET WebForm可以用的用法,只是我把它放到ASP.NET MVC里舉例子了而已。。其實我們完全可以或說應當使用LINQ。。
還有兩條要說的語句是
sqlcmd.Parameters.Add(new SqlParameter("@parameter1",SqlDbType.Int));
sqlcmd.Parameters["@parameter1"].Value = 1;
要說的是@parameter1就是定義存儲過程里的那個參數,這里給這個參數的值為1,它完全可以根據你的需要而變。
接著看Controllers里的HomeController,它唯一的一個action就是Index(),定義如下
public ViewResult Index()
        {
            SqlRepository sr = new SqlRepository(WebConfigurationManager.ConnectionStrings["connectionString01"].ConnectionString);
            return View(sr.PersonList);
        }
如果對此有不明之處,請補充問題。。
最後是強類型(類型為List<UsingProcereInMVC.Models.Person>)的名叫Index的View,主要內容如下
<body>
    <div>
        <% foreach (var v in Model)
           { %>
                Name:<%: v.PersonName %><br />
                Age: <%: v.PersonAge %><br />
        <% } %>
    </div>
</body>
如果你按著這個例子做,顯示的結果將會是
Name:Lc
Age: 22
祝你好運(當然,這條是不會顯示的)。。
希望可以幫到你,如果還有疑問,請補充問題。
如果這對你有幫助,請標為最佳答案。
Ⅱ 在ASP.NET MVC中如何使用EF調用存儲過程
要用EF調用存儲過程,必須將這個存儲過程拖拽到EF對應的文件中來,這樣這個存儲過程就自動變成了一個函數。例如存儲p_GetProct。那麼使用的時候
using(DataContext oDataContext=new DataContext())//EF對應的上下文對象
{
    oDataContext.p_GetProct();//直接通過這樣調用就行了。當然,如果存儲過程有參數,也可以通過這個函數傳遞參數。
}
希望可以幫到你。
Ⅲ MVC5加EF6 執行存儲過程 獲取表
zty_ABMXSFX 應該是你資料庫裡面對應的存儲過程
EF會把存儲過程映射為上下文中的一個方法, 起返回值為存儲過程中SELECT出來的值或結果集合
Ⅳ mvc中怎樣調用存儲過程
像簡單點的話。可以考慮在存儲過程中多加一個參數在存儲過程中進行判斷好了。
資料庫執行只會考慮登錄資料庫的許可權問題。和登錄系統的用戶名是2回事。 
如果對您有幫助,請記得採納為滿意答案,謝謝!祝您生活愉快!
vaela
Ⅳ springmvc + mybatis 怎麼調用存儲過程
不知道怎麼調用,但是可不可以在代碼里實現存儲過程所完成的功能啊,為什麼要在資料庫端進行操作
Ⅵ 求spring MVC + EXTJS + MSSQL 增刪改不用自帶的方法,直接帶參數調用後台存儲過程,請大俠提供例子
一、SpringMVC註解入門
1. 創建web項目
2. 在springmvc的配置文件中指定註解驅動,配置掃描器
Xml代碼  
<!-- mvc的註解驅動 -->  
<mvc:annotation-driven />  
  
<!--只要定義了掃描器,註解驅動就不需要,掃描器已經有了註解驅動的功能 -->  
<context:component-scan base-package="org.study1.mvc.controller" />  
  
<!-- 前綴+ viewName +後綴 -->  
<bean  
    class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
    <!-- WebContent(WebRoot)到某一指定的文件夾的路徑 ,如下表示/WEB-INF/view/*.jsp -->  
    <property name="prefix" value="/WEB-INF/view/"></property>  
    <!-- 視圖名稱的後綴 -->  
    <property name="suffix" value=".jsp"></property>  
</bean>  
<context:component-scan/> 掃描指定的包中的類上的註解,常用的註解有:
@Controller 聲明Action組件
@Service    聲明Service組件    @Service("myMovieLister") 
@Repository 聲明Dao組件
@Component   泛指組件, 當不好歸類時. 
@RequestMapping("/menu")  請求映射
@Resource  用於注入,( j2ee提供的 ) 默認按名稱裝配,@Resource(name="beanName") 
@Autowired 用於注入,(srping提供的) 默認按類型裝配 
@Transactional( rollbackFor={Exception.class}) 事務管理
@ResponseBody
@Scope("prototype")   設定bean的作用
3. @controller:標識當前類是控制層的一個具體的實現
4. @requestMapping:放在方法上面用來指定某個方法的路徑,當它放在類上的時候相當於命名空間需要組合方法上的requestmapping來訪問。
java代碼  
@Controller // 用來標注當前類是springmvc的控制層的類  
@RequestMapping("/test") // RequestMapping表示 該控制器的唯一標識或者命名空間  
public class TestController {  
  
    /** 
     * 方法的返回值是ModelAndView中的 
     */  
    @RequestMapping("/hello.do") // 用來訪問控制層的方法的註解  
    public String hello() {  
        System.out.println("springmvc annotation... ");  
        return "jsp1/index";  
    }  
  
    //*****  
}  
在本例中,項目部署名為mvc,tomcat url為 http://localhost,所以實際為:http://localhos/mvc
在本例中,因為有命名空間 /test,所以請求hello方法地址為:http://localhost/mvc/test/hello.do
輸出:springmvc annotation...
二、註解形式的參數接收
1. HttpServletRequest可以直接定義在參數的列表,通過該請求可以傳遞參數
url:http://localhost/mvc/test/toPerson.do?name=zhangsan
Java代碼  
/** 
 * HttpServletRequest可以直接定義在參數的列表, 
 *  
 */  
@RequestMapping("/toPerson.do")  
public String toPerson(HttpServletRequest request) {  
    String result = request.getParameter("name");  
    System.out.println(result);  
    return "jsp1/index";  
}  
 可以從HttpServletRequest 取出「name」屬性,然後進行操作!如上,可以取出 「name=zhangsan」
輸出:zhangsan
2. 在參數列表上直接定義要接收的參數名稱,只要參數名稱能匹配的上就能接收所傳過來的數據, 可以自動轉換成參數列表裡面的類型,注意的是值與類型之間是可以轉換的
2.1傳遞多種不同類型的參數:
url:http://localhost/mvc/test/toPerson1.do?name=zhangsan&age=14&address=china&birthday=2000-2-11
Java代碼  
/** 
 * 傳遞的參數的名字必須要與實體類的屬性set方法後面的字元串匹配的上才能接收到參數,首字元的大小寫不區分 
 * 請求中傳的參數只要是能和參數列表裡面的變數名或者實體裡面的set後面的字元串匹配的上就能接收到 a 
 *  
 */  
@RequestMapping("/toPerson1.do")  
public String toPerson1(String name, Integer age, String address,  
             Date birthday) {  
           System.out.println(name + " " + age + " " + address + " " + birthday);  
           return "jsp1/index";  
}  
  
/** 
 * 注冊時間類型的屬性編輯器,將String轉化為Date 
 */  
@InitBinder  
public void initBinder(ServletRequestDataBinder binder) {  
    binder.registerCustomEditor(Date.class, new CustomDateEditor(  
            new SimpleDateFormat("yyyy-MM-dd"), true));  
}  
輸出:zhangsan 14 china Fri Feb 11 00:00:00 CST 2000
2.2傳遞數組:
url:http://localhost/mvc/test/toPerson2.do?name=tom&name=jack  
Java代碼  
/** 
 * 對數組的接收,定義為同名即可  
 */  
@RequestMapping("/toPerson2.do")  
public String toPerson2(String[] name) {  
    for (String result : name) {  
        System.out.println(result);  
    }  
    return "jsp1/index";  
}  
 輸出:tom jack
2.3傳遞自定義對象(可多個):
url:http://localhost/mvc/test/toPerson3.do?name=zhangsan&age=14&address=china&birthday=2000-2-11
 User 定義的屬性有:name,age,並且有各自屬性的對應的set方法以及toString方法
 Person定義的屬性有:name,age.address,birthday,並且有各自屬性的對應的set方法以及toString方法
Java代碼  
/** 
 *  
 * 傳遞的參數的名字必須要與實體類的屬性set方法後面的字元串匹配的上才能接收到參數,首字元的大小寫不區分 
 * 請求中傳的參數只要是能和參數列表裡面的變數名或者實體裡面的set後面的字元串匹配的上就能接收到  
 *  
 */  
@RequestMapping("/toPerson3.do")  
public String toPerson3(Person person, User user) {  
    System.out.println(person);  
    System.out.println(user);  
    return "jsp1/index";  
}  
  輸出:
Person [name=zhangsan, age=14, address=china, birthday=Fri Feb 11 00:00:00 CST 2000]
User [name=zhangsan, age=14] 
自動封裝了對象,並且被分別注入進來!
Ⅶ MVC中通過.edmx調用存儲過程處理返回值
int r=0;
System.Data.Objects.ObjectParameter result = new System.Data.Objects.ObjectParameter("Result",System.Data.DbType.Int32);
movies.Movies_Create(Title, Convert.ToDateTime("ReleaseDate"), Genres_List, Price, Rating, result);
r=(int)result.Value;//r就是你所需要的返回值
Ⅷ mvc 怎麼執行mysql里的存儲過程
比方說你創建存儲過程的語句如下:
create procere test_proc(count int)
那麼執行存儲過程的語句就是:
call test_proc(500);
Ⅸ 怎麼在DAO層調用存儲過程。
首先解釋面上意思,service是業務層,是數據訪問層。
呵呵,這個問題我曾經也有過,記得以前剛學編程的時候,都是在service里直接調用,service裡面就new一個類對象,調用,其他有意義的事沒做,也不明白有這個有什麼用,參加工作久了以後就會知道,業務才是工作中的重中之重。
我們都知道,標准主流現在的編程方式都是採用mvc綜合設計模式,mvc本身不屬於設計模式的一種,它描述的是一種結構,最終目的達到解耦,解耦說的意思是你更改某一層代碼,不會影響我其他層代碼,如果你會像spring這樣的框架,你會了解面向介面編程,表示層調用控制層,控制層調用業務層,業務層調用數據訪問層。初期也許都是new對象去調用下一層,比如你在業務層new一個類的對象,調用類方法訪問資料庫,這樣寫是不對的,因為在業務層中是不應該含有具體對象,最多隻能有引用,如果有具體對象存在,就耦合了。當那個對象不存在,我還要修改業務的代碼,這不符合邏輯。好比主板上內存壞了,我換內存,沒必要連主板一起換。我不用知道內存是哪家生產,不用知道多大容量,只要是內存都可以插上這個介面使用。這就是mvc的意義。
接下來說你感覺service的意義,其實因為你現在做東西分層次不是那麼嚴格,在一個你們做東西業務本身也少,舉個最簡單的例子,你做一個分頁的功能,數據1000條,你20條在一個頁,你可以把這個功能寫成工具類封裝起來,然後在業務層里調用這個封裝的方法,這才是業務里真正幹得事,只要沒訪問資料庫的,都要在業務里寫。
再有不明白的追問,這是經驗問題,呵呵,其實以後你就會懂。只是剛開始寫的代碼都是有個請求,我就去資料庫取,業務幾乎沒有。
Ⅹ springmvc mybatis 存儲過程怎麼調用
mybatis  配置 裡面 寫好存儲過程,然後直接調用。
編輯userMapper.xml
編輯userMapper.xml文件,添加如下的配置項
1 <!-- 
 2         查詢得到男性或女性的數量, 如果傳入的是0就女性否則是男性
 3      -->
 4     <select id="getUserCount" parameterMap="getUserCountMap" statementType="CALLABLE">
 5         CALL mybatis.ges_user_count(?,?)
 6     </select>
 7     
 8     <!--
 9         parameterMap.put("sexid", 0);
10         parameterMap.put("usercount", -1);
11      -->
12     <parameterMap type="java.util.Map" id="getUserCountMap">
13         <parameter property="sexid" mode="IN" jdbcType="INTEGER"/>
14         <parameter property="usercount" mode="OUT" jdbcType="INTEGER"/>
15     </parameterMap>
四、編寫單元測試代碼
1 package me.gacl.test;
 2 
 3 import java.util.HashMap;
 4 import java.util.List;
 5 import java.util.Map;
 6 
 7 import me.gacl.custom.model.ConditionUser;
 8 import me.gacl.domain.User;
 9 import me.gacl.util.MyBatisUtil;
10 import org.apache.ibatis.session.SqlSession;
11 import org.junit.Test;
12 
13 /**
14  * @author gacl
15  * 測試調用存儲過程
16  */
17 public class Test6 {
18     
19     @Test
20     public void testGetUserCount(){
21         SqlSession sqlSession = MyBatisUtil.getSqlSession();
22         /**
23          * 映射sql的標識字元串,
24          * me.gacl.mapping.userMapper是userMapper.xml文件中mapper標簽的namespace屬性的值,
25          * getUserCount是select標簽的id屬性值,通過select標簽的id屬性值就可以找到要執行的SQL
26          */
27         String statement = "me.gacl.mapping.userMapper.getUserCount";//映射sql的標識字元串
28         Map<String, Integer> parameterMap = new HashMap<String, Integer>();
29         parameterMap.put("sexid", 1);
30         parameterMap.put("usercount", -1);
31         sqlSession.selectOne(statement, parameterMap);
32         Integer result = parameterMap.get("usercount");
33         System.out.println(result);
34         sqlSession.close();
35     }
36 }
