- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的程序中,用户能够将学生分组到一个类(class)中。在我的代码中,似乎存在一些奇怪的逻辑错误;我的数据库使用 StudentsGroups
表将一个组链接到学生。虽然输入应如下所示:
+---------------------+----------------------------------+
| studentsgroups | groups |
+---------+-----------+---------+-----------+------------+
| groupID | studentID | groupID | groupName | groupFocus |
+---------+-----------+---------+-----------+------------+
| 1 | 1 | 1 | TestGroup | Maths |
| 1 | 2 +---------+-----------+------------+
| 1 | 3 |
+---------+-----------+
我的输出看起来像这样:
+---------+-----------+
| groupID | studentID |
+---------+-----------+
| 1 | 0 |
| 2 | 0 |
| 3 | 0 |
+---------+-----------+
groups
表为空。我没有从中收到任何错误消息,据我所知,我的代码运行良好,但在此过程中的某个地方出现了问题。
Private Sub btnSubmit_Click(sender As Object, e As EventArgs) Handles btnSubmit.Click
' We create a new instance of a Groups object to store our entered values; the group's name
' the group's focus and the students in this group
Dim newGroup As New Groups
newGroup.strGroupName = txtGroupName.Text
newGroup.strGroupFocus = cmbGroupFocus.SelectedValue
' We add every student in this group list to the Groups object's student list.
For i As Integer = 0 To lstGroupList.Items.Count - 1
newGroup.addStudent(groupList.Item(i))
Next
' Firstly, we must insert a new group into the database. This will allow us to link every
' student in the group to this group in our StudentsGroups table.
Using conn As New MySqlConnection(connString)
conn.Open()
Using cmd As New MySqlCommand
cmd.Connection = conn
cmd.CommandText = "INSERT INTO groups(groupName, groupFocus) VALUES(@grpName, @grpFocus);"
cmd.Parameters.AddWithValue("@grpName", newGroup.strGroupName)
cmd.Parameters.AddWithValue("@grpFocus", newGroup.strGroupFocus)
End Using
conn.Close()
End Using
Try
' To get the ID of the group generated by the database, we make a temporary string to
' hold the ID value.
Dim groupID As String
Using conn As New MySqlConnection(connString)
conn.Open()
Using selComm As New MySqlCommand
' We create a SELECT query to find the new ID by using the entered group's name.
selComm.Connection = conn
selComm.CommandText = "SELECT groupID FROM groups WHERE groupName = @groupName;"
selComm.Parameters.AddWithValue("@groupName", newGroup.strGroupName)
selComm.Prepare()
' We use the ExecuteScalar method, which would return the very first entry on the
' first row. Since we only want one row and one result, this is better than using
' a DataTable and DataReader.
groupID = selComm.ExecuteScalar()
End Using
conn.Close()
End Using
' Now we begin to link the students to their group. We run through every student in the
' group list and add in their ID along with the group's ID to the table.
For i As Integer = 0 To groupList.Count - 1
Using conn As New MySqlConnection(connString)
conn.Open()
Using newCommand As New MySqlCommand
newCommand.Connection = conn
newCommand.CommandText = "INSERT INTO studentsgroups VALUES(@groupID, @studentID);"
newCommand.Parameters.AddWithValue("@groupID", CInt(groupID))
' To get the student's ID, we do the same process as above; make a new
' command to get the student's ID, using ExecuteScalar.
Dim studentID As String
' When processing a new command, we need a new connection item to
Using conn2 As New MySqlConnection(connString)
conn2.Open()
Using comm2 As New MySqlCommand
comm2.Connection = conn2
comm2.CommandText = "SELECT idNumber FROM students WHERE passCode = @passcode"
comm2.Parameters.AddWithValue("@passcode", groupList.Item(i).intIDNum)
comm2.Prepare()
studentID = comm2.ExecuteScalar()
End Using
conn2.Close()
End Using
newCommand.Parameters.AddWithValue("@studentID", CInt(studentID))
newCommand.Prepare()
newCommand.ExecuteNonQuery()
End Using
conn.Close()
End Using
Next
Catch ex As Exception
MsgBox("Error: " & ex.ToString())
Finally
MsgBox("New Group created!")
Me.Close()
End Try
End Sub
这是提交部分的相关代码,有人知道逻辑问题可能出现在哪里吗?
最佳答案
使用组表,您可以打开连接、格式化命令,然后关闭连接,而无需执行命令。添加行
cmd.ExecuteNonQuery()
在“使用 cmd...” block 的末尾。
我没有看到导致您的GroupID更改的逻辑错误,但我怀疑罪魁祸首是studentgroups表的groupID列设置为AutoIncrement(可能是因为大多数mySQL客户端默认第一列作为主键) 。构建表时请注意这一点,请记住,只有唯一值才应设置为主键,并且并非每个表都需要主键。
至于为什么你的studentID列的每一行都是0,我在遵循你的代码时遇到了一些麻烦。在行中:
comm2.CommandText = "SELECT idNumber FROM students WHERE passCode = @passcode"
comm2.Parameters.AddWithValue("@passcode", groupList.Item(i).intIDNum)
您似乎:1) 提供学生 ID 号 2) 查找学生 ID 号与 passCode 列匹配的行,以及 3) 从这些行中获取学生 ID 号。如果不了解更多有关您的数据库架构和 GUI 结构的信息,我无法判断这是否是问题或如何解决它,但让我问您:
您是否需要编写查询来获取群组中每个人的学生 ID 号?用户似乎已经选择了要添加的学生,并且此信息已存储在您的表单中。像这样的东西:
newCommand.Parameters.AddWithValue("@groupID", CInt(groupID))
'Delete everything between these two lines
newCommand.Parameters.AddWithValue("@studentID", groupList.Item(i).intIDNum)
如果我正确地推断了你的设置,那应该可以工作。如果没有,请绘制学生表格并准确解释您可以从表格访问其中的哪些列。
关于mysql - 添加数据库时出现逻辑错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30302151/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!