|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
I have just downloaded the controls and started to work on it , but realised is there any way for inserting the values in the database using the grid control and sql data source If you post some example or link me to that example, it would be great help. Many Thanks, Teju
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
Hi, This is a two step process. The first step is to allow user to insert new items into the Grid. The second step is to save the newly inserted items into your DB. The first step can be easily done by setting the Grid's AllowNewItem to true. Note in order for user to edit, you must have an editable column. The following sample assumes you have a Grid with two column: The first column is a RowNumberColumn (which is not editable), the second column is a TextBoxColumn, which is editable. Once you run the page, you can add new items into the Grid. You would then post back the page (by clicking a button, for example). Once the page is posted back, you will need to save the newly added items into your DB. The key for saving the records is AddedItems property. You would basically loop through AddedItems and call whatever your database code to do the work. For example:
Code: C#
//Open the DB connection
SqlConnection cn = new SqlConnection("your connection string here...");
cn.Open();
//User can add more than items, so we loop through each of them
foreach (EO.Web.GridItem item in grid1.AddedItems)
{
//Get the cell value in the second column
string someText = item.Cells[1].Value;
//Now insert the record
string sql = string.Format(
"insert into your_table values ('{0}')", someText);
SqlCommand cmd = new SqlCommand(sql, cn);
cmd.ExecuteNonQuery();
}
//Close the connection
cn.Close();
You can put this code inside your "Save" Button's Click handler. Note the SQL related code (open connection, call insert statement) is just for demonstration purpose. It's almost certainly that you will need to change that part so that it works with your own database. Hope this helps. Thanks!
|
|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
Hi, Thanks very much for your reply. I did try to use it and seemed to work but not to solve the whole purpose. I am trying to loop through all the elements of the gridview ie. the textbox as i won't know how many rows willl be appended. But i just get the value of the first row . I don't know what wrong Iam doing. If you could help me that would be great. In mean time i will dig further. Many Thanks, Teju
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
Hi, I am not sure why you want to to loop through all the elements of the Grid (not GridView! Make sure you are using our product, not somebody else.:P). You need to loop AddedItems for added items, ChangedItems for changed items, DeletedItems for deleted items. Those property contains all information you will need. For example, if user has appended two items, then you will see AddedItems property contains two GridItem object. If user has modified three items, you will ChangedItems contains three GridItem object. Even if the Grid contains 100 items, you will only care about what user modified/changed/deleted when it comes to update your DB. You can find more information about handling Grid editing here: http://www.essentialobjects.com/ViewDoc.aspx?t=Grid%2fediting.htmlHope this helps. Thanks
|
|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
I am definitely using the eo grid below is my code . What i am doing is trying to print all the newly added items .
Code: Visual Basic.NET
Dim ansgrid As EO.Web.Grid = dvQuestions.FindControl("grdAnswers")
For Each item As EO.Web.GridItem In ansgrid.AddedItems
'Get the cell value in the second column
Dim someText As String = item.Cells(0).Value
Response.Write(someText)
Response.End()
Next
Could you tell me what wrong AM i doing. Many Thanks, Teju
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
You are very wrong by using Response.Write and Response.End. :) You should not use that. In fact if user added two items, your For Each would loop twice and you would have ended your Response twice (by calling Response.End twice). The easiest way to see what has been added is use a Label. You would put a Label in the page and then do something like this:
Code: Visual Basic.NET
Dim s as String = ""
For Each item As EO.Web.GridItem in ansgrid.AddedItems
'Get the value
Dim someText As String = item.Cells(0).Value
'Append it to s
s = s & someText
Next
'Now display it
Label1.Text = s
Obviously this are just for you to see what has been added. Eventually you will need to change the code to save the information into your database. Hope this helps. Thanks
|
|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
Oh silly me its because I am using response .end . I will follow what you say and change my code to reflect the added items in the database. Many Thanks, Teju
|
|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
Hi Sorry for getting so late back to you. I have used exactly the same way but i am unable to retrieve the data for second column. For e.g I have four column as below Item StartDate EndDate DueDate I can get all the values for Item but not for start date End date etc. Could you please help. Many Thanks, Teju
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
Hi,
Please create a complete test page and post both the .aspx and .vb code so that we can take a look. Make sure the code runs independently.
Thanks!
|
|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
Hi Sorry for giving you such a brief. Below is my aspx
Code: Visual Basic.NET
Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs)
Dim ansgrid As EO.Web.Grid = dvCourseWork.FindControl("grdCourseItem")
Dim s As String = ""
Dim s2 As String = ""
For Each item As EO.Web.GridItem In ansgrid.AddedItems
'Get the value
Dim txtanswers As String = item.Cells(0).Value
Dim txtcorrect As String = item.Cells(1).Value
'Append it to s
s = s & txtanswers
s2 = s2 & txtcorrect
Next
'Now display it
Label1.Text = s & "<br>" & s2
End Sub
Code: HTML/ASPX
<eo:Grid id="grdCourseItem" Width="99%" Height="200px" runat="server" ColumnHeaderDescImage="00050105"
BorderWidth="1px" IsCallbackByMe="False" BorderColor="#7F9DB9" Font-Size="8.75pt" Font-Names="Tahoma"
ColumnHeaderAscImage="00050104" GoToBoxVisible="True" GridLines="Both" FixedColumnCount="1"
ColumnHeaderDividerImage="00050103" GridLineColor="220, 223, 228" AllowNewItem="True"
FullRowMode="False">
<FooterStyle CssText="padding-bottom:4px;padding-left:4px;padding-right:4px;padding-top:4px;"></FooterStyle>
<ItemStyles>
<eo:GridItemStyleSet>
<ItemHoverStyle CssText="background-color: whitesmoke"></ItemHoverStyle>
<CellStyle CssText="padding-left:8px;padding-top:2px;"></CellStyle>
<ItemStyle CssText="background-color: white"></ItemStyle>
<FixedColumnCellStyle CssText="border-right: #d6d2c2 1px solid; padding-right: 10px; border-top: #faf9f4 1px solid; border-left: #faf9f4 1px solid; border-bottom: #d6d2c2 1px solid; background-color: #ebeadb; text-align: right"></FixedColumnCellStyle>
</eo:GridItemStyleSet>
</ItemStyles>
<ContentPaneStyle CssText="border-bottom-color:#7f9db9;border-bottom-style:solid;border-bottom-width:1px;border-left-color:#7f9db9;border-left-style:solid;border-left-width:1px;border-right-color:#7f9db9;border-right-style:solid;border-right-width:1px;border-top-color:#7f9db9;border-top-style:solid;border-top-width:1px;"></ContentPaneStyle>
<ColumnTemplates>
<eo:TextBoxColumn>
<TextBoxStyle CssText="BORDER-RIGHT: #7f9db9 1px solid; PADDING-RIGHT: 2px; BORDER-TOP: #7f9db9 1px solid; PADDING-LEFT: 2px; FONT-SIZE: 8.75pt; PADDING-BOTTOM: 1px; MARGIN: 0px; BORDER-LEFT: #7f9db9 1px solid; PADDING-TOP: 2px; BORDER-BOTTOM: #7f9db9 1px solid; FONT-FAMILY: Tahoma"></TextBoxStyle>
</eo:TextBoxColumn>
<eo:DateTimeColumn>
<DatePicker DayHeaderFormat="FirstLetter" DayCellHeight="16" DisabledDates="" TitleLeftArrowImageUrl="DefaultSubMenuIconRTL"
OtherMonthDayVisible="True" DayCellWidth="19" TitleRightArrowImageUrl="DefaultSubMenuIcon"
ControlSkinID="None" SelectedDates="" PickerFormat="dd/MM/yyyy" PickerHint="dd/mm/yyyy">
<DayHoverStyle CssText="font-family: tahoma; font-size: 12px; border-right: #fbe694 1px solid; border-top: #fbe694 1px solid; border-left: #fbe694 1px solid; border-bottom: #fbe694 1px solid"></DayHoverStyle>
<TitleStyle CssText="background-color:#9ebef5;font-family:Tahoma;font-size:12px;padding-bottom:2px;padding-left:6px;padding-right:6px;padding-top:2px;"></TitleStyle>
<DayHeaderStyle CssText="font-family: tahoma; font-size: 12px; border-bottom: #aca899 1px solid"></DayHeaderStyle>
<DayStyle CssText="font-family: tahoma; font-size: 12px; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></DayStyle>
<SelectedDayStyle CssText="font-family: tahoma; font-size: 12px; background-color: #fbe694; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></SelectedDayStyle>
<TitleArrowStyle CssText="cursor:hand"></TitleArrowStyle>
<TodayStyle CssText="font-family: tahoma; font-size: 12px; border-right: #bb5503 1px solid; border-top: #bb5503 1px solid; border-left: #bb5503 1px solid; border-bottom: #bb5503 1px solid"></TodayStyle>
<PickerStyle CssText="border-bottom-color:#7f9db9;border-bottom-style:solid;border-bottom-width:1px;border-left-color:#7f9db9;border-left-style:solid;border-left-width:1px;border-right-color:#7f9db9;border-right-style:solid;border-right-width:1px;border-top-color:#7f9db9;border-top-style:solid;border-top-width:1px;font-family:Courier New;font-size:8pt;margin-bottom:0px;margin-left:0px;margin-right:0px;margin-top:0px;padding-bottom:1px;padding-left:2px;padding-right:2px;padding-top:2px;"></PickerStyle>
<OtherMonthDayStyle CssText="font-family: tahoma; font-size: 12px; color: gray; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></OtherMonthDayStyle>
<CalendarStyle CssText="background-color: white; border-right: #7f9db9 1px solid; padding-right: 4px; border-top: #7f9db9 1px solid; padding-left: 4px; font-size: 9px; padding-bottom: 4px; border-left: #7f9db9 1px solid; padding-top: 4px; border-bottom: #7f9db9 1px solid; font-family: tahoma"></CalendarStyle>
<DisabledDayStyle CssText="font-family: tahoma; font-size: 12px; color: gray; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></DisabledDayStyle>
<MonthStyle CssText="font-family: tahoma; font-size: 12px; margin-left: 14px; cursor: hand; margin-right: 14px"></MonthStyle>
</DatePicker>
</eo:DateTimeColumn>
<eo:DateTimeColumn>
<DatePicker DayHeaderFormat="FirstLetter" DayCellHeight="16" DisabledDates="" TitleLeftArrowImageUrl="DefaultSubMenuIconRTL"
OtherMonthDayVisible="True" DayCellWidth="19" TitleRightArrowImageUrl="DefaultSubMenuIcon"
ControlSkinID="None" SelectedDates="" PickerFormat="dd/MM/yyyy">
<DayHoverStyle CssText="font-family: tahoma; font-size: 12px; border-right: #fbe694 1px solid; border-top: #fbe694 1px solid; border-left: #fbe694 1px solid; border-bottom: #fbe694 1px solid"></DayHoverStyle>
<TitleStyle CssText="background-color:#9ebef5;font-family:Tahoma;font-size:12px;padding-bottom:2px;padding-left:6px;padding-right:6px;padding-top:2px;"></TitleStyle>
<DayHeaderStyle CssText="font-family: tahoma; font-size: 12px; border-bottom: #aca899 1px solid"></DayHeaderStyle>
<DayStyle CssText="font-family: tahoma; font-size: 12px; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></DayStyle>
<SelectedDayStyle CssText="font-family: tahoma; font-size: 12px; background-color: #fbe694; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></SelectedDayStyle>
<TitleArrowStyle CssText="cursor:hand"></TitleArrowStyle>
<TodayStyle CssText="font-family: tahoma; font-size: 12px; border-right: #bb5503 1px solid; border-top: #bb5503 1px solid; border-left: #bb5503 1px solid; border-bottom: #bb5503 1px solid"></TodayStyle>
<PickerStyle CssText="border-bottom-color:#7f9db9;border-bottom-style:solid;border-bottom-width:1px;border-left-color:#7f9db9;border-left-style:solid;border-left-width:1px;border-right-color:#7f9db9;border-right-style:solid;border-right-width:1px;border-top-color:#7f9db9;border-top-style:solid;border-top-width:1px;font-family:Courier New;font-size:8pt;margin-bottom:0px;margin-left:0px;margin-right:0px;margin-top:0px;padding-bottom:1px;padding-left:2px;padding-right:2px;padding-top:2px;"></PickerStyle>
<OtherMonthDayStyle CssText="font-family: tahoma; font-size: 12px; color: gray; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></OtherMonthDayStyle>
<CalendarStyle CssText="background-color: white; border-right: #7f9db9 1px solid; padding-right: 4px; border-top: #7f9db9 1px solid; padding-left: 4px; font-size: 9px; padding-bottom: 4px; border-left: #7f9db9 1px solid; padding-top: 4px; border-bottom: #7f9db9 1px solid; font-family: tahoma"></CalendarStyle>
<DisabledDayStyle CssText="font-family: tahoma; font-size: 12px; color: gray; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></DisabledDayStyle>
<MonthStyle CssText="font-family: tahoma; font-size: 12px; margin-left: 14px; cursor: hand; margin-right: 14px"></MonthStyle>
</DatePicker>
</eo:DateTimeColumn>
<eo:DateTimeColumn>
<DatePicker DayHeaderFormat="FirstLetter" DayCellHeight="16" DisabledDates="" TitleLeftArrowImageUrl="DefaultSubMenuIconRTL"
OtherMonthDayVisible="True" DayCellWidth="19" TitleRightArrowImageUrl="DefaultSubMenuIcon"
ControlSkinID="None" SelectedDates="" PickerFormat="dd/MM/yyyy">
<DayHoverStyle CssText="font-family: tahoma; font-size: 12px; border-right: #fbe694 1px solid; border-top: #fbe694 1px solid; border-left: #fbe694 1px solid; border-bottom: #fbe694 1px solid"></DayHoverStyle>
<TitleStyle CssText="background-color:#9ebef5;font-family:Tahoma;font-size:12px;padding-bottom:2px;padding-left:6px;padding-right:6px;padding-top:2px;"></TitleStyle>
<DayHeaderStyle CssText="font-family: tahoma; font-size: 12px; border-bottom: #aca899 1px solid"></DayHeaderStyle>
<DayStyle CssText="font-family: tahoma; font-size: 12px; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></DayStyle>
<SelectedDayStyle CssText="font-family: tahoma; font-size: 12px; background-color: #fbe694; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></SelectedDayStyle>
<TitleArrowStyle CssText="cursor:hand"></TitleArrowStyle>
<TodayStyle CssText="font-family: tahoma; font-size: 12px; border-right: #bb5503 1px solid; border-top: #bb5503 1px solid; border-left: #bb5503 1px solid; border-bottom: #bb5503 1px solid"></TodayStyle>
<PickerStyle CssText="border-bottom-color:#7f9db9;border-bottom-style:solid;border-bottom-width:1px;border-left-color:#7f9db9;border-left-style:solid;border-left-width:1px;border-right-color:#7f9db9;border-right-style:solid;border-right-width:1px;border-top-color:#7f9db9;border-top-style:solid;border-top-width:1px;font-family:Courier New;font-size:8pt;margin-bottom:0px;margin-left:0px;margin-right:0px;margin-top:0px;padding-bottom:1px;padding-left:2px;padding-right:2px;padding-top:2px;"></PickerStyle>
<OtherMonthDayStyle CssText="font-family: tahoma; font-size: 12px; color: gray; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></OtherMonthDayStyle>
<CalendarStyle CssText="background-color: white; border-right: #7f9db9 1px solid; padding-right: 4px; border-top: #7f9db9 1px solid; padding-left: 4px; font-size: 9px; padding-bottom: 4px; border-left: #7f9db9 1px solid; padding-top: 4px; border-bottom: #7f9db9 1px solid; font-family: tahoma"></CalendarStyle>
<DisabledDayStyle CssText="font-family: tahoma; font-size: 12px; color: gray; border-right: white 1px solid; border-top: white 1px solid; border-left: white 1px solid; border-bottom: white 1px solid"></DisabledDayStyle>
<MonthStyle CssText="font-family: tahoma; font-size: 12px; margin-left: 14px; cursor: hand; margin-right: 14px"></MonthStyle>
</DatePicker>
</eo:DateTimeColumn>
<eo:MaskedEditColumn>
<MaskedEdit ControlSkinID="None" TextBoxStyle-CssText="BORDER-RIGHT: #7f9db9 1px solid; PADDING-RIGHT: 2px; BORDER-TOP: #7f9db9 1px solid; PADDING-LEFT: 2px; PADDING-BOTTOM: 1px; MARGIN: 0px; BORDER-LEFT: #7f9db9 1px solid; PADDING-TOP: 2px; BORDER-BOTTOM: #7f9db9 1px solid; font-family:Courier New;font-size:8pt;"></MaskedEdit>
</eo:MaskedEditColumn>
</ColumnTemplates>
<Columns>
<eo:RowNumberColumn Width="40"></eo:RowNumberColumn>
<eo:TextBoxColumn Width="110" HeaderText="Item"></eo:TextBoxColumn>
<eo:DateTimeColumn Width="80" HeaderText="StartDate"></eo:DateTimeColumn>
<eo:DateTimeColumn Width="80" HeaderText="EndDate"></eo:DateTimeColumn>
<eo:DateTimeColumn Width="80" HeaderText="DueDate"></eo:DateTimeColumn>
</Columns>
<ColumnHeaderStyle CssText="background-image:url('00050101');padding-left:8px;padding-top:3px;"></ColumnHeaderStyle>
</eo:Grid>
<asp:Label ID="Label1" runat="server" ></asp:Label>
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" />
I will create test page in a short while to put on our staging server. Many Thanks, Teju
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
I see your code getting "txtanswers" and "txtcorrect" from the first and second column. So my questions to you:
1. Why do you get txtanswers from your first column? The first column is a RowNumberColumn. The contents is always row number.
2. Your third column, not second column is a DateTime column. Where is the code that retrieves value from that column?
Thanks
|
|
Rank: Member Groups: Member
Joined: 1/23/2009 Posts: 12
|
Thanks, very much !!!. It works great. My next question is . Is there any way of validating I mean if some one appends a row but doesn't put any information.
Sorry for any trouble. Many Thanks, Teju
|
|
Rank: Administration Groups: Administration
Joined: 5/27/2007 Posts: 24,229
|
That will be up to you. The Grid does not do any validation for you.
Thanks
|
|