Pase la identificación del modelo a PartialView para editar

Tengo una lista de objetos de fotografía que paso a una vista: -

Public class Photography
{
    public Photography()
    {
        Name = "";
        Description = "";
        Category = "";
        ImgUrl = "";
        IsAccordion = false;
    }
    public string Name { get; set; }
    public string Description { get; set; }
    public string Category { get; set; }
    public string ImgUrl { get; set; }
    public bool IsAccordion { get; set; }
}

En mi opinión, recorro la lista así:

@foreach (var item in Model.Photographys)
{
    <li class="span3" style="text-align: center">
        <div class="thumbnail thumbnail-1">
            <h3 style="margin-bottom: 10px;">@item.Name</h3>
            <div class="">
                <div class="">
                    <img src="@item.ImgUrl" alt="" style="visibility: visible; opacity: 1;">
                </div>
            </div>
            <section>
                <p>@item.Description</p>
                <a href="#" class="btn btn-1">Read More</a>
                <p>@item.IsAccordion</p>
            </section>
        </div>
    </li>
}

Lo que quiero hacer es tener una vista parcial que me permita editar las propiedades de la foto en la que hago clic. He creado una vista parcial usando el scaffoldoption "Editar". Se ve así:

@model aPhoto_web.Models.AdminPages.Photography

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        <h4>Photography</h4>
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="form-group">
            @Html.LabelFor(model => model.Name, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Name, "", new { @class = "text-danger" })
            </div>
        </div>
}

etcétera etcétera...

La mayoría de las vistas parciales de las que he leído se procesan directamente cuando se procesa la vista padre ... Eso no es lo que quiero ... Solo quiero que aparezca la vista parcial cuando de alguna manera le pase mi foto-objeto.

Sé que esta es una "gran" pregunta, pero si alguien puede señalarme en la dirección correcta, ¡sería genial! Gracias.

EDITAR para aclarar: Eche un vistazo a este código donde he agregado un "RenderPartial" en la parte inferior del bucle.

@foreach (var item in Model.Photographys)
{
    <li class="span3" style="text-align: center">

        <div class="thumbnail thumbnail-1">
            <h3 style="margin-bottom: 10px;">@item.Name</h3>

            <div class="">
                <div class="">
                    <img src="@item.ImgUrl" alt="" style="visibility: visible; opacity: 1;">
                </div>
            </div>

            <section>                          
                <p>@item.Description</p>
                <a href="#" class="btn btn-1">Read More</a>
                <p>@item.IsAccordion</p>
            </section>
        </div>

        @{
            Html.RenderPartial("_editPhoto", item);
        }
    </li>
}

Esto genera una vista parcial de cada elemento del ciclo, por supuesto. Me gustaría un método que pase el objeto en el que hago clic al parcial ...

EDITAR:

public ActionResult EditPhoto(string id)
{
    var photo = RavenSession.Load<ContentPage>(id) as Photography;
    return PartialView("_editPhoto", photo);  
}

Respuestas a la pregunta(1)

Su respuesta a la pregunta