()
| 134 | } |
| 135 | |
| 136 | func (rows *mysqlRows) nextResultSet() (int, error) { |
| 137 | if rows.mc == nil { |
| 138 | return 0, io.EOF |
| 139 | } |
| 140 | if err := rows.mc.error(); err != nil { |
| 141 | return 0, err |
| 142 | } |
| 143 | |
| 144 | // Remove unread packets from stream |
| 145 | if !rows.rs.done { |
| 146 | if err := rows.mc.skipRows(); err != nil { |
| 147 | return 0, err |
| 148 | } |
| 149 | rows.rs.done = true |
| 150 | } |
| 151 | |
| 152 | if !rows.HasNextResultSet() { |
| 153 | rows.mc = nil |
| 154 | return 0, io.EOF |
| 155 | } |
| 156 | rows.rs = resultSet{} |
| 157 | // rows.mc.affectedRows and rows.mc.insertIds accumulate on each call to |
| 158 | // nextResultSet. |
| 159 | resLen, _, err := rows.mc.resultUnchanged().readResultSetHeaderPacket() |
| 160 | if err != nil { |
| 161 | // Clean up about multi-results flag |
| 162 | rows.rs.done = true |
| 163 | rows.mc.status = rows.mc.status & (^statusMoreResultsExists) |
| 164 | } |
| 165 | return resLen, err |
| 166 | } |
| 167 | |
| 168 | func (rows *mysqlRows) nextNotEmptyResultSet() (int, error) { |
| 169 | for { |
no test coverage detected