Выполнить SQL-запрос WCF RIA Silverlight - PullRequest
0 голосов
/ 17 апреля 2011

Я создал базу данных, связал ее с DomainService в моем приложении Silverlight.Теперь я хочу иметь возможность выполнять определенные действия, такие как регистрация, вход в систему и т. Д. С помощью службы.

Как бы я мог это сделать.У меня есть предустановленные методы, созданные в службе, например, InsertUser, но для этого требуется только один параметр, поэтому я не уверен, как он работает.В метаданных у меня есть все поля и т. Д.

Может кто-нибудь помочь мне здесь.

Спасибо.

public IQueryable<User> GetUsers()
        {
            return this.ObjectContext.Users;
        }

public void InsertUser(User user)
        {
            if ((user.EntityState != EntityState.Detached))
            {
                this.ObjectContext.ObjectStateManager.ChangeObjectState(user, EntityState.Added);
            }
            else
            {
                this.ObjectContext.Users.AddObject(user);
            }
        }

Для получения пользователя, которого я использовал (в качестве основы дляКод TBohnen.jnr):

UserContext _userContext = new UserContext();

        public MainPage()
        {
            InitializeComponent();
            LoadOperation loGetUsers = _userContext.Load(_userContext.GetUsersQuery());
            loGetUsers.Completed += new EventHandler(loGetUsers_Completed);
        }

        void loGetUsers_Completed(object sender, EventArgs e)
        {
            LoadOperation<Web.User> lo = (LoadOperation<Web.User>)sender;
            var user = _userContext.Users;
            MessageBox.Show(user.ToString());
        }

1 Ответ

2 голосов
/ 17 апреля 2011

Это добавление нового пользователя:

YourDomainContext dc = new YourDomainContext();
User userToAdd = new User();
//You will have to set your properties here as I don't know them, I will give an example.
userToAdd.username = "NewUser"; 
dc.User.Add(userToAdd);
dc.SubmitChanges();

Для извлечения существующих пользователей:

YourDomainContext dc = new YourDomainContext();
LoadOperation loGetUsers = dc.Load(dc.GetUsersQuery());
loGetUsers.Completed += new EventHandler( loadOperation_Completed );// You will see there is a callback overloads as well

and then add this as well.

private void loadOperation_Completed( object sender, EventArgs e )
{
    LoadOperation<User> lo = (LoadOperation<User>)sender;
    //Have a look at all the properties like lo.Error etc. but to see the retrieved users you can either use:
    var users = lo.AllEntities;
    //or if you declared your domaincontext as a class level parameter:
    var users = dc.User;
    foreach (Web.User user in users)
    {
        MessageBox.show(user.username);
    }
}

Это вызовет асинхронный вызов, который получит все пользователи и добавит его.к DomainContext, и вы сможете получить к нему доступ через dc.User

...